amino
Lightweight Robot Utility Library
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
scene_dyn.h
Go to the documentation of this file.
1 /* -*- mode: C; c-basic-offset: 4; -*- */
2 /* ex: set shiftwidth=4 tabstop=4 expandtab: */
3 /*
4  * Copyright (c) 2015, Rice University
5  * All rights reserved.
6  *
7  * Author(s): Neil T. Dantam <ntd@rice.edu>
8  *
9  * Redistribution and use in source and binary forms, with or
10  * without modification, are permitted provided that the following
11  * conditions are met:
12  * * Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  * * Redistributions in binary form must reproduce the above
15  * copyright notice, this list of conditions and the following
16  * disclaimer in the documentation and/or other materials provided
17  * with the distribution.
18  * * Neither the name of copyright holder the names of its
19  * contributors may be used to endorse or promote products derived
20  * from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
23  * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
24  * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
25  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
26  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
27  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
28  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
29  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
30  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
31  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
33  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34  * POSSIBILITY OF SUCH DAMAGE.
35  *
36  */
37 
38 #ifndef AMINO_SCENE_DYN_H
39 #define AMINO_SCENE_DYN_H
40 
54 AA_API void
55 aa_rx_sg_frame_set_inertial( struct aa_rx_sg *scenegraph,
56  const char *frame,
57  double mass,
58  const double inertia[9] );
64 AA_API double
65 aa_rx_sg_frame_get_mass( struct aa_rx_sg *scenegraph,
66  aa_rx_frame_id frame );
67 
74 AA_API const double*
75 aa_rx_sg_frame_get_inertia( struct aa_rx_sg *scenegraph,
76  aa_rx_frame_id frame );
77 
78 #endif /*AMINO_SCENE_DYN_H*/
signed long aa_rx_frame_id
Type for frame indices.
Definition: scenegraph.h:49
Opaque type for a scene_graph.
AA_API const double * aa_rx_sg_frame_get_inertia(struct aa_rx_sg *scenegraph, aa_rx_frame_id frame)
Get the frame inertia tensor.
#define AA_API
calling and name mangling convention for functions
Definition: amino.h:95
AA_API double aa_rx_sg_frame_get_mass(struct aa_rx_sg *scenegraph, aa_rx_frame_id frame)
Get the frame mass.
AA_API void aa_rx_sg_frame_set_inertial(struct aa_rx_sg *scenegraph, const char *frame, double mass, const double inertia[9])
Set the frame inertial parameters.