2016-04-30 18:18:54 +00:00
# include "../SharedMemory/PhysicsClientC_API.h"
2016-05-10 07:57:54 +00:00
# include "../SharedMemory/PhysicsDirectC_API.h"
2016-06-17 01:46:34 +00:00
# include "../SharedMemory/SharedMemoryInProcessPhysicsC_API.h"
2016-11-04 20:15:10 +00:00
# ifdef BT_ENABLE_ENET
# include "../SharedMemory/PhysicsClientUDP_C_API.h"
2017-03-13 23:06:52 +00:00
# endif //BT_ENABLE_ENET
2018-07-30 15:53:37 +00:00
# define PYBULLET_PI (3.1415926535897932384626433832795029)
2016-09-11 10:09:51 +00:00
2018-07-01 21:42:32 +00:00
# ifdef BT_ENABLE_DART
# include "../SharedMemory/dart/DARTPhysicsC_API.h"
# endif
# ifdef BT_ENABLE_MUJOCO
# include "../SharedMemory/mujoco/MuJoCoPhysicsC_API.h"
# endif
2018-09-04 06:13:15 +00:00
# ifdef BT_ENABLE_GRPC
# include "../SharedMemory/PhysicsClientGRPC_C_API.h"
# endif
2017-02-21 04:34:05 +00:00
# ifdef BT_ENABLE_CLSOCKET
# include "../SharedMemory/PhysicsClientTCP_C_API.h"
2017-03-13 23:06:52 +00:00
# endif //BT_ENABLE_CLSOCKET
2017-02-21 04:34:05 +00:00
2017-04-11 19:17:08 +00:00
# if defined(__APPLE__) && (!defined(B3_NO_PYTHON_FRAMEWORK))
2016-04-30 18:18:54 +00:00
# include <Python/Python.h>
# else
# include <Python.h>
# endif
2017-12-28 18:05:51 +00:00
# include "../Importers/ImportURDFDemo/urdfStringSplit.h"
2017-04-11 19:17:08 +00:00
# ifdef B3_DUMP_PYTHON_VERSION
# define B3_VALUE_TO_STRING(x) #x
# define B3_VALUE(x) B3_VALUE_TO_STRING(x)
2018-09-23 21:17:31 +00:00
# define B3_VAR_NAME_VALUE(var) #var "=" B3_VALUE(var)
2017-04-11 19:17:08 +00:00
# pragma message(B3_VAR_NAME_VALUE(PY_MAJOR_VERSION))
# pragma message(B3_VAR_NAME_VALUE(PY_MINOR_VERSION))
# endif
2016-09-11 10:09:51 +00:00
# ifdef PYBULLET_USE_NUMPY
# include <numpy/arrayobject.h>
# endif
2016-06-23 05:10:00 +00:00
# if PY_MAJOR_VERSION >= 3
# define PyInt_FromLong PyLong_FromLong
# define PyString_FromString PyBytes_FromString
2016-09-08 18:12:58 +00:00
# endif
2016-06-23 05:10:00 +00:00
2016-09-08 18:12:58 +00:00
static PyObject * SpamError ;
2016-12-28 04:25:52 +00:00
# define MAX_PHYSICS_CLIENTS 1024
2016-12-29 05:51:54 +00:00
static b3PhysicsClientHandle sPhysicsClients1 [ MAX_PHYSICS_CLIENTS ] = { 0 } ;
2017-01-21 22:30:37 +00:00
static int sPhysicsClientsGUI [ MAX_PHYSICS_CLIENTS ] = { 0 } ;
2017-03-13 23:06:52 +00:00
static int sNumPhysicsClients = 0 ;
2016-05-03 19:59:21 +00:00
2016-12-29 05:51:54 +00:00
b3PhysicsClientHandle getPhysicsClient ( int physicsClientId )
{
b3PhysicsClientHandle sm ;
2017-03-13 23:06:52 +00:00
if ( ( physicsClientId < 0 ) | | ( physicsClientId > = MAX_PHYSICS_CLIENTS ) | | ( 0 = = sPhysicsClients1 [ physicsClientId ] ) )
2016-12-29 05:51:54 +00:00
{
return 0 ;
}
sm = sPhysicsClients1 [ physicsClientId ] ;
if ( sm )
{
if ( b3CanSubmitCommand ( sm ) )
{
return sm ;
}
//broken connection?
b3DisconnectSharedMemory ( sm ) ;
sPhysicsClients1 [ physicsClientId ] = 0 ;
2017-01-21 22:30:37 +00:00
sPhysicsClientsGUI [ physicsClientId ] = 0 ;
2016-12-29 05:51:54 +00:00
sNumPhysicsClients - - ;
}
return 0 ;
}
2016-11-28 23:11:34 +00:00
2017-03-13 23:06:52 +00:00
static double pybullet_internalGetFloatFromSequence ( PyObject * seq , int index )
{
2016-11-28 23:11:34 +00:00
double v = 0.0 ;
PyObject * item ;
2017-03-13 23:06:52 +00:00
if ( PyList_Check ( seq ) )
{
2016-11-28 23:11:34 +00:00
item = PyList_GET_ITEM ( seq , index ) ;
v = PyFloat_AsDouble ( item ) ;
}
2017-03-13 23:06:52 +00:00
else
{
2016-11-28 23:11:34 +00:00
item = PyTuple_GET_ITEM ( seq , index ) ;
v = PyFloat_AsDouble ( item ) ;
}
return v ;
}
2017-06-19 17:14:26 +00:00
static int pybullet_internalGetIntFromSequence ( PyObject * seq , int index )
{
int v = 0 ;
PyObject * item ;
if ( PyList_Check ( seq ) )
{
item = PyList_GET_ITEM ( seq , index ) ;
v = PyLong_AsLong ( item ) ;
}
else
{
item = PyTuple_GET_ITEM ( seq , index ) ;
v = PyLong_AsLong ( item ) ;
}
return v ;
}
2016-11-28 23:11:34 +00:00
// internal function to set a float matrix[16]
// used to initialize camera position with
// a view and projection matrix in renderImage()
//
// // Args:
// matrix - float[16] which will be set by values from objMat
2017-03-13 23:06:52 +00:00
static int pybullet_internalSetMatrix ( PyObject * objMat , float matrix [ 16 ] )
{
2016-11-28 23:11:34 +00:00
int i , len ;
PyObject * seq ;
2018-09-23 21:17:31 +00:00
if ( objMat = = NULL )
2017-05-18 00:25:34 +00:00
return 0 ;
2016-11-28 23:11:34 +00:00
seq = PySequence_Fast ( objMat , " expected a sequence " ) ;
if ( seq )
{
len = PySequence_Size ( objMat ) ;
2017-03-13 23:06:52 +00:00
if ( len = = 16 )
{
for ( i = 0 ; i < len ; i + + )
{
2016-11-28 23:11:34 +00:00
matrix [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
Py_DECREF ( seq ) ;
return 1 ;
}
Py_DECREF ( seq ) ;
}
2017-11-13 05:53:14 +00:00
PyErr_Clear ( ) ;
2016-11-28 23:11:34 +00:00
return 0 ;
}
// internal function to set a float vector[3]
// used to initialize camera position with
// a view and projection matrix in renderImage()
//
// // Args:
// vector - float[3] which will be set by values from objMat
2017-03-13 23:06:52 +00:00
static int pybullet_internalSetVector ( PyObject * objVec , float vector [ 3 ] )
{
2016-11-28 23:11:34 +00:00
int i , len ;
PyObject * seq = 0 ;
2017-05-18 00:25:34 +00:00
2016-11-28 23:11:34 +00:00
if ( objVec = = NULL )
return 0 ;
seq = PySequence_Fast ( objVec , " expected a sequence " ) ;
if ( seq )
{
len = PySequence_Size ( objVec ) ;
2018-01-08 20:25:56 +00:00
assert ( len = = 3 ) ;
2017-03-13 23:06:52 +00:00
if ( len = = 3 )
{
for ( i = 0 ; i < len ; i + + )
{
2016-11-28 23:11:34 +00:00
vector [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
Py_DECREF ( seq ) ;
return 1 ;
}
Py_DECREF ( seq ) ;
}
2017-11-13 05:53:14 +00:00
PyErr_Clear ( ) ;
2016-11-28 23:11:34 +00:00
return 0 ;
}
// vector - double[3] which will be set by values from obVec
2017-03-13 23:06:52 +00:00
static int pybullet_internalSetVectord ( PyObject * obVec , double vector [ 3 ] )
{
2016-11-28 23:11:34 +00:00
int i , len ;
PyObject * seq ;
if ( obVec = = NULL )
return 0 ;
seq = PySequence_Fast ( obVec , " expected a sequence " ) ;
if ( seq )
{
len = PySequence_Size ( obVec ) ;
2018-01-08 20:25:56 +00:00
assert ( len = = 3 ) ;
2017-03-13 23:06:52 +00:00
if ( len = = 3 )
{
for ( i = 0 ; i < len ; i + + )
{
2016-11-28 23:11:34 +00:00
vector [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
Py_DECREF ( seq ) ;
return 1 ;
}
Py_DECREF ( seq ) ;
}
2017-11-13 05:53:14 +00:00
PyErr_Clear ( ) ;
2016-11-28 23:11:34 +00:00
return 0 ;
}
// vector - double[3] which will be set by values from obVec
2017-03-13 23:06:52 +00:00
static int pybullet_internalSetVector4d ( PyObject * obVec , double vector [ 4 ] )
{
2016-11-28 23:11:34 +00:00
int i , len ;
PyObject * seq ;
if ( obVec = = NULL )
return 0 ;
seq = PySequence_Fast ( obVec , " expected a sequence " ) ;
2017-11-12 18:36:30 +00:00
if ( seq )
2017-03-13 23:06:52 +00:00
{
2017-11-12 18:36:30 +00:00
len = PySequence_Size ( obVec ) ;
if ( len = = 4 )
2017-03-13 23:06:52 +00:00
{
2017-11-12 18:36:30 +00:00
for ( i = 0 ; i < len ; i + + )
{
vector [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
Py_DECREF ( seq ) ;
return 1 ;
2016-11-28 23:11:34 +00:00
}
Py_DECREF ( seq ) ;
}
2017-11-13 05:53:14 +00:00
PyErr_Clear ( ) ;
2016-11-28 23:11:34 +00:00
return 0 ;
}
2017-06-19 17:14:26 +00:00
static int pybullet_internalGetVector3FromSequence ( PyObject * seq , int index , double vec [ 3 ] )
{
int v = 0 ;
PyObject * item ;
if ( PyList_Check ( seq ) )
{
item = PyList_GET_ITEM ( seq , index ) ;
2018-09-23 21:17:31 +00:00
pybullet_internalSetVectord ( item , vec ) ;
2017-06-19 17:14:26 +00:00
}
else
{
2018-09-11 20:24:35 +00:00
item = PyTuple_GET_ITEM ( seq , index ) ;
2018-09-23 21:17:31 +00:00
pybullet_internalSetVectord ( item , vec ) ;
2017-06-19 17:14:26 +00:00
}
return v ;
}
static int pybullet_internalGetVector4FromSequence ( PyObject * seq , int index , double vec [ 4 ] )
{
int v = 0 ;
PyObject * item ;
if ( PyList_Check ( seq ) )
{
item = PyList_GET_ITEM ( seq , index ) ;
2018-09-23 21:17:31 +00:00
pybullet_internalSetVector4d ( item , vec ) ;
2017-06-19 17:14:26 +00:00
}
else
{
2018-09-11 20:24:35 +00:00
item = PyTuple_GET_ITEM ( seq , index ) ;
2018-09-23 21:17:31 +00:00
pybullet_internalSetVector4d ( item , vec ) ;
2017-06-19 17:14:26 +00:00
}
return v ;
}
2016-06-10 22:07:41 +00:00
// Step through one timestep of the simulation
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_stepSimulation ( PyObject * self , PyObject * args , PyObject * keywds )
2016-12-28 04:25:52 +00:00
{
int physicsClientId = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
b3PhysicsClientHandle sm = 0 ;
2016-04-30 18:18:54 +00:00
2017-03-13 23:06:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-04-30 18:18:54 +00:00
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
if ( b3CanSubmitCommand ( sm ) )
{
statusHandle = b3SubmitClientCommandAndWaitStatus (
sm , b3InitStepSimulationCommand ( sm ) ) ;
statusType = b3GetStatusType ( statusHandle ) ;
}
2016-12-28 04:25:52 +00:00
}
2017-03-13 23:06:52 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_connectPhysicsServer ( PyObject * self , PyObject * args , PyObject * keywds )
{
int freeIndex = - 1 ;
int method = eCONNECT_GUI ;
int i ;
2018-09-23 21:17:31 +00:00
char * options = 0 ;
2017-08-15 00:02:20 +00:00
2017-03-13 23:06:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2016-11-05 00:06:55 +00:00
2017-03-13 23:06:52 +00:00
if ( sNumPhysicsClients > = MAX_PHYSICS_CLIENTS )
2016-11-05 00:06:55 +00:00
{
2017-03-13 23:06:52 +00:00
PyErr_SetString ( SpamError ,
" Exceeding maximum number of physics connections. " ) ;
return NULL ;
2016-11-05 00:06:55 +00:00
}
2017-01-21 22:30:37 +00:00
{
2017-03-13 23:06:52 +00:00
int key = SHARED_MEMORY_KEY ;
int udpPort = 1234 ;
int tcpPort = 6667 ;
2018-09-20 16:07:47 +00:00
int grpcPort = - 1 ;
2018-01-09 16:43:00 +00:00
int argc = 0 ;
2018-09-23 21:17:31 +00:00
char * * argv = 0 ;
2017-03-13 23:06:52 +00:00
const char * hostName = " localhost " ;
2018-09-23 21:17:31 +00:00
static char * kwlist1 [ ] = { " method " , " key " , " options " , NULL } ;
static char * kwlist2 [ ] = { " method " , " hostName " , " port " , " options " , NULL } ;
2017-03-30 18:01:33 +00:00
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|is " , kwlist1 , & method , & key , & options ) )
2017-01-21 22:30:37 +00:00
{
2017-03-30 18:01:33 +00:00
int port = - 1 ;
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|sis " , kwlist2 , & method , & hostName , & port , & options ) )
2017-01-21 22:30:37 +00:00
{
return NULL ;
2018-09-23 21:17:31 +00:00
}
else
2017-03-30 18:01:33 +00:00
{
PyErr_Clear ( ) ;
2018-09-23 21:17:31 +00:00
if ( port > = 0 )
2017-03-30 18:01:33 +00:00
{
udpPort = port ;
tcpPort = port ;
2018-09-20 16:07:47 +00:00
grpcPort = port ;
2017-03-30 18:01:33 +00:00
}
2017-01-21 22:30:37 +00:00
}
}
2017-03-13 23:06:52 +00:00
//Only one local in-process GUI connection allowed.
if ( method = = eCONNECT_GUI )
2016-11-05 00:06:55 +00:00
{
2017-03-13 23:06:52 +00:00
int i ;
for ( i = 0 ; i < MAX_PHYSICS_CLIENTS ; i + + )
2016-11-05 00:06:55 +00:00
{
2017-08-15 21:15:30 +00:00
if ( ( sPhysicsClientsGUI [ i ] = = eCONNECT_GUI ) | | ( sPhysicsClientsGUI [ i ] = = eCONNECT_GUI_SERVER ) )
2017-03-13 23:06:52 +00:00
{
PyErr_SetString ( SpamError ,
2017-08-15 21:15:30 +00:00
" Only one local in-process GUI/GUI_SERVER connection allowed. Use DIRECT connection mode or start a separate GUI physics server (ExampleBrowser, App_SharedMemoryPhysics_GUI, App_SharedMemoryPhysics_VR) and connect over SHARED_MEMORY, UDP or TCP instead. " ) ;
2017-03-13 23:06:52 +00:00
return NULL ;
}
}
}
2016-11-05 00:06:55 +00:00
2017-12-28 18:05:51 +00:00
if ( options )
{
2017-12-28 20:57:49 +00:00
int i ;
2017-12-28 18:05:51 +00:00
argv = urdfStrSplit ( options , " " ) ;
argc = urdfStrArrayLen ( argv ) ;
2017-12-28 20:57:49 +00:00
for ( i = 0 ; i < argc ; i + + )
2017-12-28 18:05:51 +00:00
{
printf ( " argv[%d]=%s \n " , i , argv [ i ] ) ;
}
}
2017-03-13 23:06:52 +00:00
switch ( method )
{
case eCONNECT_GUI :
{
2016-05-10 07:57:54 +00:00
# ifdef __APPLE__
2017-08-16 19:33:25 +00:00
sm = b3CreateInProcessPhysicsServerAndConnectMainThread ( argc , argv ) ;
2017-08-15 00:02:20 +00:00
# else
2017-08-16 19:33:25 +00:00
sm = b3CreateInProcessPhysicsServerAndConnect ( argc , argv ) ;
2017-08-15 00:02:20 +00:00
# endif
break ;
}
2018-02-15 00:49:44 +00:00
case eCONNECT_GUI_MAIN_THREAD :
2018-09-23 21:17:31 +00:00
{
sm = b3CreateInProcessPhysicsServerAndConnectMainThread ( argc , argv ) ;
break ;
}
2017-08-15 00:02:20 +00:00
case eCONNECT_GUI_SERVER :
{
# ifdef __APPLE__
2017-08-16 19:33:25 +00:00
sm = b3CreateInProcessPhysicsServerAndConnectMainThreadSharedMemory ( argc , argv ) ;
2016-05-10 07:57:54 +00:00
# else
2017-08-16 19:33:25 +00:00
sm = b3CreateInProcessPhysicsServerAndConnectSharedMemory ( argc , argv ) ;
2016-05-10 07:57:54 +00:00
# endif
2017-03-13 23:06:52 +00:00
break ;
}
2018-09-23 21:17:31 +00:00
case eCONNECT_SHARED_MEMORY_SERVER :
{
sm = b3CreateInProcessPhysicsServerFromExistingExampleBrowserAndConnect3 ( 0 , key ) ;
break ;
}
2017-03-13 23:06:52 +00:00
case eCONNECT_DIRECT :
{
sm = b3ConnectPhysicsDirect ( ) ;
break ;
}
2018-07-01 21:42:32 +00:00
# ifdef BT_ENABLE_DART
case eCONNECT_DART :
{
sm = b3ConnectPhysicsDART ( ) ;
break ;
}
# endif
# ifdef BT_ENABLE_MUJOCO
case eCONNECT_MUJOCO :
{
sm = b3ConnectPhysicsMuJoCo ( ) ;
break ;
}
# endif
2018-09-04 06:13:15 +00:00
case eCONNECT_GRPC :
{
# ifdef BT_ENABLE_GRPC
2018-09-20 16:07:47 +00:00
sm = b3ConnectPhysicsGRPC ( hostName , grpcPort ) ;
2018-09-04 06:13:15 +00:00
# else
2018-09-04 16:10:57 +00:00
PyErr_SetString ( SpamError , " GRPC is not enabled in this pybullet build " ) ;
2018-09-04 06:13:15 +00:00
# endif
break ;
2018-09-23 21:17:31 +00:00
}
2017-03-13 23:06:52 +00:00
case eCONNECT_SHARED_MEMORY :
{
sm = b3ConnectSharedMemory ( key ) ;
break ;
}
case eCONNECT_UDP :
{
2016-11-04 20:15:10 +00:00
# ifdef BT_ENABLE_ENET
2017-03-13 23:06:52 +00:00
sm = b3ConnectPhysicsUDP ( hostName , udpPort ) ;
2016-11-04 20:15:10 +00:00
# else
2017-03-13 23:06:52 +00:00
PyErr_SetString ( SpamError , " UDP is not enabled in this pybullet build " ) ;
return NULL ;
# endif //BT_ENABLE_ENET
2016-11-04 20:15:10 +00:00
2017-03-13 23:06:52 +00:00
break ;
}
case eCONNECT_TCP :
{
2017-02-21 04:34:05 +00:00
# ifdef BT_ENABLE_CLSOCKET
2017-03-13 23:06:52 +00:00
sm = b3ConnectPhysicsTCP ( hostName , tcpPort ) ;
2017-02-21 04:34:05 +00:00
# else
2017-03-13 23:06:52 +00:00
PyErr_SetString ( SpamError , " TCP is not enabled in this pybullet build " ) ;
return NULL ;
# endif //BT_ENABLE_CLSOCKET
break ;
}
default :
{
PyErr_SetString ( SpamError , " connectPhysicsServer unexpected argument " ) ;
return NULL ;
}
} ;
2017-12-28 18:05:51 +00:00
if ( options )
{
urdfStrArrayFree ( argv ) ;
}
2017-03-13 23:06:52 +00:00
}
2018-01-15 16:33:19 +00:00
if ( sm )
2017-03-13 23:06:52 +00:00
{
2018-01-15 16:33:19 +00:00
if ( b3CanSubmitCommand ( sm ) )
2017-03-13 23:06:52 +00:00
{
2018-01-15 16:33:19 +00:00
for ( i = 0 ; i < MAX_PHYSICS_CLIENTS ; i + + )
2017-03-13 23:06:52 +00:00
{
2018-01-15 16:33:19 +00:00
if ( sPhysicsClients1 [ i ] = = 0 )
{
freeIndex = i ;
break ;
}
2017-03-13 23:06:52 +00:00
}
2018-01-15 16:33:19 +00:00
if ( freeIndex > = 0 )
{
b3SharedMemoryCommandHandle command ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2017-01-21 02:13:24 +00:00
2018-01-15 16:33:19 +00:00
sPhysicsClients1 [ freeIndex ] = sm ;
sPhysicsClientsGUI [ freeIndex ] = method ;
sNumPhysicsClients + + ;
2017-01-21 02:13:24 +00:00
2018-01-15 16:33:19 +00:00
command = b3InitSyncBodyInfoCommand ( sm ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2017-09-14 00:05:23 +00:00
2018-09-11 20:24:35 +00:00
if ( statusType ! = CMD_SYNC_BODY_INFO_COMPLETED )
2018-01-15 16:33:19 +00:00
{
printf ( " Connection terminated, couldn't get body info \n " ) ;
b3DisconnectSharedMemory ( sm ) ;
2018-09-23 21:17:31 +00:00
sm = 0 ;
2018-01-15 16:33:19 +00:00
sPhysicsClients1 [ freeIndex ] = 0 ;
2018-09-23 21:17:31 +00:00
sPhysicsClientsGUI [ freeIndex ] = 0 ;
sNumPhysicsClients + + ;
return PyInt_FromLong ( - 1 ) ;
2018-01-15 16:33:19 +00:00
}
2018-06-02 20:40:08 +00:00
command = b3InitSyncUserDataCommand ( sm ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType ! = CMD_SYNC_USER_DATA_COMPLETED )
{
printf ( " Connection terminated, couldn't get user data \n " ) ;
b3DisconnectSharedMemory ( sm ) ;
2018-09-23 21:17:31 +00:00
sm = 0 ;
2018-06-02 20:40:08 +00:00
sPhysicsClients1 [ freeIndex ] = 0 ;
2018-09-23 21:17:31 +00:00
sPhysicsClientsGUI [ freeIndex ] = 0 ;
sNumPhysicsClients + + ;
return PyInt_FromLong ( - 1 ) ;
2018-06-02 20:40:08 +00:00
}
2017-02-22 17:33:30 +00:00
}
2018-09-23 21:17:31 +00:00
}
else
2018-01-15 16:33:19 +00:00
{
b3DisconnectSharedMemory ( sm ) ;
2017-03-13 23:06:52 +00:00
}
}
return PyInt_FromLong ( freeIndex ) ;
2016-09-08 18:12:58 +00:00
}
static PyObject * pybullet_disconnectPhysicsServer ( PyObject * self ,
2017-03-13 23:06:52 +00:00
PyObject * args ,
PyObject * keywds )
{
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
2017-03-13 23:06:52 +00:00
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
{
b3DisconnectSharedMemory ( sm ) ;
sm = 0 ;
}
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
sPhysicsClients1 [ physicsClientId ] = 0 ;
sPhysicsClientsGUI [ physicsClientId ] = 0 ;
sNumPhysicsClients - - ;
2016-12-28 04:25:52 +00:00
2017-03-13 23:06:52 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-05-03 19:59:21 +00:00
}
2017-04-05 22:21:26 +00:00
///to avoid memory leaks, disconnect all physics servers explicitly
void b3pybulletExitFunc ( void )
2017-03-30 20:50:02 +00:00
{
int i ;
2018-09-23 21:17:31 +00:00
for ( i = 0 ; i < MAX_PHYSICS_CLIENTS ; i + + )
2017-03-30 20:50:02 +00:00
{
if ( sPhysicsClients1 [ i ] )
{
b3DisconnectSharedMemory ( sPhysicsClients1 [ i ] ) ;
sPhysicsClients1 [ i ] = 0 ;
sNumPhysicsClients - - ;
}
}
}
2018-01-12 05:04:08 +00:00
static PyObject * pybullet_isConnected ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
int isConnected = 0 ;
int method = 0 ;
PyObject * pylist = 0 ;
PyObject * val = 0 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
2018-01-12 05:04:08 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm ! = 0 )
{
if ( b3CanSubmitCommand ( sm ) )
{
isConnected = 1 ;
method = sPhysicsClientsGUI [ physicsClientId ] ;
}
}
return PyLong_FromLong ( isConnected ) ;
}
2017-10-05 16:02:33 +00:00
static PyObject * pybullet_getConnectionInfo ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
2018-09-23 21:17:31 +00:00
int isConnected = 0 ;
int method = 0 ;
2017-10-05 16:02:33 +00:00
PyObject * pylist = 0 ;
2017-10-05 16:57:17 +00:00
PyObject * val = 0 ;
2017-10-05 16:02:33 +00:00
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm ! = 0 )
{
if ( b3CanSubmitCommand ( sm ) )
{
isConnected = 1 ;
method = sPhysicsClientsGUI [ physicsClientId ] ;
}
}
2018-09-23 21:17:31 +00:00
val = Py_BuildValue ( " {s:i,s:i} " , " isConnected " , isConnected , " connectionMethod " , method ) ;
2017-10-05 16:57:17 +00:00
return val ;
2017-10-05 16:02:33 +00:00
}
2018-05-07 22:57:36 +00:00
static PyObject * pybullet_syncBodyInfo ( PyObject * self , PyObject * args , PyObject * keywds )
{
2018-09-23 21:17:31 +00:00
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
b3SharedMemoryCommandHandle command ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
command = b3InitSyncBodyInfoCommand ( sm ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
if ( statusType ! = CMD_SYNC_BODY_INFO_COMPLETED )
{
PyErr_SetString ( SpamError , " Error in syncBodyzInfo command. " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2018-05-07 22:57:36 +00:00
}
2018-06-02 20:40:08 +00:00
static PyObject * pybullet_syncUserData ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
b3SharedMemoryCommandHandle command ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
command = b3InitSyncUserDataCommand ( sm ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType ! = CMD_SYNC_USER_DATA_COMPLETED )
{
PyErr_SetString ( SpamError , " Error in syncUserInfo command. " ) ;
return NULL ;
}
2018-06-05 16:16:00 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2018-06-02 20:40:08 +00:00
}
static PyObject * pybullet_addUserData ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
int bodyUniqueId = - 1 ;
2018-07-03 15:45:19 +00:00
int linkIndex = - 1 ;
int visualShapeIndex = - 1 ;
2018-06-02 20:40:08 +00:00
const char * key = " " ;
2018-09-23 21:17:31 +00:00
const char * value = " " ; // TODO: Change this to a PyObject and detect the type dynamically.
2018-06-02 20:40:08 +00:00
2018-07-03 15:45:19 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " key " , " value " , " linkIndex " , " visualShapeIndex " , " physicsClientId " , NULL } ;
2018-06-02 20:40:08 +00:00
b3SharedMemoryCommandHandle command ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
int userDataId ;
2018-09-23 21:17:31 +00:00
int valueLen = - 1 ;
2018-06-02 20:40:08 +00:00
2018-07-03 15:45:19 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iss|iii " , kwlist , & bodyUniqueId , & key , & value , & linkIndex , & visualShapeIndex , & physicsClientId ) )
2018-06-02 20:40:08 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-09-23 21:17:31 +00:00
valueLen = strlen ( value ) + 1 ;
2018-07-03 15:45:19 +00:00
command = b3InitAddUserDataCommand ( sm , bodyUniqueId , linkIndex , visualShapeIndex , key , USER_DATA_VALUE_TYPE_STRING , valueLen , value ) ;
2018-06-02 20:40:08 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType ! = CMD_ADD_USER_DATA_COMPLETED )
{
PyErr_SetString ( SpamError , " Error in addUserData command. " ) ;
return NULL ;
}
userDataId = b3GetUserDataIdFromStatus ( statusHandle ) ;
return PyInt_FromLong ( userDataId ) ;
}
static PyObject * pybullet_removeUserData ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
int userDataId = - 1 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " userDataId " , " physicsClientId " , NULL } ;
2018-06-02 20:40:08 +00:00
b3SharedMemoryCommandHandle command ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2018-07-03 15:45:19 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & userDataId , & physicsClientId ) )
2018-06-02 20:40:08 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-07-03 15:45:19 +00:00
command = b3InitRemoveUserDataCommand ( sm , userDataId ) ;
2018-06-02 20:40:08 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType ! = CMD_REMOVE_USER_DATA_COMPLETED )
{
PyErr_SetString ( SpamError , " Error in removeUserData command. " ) ;
2018-06-05 16:16:00 +00:00
return NULL ;
2018-06-02 20:40:08 +00:00
}
2018-06-05 16:16:00 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2018-06-02 20:40:08 +00:00
}
static PyObject * pybullet_getUserDataId ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
int bodyUniqueId = - 1 ;
int linkIndex = - 1 ;
2018-07-03 15:45:19 +00:00
int visualShapeIndex = - 1 ;
2018-06-02 20:40:08 +00:00
const char * key = " " ;
int userDataId ;
2018-07-03 15:45:19 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " key " , " linkIndex " , " visualShapeIndex " , " physicsClientId " , NULL } ;
2018-09-11 20:24:35 +00:00
2018-07-03 15:45:19 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " is|iii " , kwlist , & bodyUniqueId , & key , & linkIndex , & visualShapeIndex , & physicsClientId ) )
2018-06-02 20:40:08 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-07-03 15:45:19 +00:00
userDataId = b3GetUserDataId ( sm , bodyUniqueId , linkIndex , visualShapeIndex , key ) ;
2018-06-02 20:40:08 +00:00
return PyInt_FromLong ( userDataId ) ;
}
static PyObject * pybullet_getUserData ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
int userDataId = - 1 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " userDataId " , " physicsClientId " , NULL } ;
2018-06-02 20:40:08 +00:00
struct b3UserDataValue value ;
2018-07-03 15:45:19 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & userDataId , & physicsClientId ) )
2018-06-02 20:40:08 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-09-23 21:17:31 +00:00
if ( ! b3GetUserData ( sm , userDataId , & value ) )
{
2018-06-09 19:19:29 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2018-06-02 20:40:08 +00:00
}
2018-09-11 20:24:35 +00:00
if ( value . m_type ! = USER_DATA_VALUE_TYPE_STRING )
2018-06-05 16:16:00 +00:00
{
PyErr_SetString ( SpamError , " User data value has unknown type " ) ;
return NULL ;
2018-06-02 20:40:08 +00:00
}
2018-06-05 16:16:00 +00:00
2018-09-23 21:17:31 +00:00
return PyString_FromString ( ( const char * ) value . m_data1 ) ;
2018-06-02 20:40:08 +00:00
}
static PyObject * pybullet_getNumUserData ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
int bodyUniqueId = - 1 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " physicsClientId " , NULL } ;
2018-06-02 20:40:08 +00:00
int numUserData ;
2018-07-03 15:45:19 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & bodyUniqueId , & physicsClientId ) )
2018-06-02 20:40:08 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-07-03 15:45:19 +00:00
numUserData = b3GetNumUserData ( sm , bodyUniqueId ) ;
2018-06-02 20:40:08 +00:00
return PyInt_FromLong ( numUserData ) ;
}
static PyObject * pybullet_getUserDataInfo ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
int bodyUniqueId = - 1 ;
int userDataIndex = - 1 ;
2018-07-03 15:45:19 +00:00
int linkIndex = - 1 ;
int visualShapeIndex = - 1 ;
2018-06-02 20:40:08 +00:00
2018-07-03 15:45:19 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " userDataIndex " , " physicsClientId " , NULL } ;
2018-06-02 20:40:08 +00:00
const char * key = 0 ;
int userDataId = - 1 ;
2018-07-03 15:45:19 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|i " , kwlist , & bodyUniqueId , & userDataIndex , & physicsClientId ) )
2018-06-02 20:40:08 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-07-03 15:45:19 +00:00
b3GetUserDataInfo ( sm , bodyUniqueId , userDataIndex , & key , & userDataId , & linkIndex , & visualShapeIndex ) ;
2018-09-23 21:17:31 +00:00
if ( key = = 0 | | userDataId = = - 1 )
{
2018-06-02 20:40:08 +00:00
PyErr_SetString ( SpamError , " Could not get user data info. " ) ;
2018-06-05 16:16:00 +00:00
return NULL ;
2018-06-02 20:40:08 +00:00
}
2018-06-05 16:16:00 +00:00
2018-06-02 20:40:08 +00:00
{
2018-09-23 21:17:31 +00:00
PyObject * userDataInfoTuple = PyTuple_New ( 5 ) ;
2018-06-02 20:40:08 +00:00
PyTuple_SetItem ( userDataInfoTuple , 0 , PyInt_FromLong ( userDataId ) ) ;
PyTuple_SetItem ( userDataInfoTuple , 1 , PyString_FromString ( key ) ) ;
2018-07-03 15:45:19 +00:00
PyTuple_SetItem ( userDataInfoTuple , 2 , PyInt_FromLong ( bodyUniqueId ) ) ;
PyTuple_SetItem ( userDataInfoTuple , 3 , PyInt_FromLong ( linkIndex ) ) ;
PyTuple_SetItem ( userDataInfoTuple , 4 , PyInt_FromLong ( visualShapeIndex ) ) ;
2018-06-02 20:40:08 +00:00
return userDataInfoTuple ;
}
}
2018-05-07 22:57:36 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_saveWorld ( PyObject * self , PyObject * args , PyObject * keywds )
{
2016-10-13 06:03:36 +00:00
const char * worldFileName = " " ;
2016-12-28 04:25:52 +00:00
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " worldFileName " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|i " , kwlist , & worldFileName , & physicsClientId ) )
2016-10-13 06:03:36 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-10-13 06:03:36 +00:00
{
2017-03-13 23:06:52 +00:00
b3SharedMemoryCommandHandle command ;
2016-10-13 06:03:36 +00:00
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
command = b3SaveWorldCommandInit ( sm , worldFileName ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2017-03-13 23:06:52 +00:00
if ( statusType ! = CMD_SAVE_WORLD_COMPLETED )
{
2016-10-13 06:03:36 +00:00
PyErr_SetString ( SpamError , " saveWorld command execution failed. " ) ;
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2017-03-13 23:06:52 +00:00
}
2016-10-13 06:03:36 +00:00
PyErr_SetString ( SpamError , " Cannot execute saveWorld command. " ) ;
return NULL ;
2016-11-11 22:44:50 +00:00
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_loadBullet ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-11 22:44:50 +00:00
{
const char * bulletFileName = " " ;
2016-11-12 02:07:42 +00:00
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
b3SharedMemoryCommandHandle command ;
2017-03-13 23:06:52 +00:00
int i , numBodies ;
2016-11-14 15:39:34 +00:00
int bodyIndicesOut [ MAX_SDF_BODIES ] ;
2016-12-28 04:25:52 +00:00
PyObject * pylist = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " bulletFileName " , " physicsClientId " , NULL } ;
2017-03-13 23:06:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|i " , kwlist , & bulletFileName , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
2016-11-11 22:44:50 +00:00
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
2016-11-12 02:07:42 +00:00
return NULL ;
2016-11-11 22:44:50 +00:00
}
2016-11-12 02:07:42 +00:00
command = b3LoadBulletCommandInit ( sm , bulletFileName ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType ! = CMD_BULLET_LOADING_COMPLETED )
{
PyErr_SetString ( SpamError , " Couldn't load .bullet file. " ) ;
return NULL ;
}
2016-11-14 15:39:34 +00:00
numBodies =
2017-03-13 23:06:52 +00:00
b3GetStatusBodyIndices ( statusHandle , bodyIndicesOut , MAX_SDF_BODIES ) ;
if ( numBodies > MAX_SDF_BODIES )
{
PyErr_SetString ( SpamError , " loadBullet exceeds body capacity " ) ;
return NULL ;
}
pylist = PyTuple_New ( numBodies ) ;
if ( numBodies > 0 & & numBodies < = MAX_SDF_BODIES )
{
for ( i = 0 ; i < numBodies ; i + + )
{
PyTuple_SetItem ( pylist , i , PyInt_FromLong ( bodyIndicesOut [ i ] ) ) ;
}
}
return pylist ;
2016-11-11 22:44:50 +00:00
}
2016-12-28 04:25:52 +00:00
static PyObject * pybullet_saveBullet ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-11 22:44:50 +00:00
{
const char * bulletFileName = " " ;
2016-11-12 02:07:42 +00:00
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
b3SharedMemoryCommandHandle command ;
2016-12-28 04:25:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2016-11-11 22:44:50 +00:00
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
static char * kwlist [ ] = { " bulletFileName " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|i " , kwlist , & bulletFileName , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
2016-11-11 22:44:50 +00:00
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
2016-11-11 22:44:50 +00:00
}
2016-12-28 04:25:52 +00:00
2016-11-12 02:07:42 +00:00
command = b3SaveBulletCommandInit ( sm , bulletFileName ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
2016-11-14 22:08:05 +00:00
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType ! = CMD_BULLET_SAVING_COMPLETED )
2016-11-12 02:07:42 +00:00
{
PyErr_SetString ( SpamError , " Couldn't save .bullet file. " ) ;
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-11-11 22:44:50 +00:00
}
2016-10-13 06:03:36 +00:00
2017-12-28 18:05:51 +00:00
static PyObject * pybullet_restoreState ( PyObject * self , PyObject * args , PyObject * keywds )
{
const char * fileName = " " ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
int stateId = - 1 ;
b3SharedMemoryCommandHandle command ;
PyObject * pylist = 0 ;
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " stateId " , " fileName " , " physicsClientId " , NULL } ;
2017-12-28 18:05:51 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |isi " , kwlist , & stateId , & fileName , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
command = b3LoadStateCommandInit ( sm ) ;
if ( stateId > = 0 )
{
b3LoadStateSetStateId ( command , stateId ) ;
}
if ( fileName )
{
b3LoadStateSetFileName ( command , fileName ) ;
}
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType ! = CMD_RESTORE_STATE_COMPLETED )
{
PyErr_SetString ( SpamError , " Couldn't restore state. " ) ;
return NULL ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject * pybullet_saveState ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
b3SharedMemoryCommandHandle command ;
b3PhysicsClientHandle sm = 0 ;
int stateId = - 1 ;
int physicsClientId = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
2017-12-28 18:05:51 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
command = b3SaveStateCommandInit ( sm ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType ! = CMD_SAVE_STATE_COMPLETED )
{
PyErr_SetString ( SpamError , " Couldn't save state " ) ;
return NULL ;
}
2017-12-31 23:37:16 +00:00
stateId = b3GetStatusGetStateId ( statusHandle ) ;
2018-09-11 20:24:35 +00:00
return PyInt_FromLong ( stateId ) ;
2017-12-28 18:05:51 +00:00
}
2016-12-28 04:25:52 +00:00
static PyObject * pybullet_loadMJCF ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-11 22:44:50 +00:00
{
2016-12-28 04:25:52 +00:00
const char * mjcfFileName = " " ;
2016-11-12 02:07:42 +00:00
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
b3SharedMemoryCommandHandle command ;
2016-12-28 04:25:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2016-12-31 22:43:15 +00:00
int numBodies = 0 ;
int i ;
int bodyIndicesOut [ MAX_SDF_BODIES ] ;
PyObject * pylist = 0 ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
2017-05-10 22:01:25 +00:00
int flags = - 1 ;
static char * kwlist [ ] = { " mjcfFileName " , " flags " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|ii " , kwlist , & mjcfFileName , & flags , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
2016-11-11 22:44:50 +00:00
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
2016-11-11 22:44:50 +00:00
}
2016-12-28 04:25:52 +00:00
command = b3LoadMJCFCommandInit ( sm , mjcfFileName ) ;
2018-09-23 21:17:31 +00:00
if ( flags > = 0 )
2017-05-10 22:01:25 +00:00
{
2018-09-23 21:17:31 +00:00
b3LoadMJCFCommandSetFlags ( command , flags ) ;
2017-05-10 22:01:25 +00:00
}
2016-11-12 02:07:42 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
2016-11-14 22:08:05 +00:00
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType ! = CMD_MJCF_LOADING_COMPLETED )
2016-11-12 02:07:42 +00:00
{
PyErr_SetString ( SpamError , " Couldn't load .mjcf file. " ) ;
return NULL ;
}
2016-12-31 22:43:15 +00:00
2017-03-13 23:06:52 +00:00
numBodies =
b3GetStatusBodyIndices ( statusHandle , bodyIndicesOut , MAX_SDF_BODIES ) ;
if ( numBodies > MAX_SDF_BODIES )
{
2017-11-04 19:51:13 +00:00
char str [ 1024 ] ;
2018-09-23 21:17:31 +00:00
sprintf ( str , " SDF exceeds body capacity: %d > %d " , numBodies , MAX_SDF_BODIES ) ;
2017-11-04 19:51:13 +00:00
PyErr_SetString ( SpamError , str ) ;
2017-03-13 23:06:52 +00:00
return NULL ;
}
2016-12-31 22:43:15 +00:00
2017-03-13 23:06:52 +00:00
pylist = PyTuple_New ( numBodies ) ;
2016-12-31 22:43:15 +00:00
2017-03-13 23:06:52 +00:00
if ( numBodies > 0 & & numBodies < = MAX_SDF_BODIES )
{
for ( i = 0 ; i < numBodies ; i + + )
{
PyTuple_SetItem ( pylist , i , PyInt_FromLong ( bodyIndicesOut [ i ] ) ) ;
}
}
return pylist ;
2016-11-11 22:44:50 +00:00
}
2017-05-09 17:44:33 +00:00
static PyObject * pybullet_changeDynamicsInfo ( PyObject * self , PyObject * args , PyObject * keywds )
2017-05-02 05:18:54 +00:00
{
int bodyUniqueId = - 1 ;
int linkIndex = - 2 ;
double mass = - 1 ;
2017-05-04 04:47:53 +00:00
double lateralFriction = - 1 ;
2018-09-23 21:17:31 +00:00
double spinningFriction = - 1 ;
2017-05-27 01:14:38 +00:00
double rollingFriction = - 1 ;
double restitution = - 1 ;
2017-06-05 05:04:16 +00:00
double linearDamping = - 1 ;
double angularDamping = - 1 ;
2017-06-07 15:37:42 +00:00
double contactStiffness = - 1 ;
double contactDamping = - 1 ;
2018-09-23 21:17:31 +00:00
double ccdSweptSphereRadius = - 1 ;
2017-06-07 16:37:28 +00:00
int frictionAnchor = - 1 ;
2018-05-23 03:26:00 +00:00
double contactProcessingThreshold = - 1 ;
2018-06-16 04:26:26 +00:00
int activationState = - 1 ;
2018-05-23 03:26:00 +00:00
2018-09-23 21:17:31 +00:00
PyObject * localInertiaDiagonalObj = 0 ;
2017-06-07 16:37:28 +00:00
2017-05-02 05:18:54 +00:00
b3PhysicsClientHandle sm = 0 ;
2018-09-11 20:24:35 +00:00
2017-05-02 05:18:54 +00:00
int physicsClientId = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " linkIndex " , " mass " , " lateralFriction " , " spinningFriction " , " rollingFriction " , " restitution " , " linearDamping " , " angularDamping " , " contactStiffness " , " contactDamping " , " frictionAnchor " , " localInertiaDiagonal " , " ccdSweptSphereRadius " , " contactProcessingThreshold " , " activationState " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|dddddddddiOddii " , kwlist , & bodyUniqueId , & linkIndex , & mass , & lateralFriction , & spinningFriction , & rollingFriction , & restitution , & linearDamping , & angularDamping , & contactStiffness , & contactDamping , & frictionAnchor , & localInertiaDiagonalObj , & ccdSweptSphereRadius , & contactProcessingThreshold , & activationState , & physicsClientId ) )
2017-05-02 05:18:54 +00:00
{
return NULL ;
}
2018-09-11 20:24:35 +00:00
2017-05-02 05:18:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
if ( ( contactStiffness > = 0 & & contactDamping < 0 ) | | ( contactStiffness < 0 & & contactDamping > = 0 ) )
2018-05-16 21:24:12 +00:00
{
PyErr_SetString ( SpamError , " Both contactStiffness and contactDamping needs to be set together. " ) ;
return NULL ;
}
2017-05-02 05:18:54 +00:00
{
2017-05-09 17:44:33 +00:00
b3SharedMemoryCommandHandle command = b3InitChangeDynamicsInfo ( sm ) ;
2017-05-02 05:18:54 +00:00
b3SharedMemoryStatusHandle statusHandle ;
2018-09-11 20:24:35 +00:00
2017-05-02 05:18:54 +00:00
if ( mass > = 0 )
{
2017-05-09 17:44:33 +00:00
b3ChangeDynamicsInfoSetMass ( command , bodyUniqueId , linkIndex , mass ) ;
2017-05-02 05:18:54 +00:00
}
2017-12-21 00:56:31 +00:00
if ( localInertiaDiagonalObj )
{
double localInertiaDiagonal [ 3 ] ;
pybullet_internalSetVectord ( localInertiaDiagonalObj , localInertiaDiagonal ) ;
b3ChangeDynamicsInfoSetLocalInertiaDiagonal ( command , bodyUniqueId , linkIndex , localInertiaDiagonal ) ;
}
2017-05-04 04:47:53 +00:00
if ( lateralFriction > = 0 )
{
2017-05-09 17:44:33 +00:00
b3ChangeDynamicsInfoSetLateralFriction ( command , bodyUniqueId , linkIndex , lateralFriction ) ;
2017-05-04 04:47:53 +00:00
}
2018-09-23 21:17:31 +00:00
if ( spinningFriction > = 0 )
2017-05-27 01:14:38 +00:00
{
2018-09-23 21:17:31 +00:00
b3ChangeDynamicsInfoSetSpinningFriction ( command , bodyUniqueId , linkIndex , spinningFriction ) ;
2017-05-27 01:14:38 +00:00
}
2018-09-23 21:17:31 +00:00
if ( rollingFriction > = 0 )
2017-05-27 01:14:38 +00:00
{
2018-09-23 21:17:31 +00:00
b3ChangeDynamicsInfoSetRollingFriction ( command , bodyUniqueId , linkIndex , rollingFriction ) ;
2017-05-27 01:14:38 +00:00
}
2018-09-23 21:17:31 +00:00
if ( linearDamping > = 0 )
2017-06-05 05:04:16 +00:00
{
2018-09-23 21:17:31 +00:00
b3ChangeDynamicsInfoSetLinearDamping ( command , bodyUniqueId , linearDamping ) ;
2017-06-05 05:04:16 +00:00
}
2018-09-23 21:17:31 +00:00
if ( angularDamping > = 0 )
2017-06-05 05:04:16 +00:00
{
2018-09-23 21:17:31 +00:00
b3ChangeDynamicsInfoSetAngularDamping ( command , bodyUniqueId , angularDamping ) ;
2017-06-05 05:04:16 +00:00
}
2018-09-23 21:17:31 +00:00
if ( restitution > = 0 )
2017-05-27 01:14:38 +00:00
{
b3ChangeDynamicsInfoSetRestitution ( command , bodyUniqueId , linkIndex , restitution ) ;
}
2018-09-23 21:17:31 +00:00
if ( contactStiffness > = 0 & & contactDamping > = 0 )
2017-06-07 15:37:42 +00:00
{
2018-09-23 21:17:31 +00:00
b3ChangeDynamicsInfoSetContactStiffnessAndDamping ( command , bodyUniqueId , linkIndex , contactStiffness , contactDamping ) ;
2017-06-07 15:37:42 +00:00
}
2018-09-23 21:17:31 +00:00
if ( frictionAnchor > = 0 )
2017-06-07 16:37:28 +00:00
{
2018-09-23 21:17:31 +00:00
b3ChangeDynamicsInfoSetFrictionAnchor ( command , bodyUniqueId , linkIndex , frictionAnchor ) ;
2017-06-07 16:37:28 +00:00
}
2018-09-23 21:17:31 +00:00
if ( ccdSweptSphereRadius > = 0 )
2018-02-17 03:44:33 +00:00
{
2018-09-23 21:17:31 +00:00
b3ChangeDynamicsInfoSetCcdSweptSphereRadius ( command , bodyUniqueId , linkIndex , ccdSweptSphereRadius ) ;
2018-02-17 03:44:33 +00:00
}
2018-06-16 04:26:26 +00:00
if ( activationState > = 0 )
{
b3ChangeDynamicsInfoSetActivationState ( command , bodyUniqueId , activationState ) ;
}
2018-05-23 03:26:00 +00:00
if ( contactProcessingThreshold > = 0 )
{
b3ChangeDynamicsInfoSetContactProcessingThreshold ( command , bodyUniqueId , linkIndex , contactProcessingThreshold ) ;
}
2017-05-02 05:18:54 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
}
2018-09-11 20:24:35 +00:00
2017-05-02 05:18:54 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-05-09 17:31:28 +00:00
static PyObject * pybullet_getDynamicsInfo ( PyObject * self , PyObject * args , PyObject * keywds )
2017-05-08 05:41:05 +00:00
{
{
int bodyUniqueId = - 1 ;
int linkIndex = - 2 ;
2017-12-20 22:54:32 +00:00
2017-05-08 05:41:05 +00:00
b3PhysicsClientHandle sm = 0 ;
2018-09-11 20:24:35 +00:00
2017-05-08 05:41:05 +00:00
int physicsClientId = 0 ;
2018-01-04 03:17:28 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " linkIndex " , " physicsClientId " , NULL } ;
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|i " , kwlist , & bodyUniqueId , & linkIndex , & physicsClientId ) )
2017-05-08 05:41:05 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
int status_type = 0 ;
b3SharedMemoryCommandHandle cmd_handle ;
b3SharedMemoryStatusHandle status_handle ;
2017-05-28 16:48:12 +00:00
struct b3DynamicsInfo info ;
2018-09-11 20:24:35 +00:00
2017-05-08 05:41:05 +00:00
if ( bodyUniqueId < 0 )
{
2017-05-09 17:31:28 +00:00
PyErr_SetString ( SpamError , " getDynamicsInfo failed; invalid bodyUniqueId " ) ;
2017-05-08 05:41:05 +00:00
return NULL ;
}
if ( linkIndex < - 1 )
{
2017-05-09 17:31:28 +00:00
PyErr_SetString ( SpamError , " getDynamicsInfo failed; invalid linkIndex " ) ;
2017-05-08 05:41:05 +00:00
return NULL ;
}
2017-05-09 17:31:28 +00:00
cmd_handle = b3GetDynamicsInfoCommandInit ( sm , bodyUniqueId , linkIndex ) ;
2017-05-08 05:41:05 +00:00
status_handle = b3SubmitClientCommandAndWaitStatus ( sm , cmd_handle ) ;
status_type = b3GetStatusType ( status_handle ) ;
2017-05-09 17:31:28 +00:00
if ( status_type ! = CMD_GET_DYNAMICS_INFO_COMPLETED )
2017-05-08 05:41:05 +00:00
{
2017-05-09 17:31:28 +00:00
PyErr_SetString ( SpamError , " getDynamicsInfo failed; invalid return status " ) ;
2017-05-08 05:41:05 +00:00
return NULL ;
}
2018-09-11 20:24:35 +00:00
2017-05-09 17:31:28 +00:00
if ( b3GetDynamicsInfo ( status_handle , & info ) )
2017-05-08 05:41:05 +00:00
{
2018-01-04 03:17:28 +00:00
int numFields = 10 ;
2017-12-20 22:54:32 +00:00
PyObject * pyDynamicsInfo = PyTuple_New ( numFields ) ;
2017-05-09 17:31:28 +00:00
PyTuple_SetItem ( pyDynamicsInfo , 0 , PyFloat_FromDouble ( info . m_mass ) ) ;
PyTuple_SetItem ( pyDynamicsInfo , 1 , PyFloat_FromDouble ( info . m_lateralFrictionCoeff ) ) ;
2018-09-11 20:24:35 +00:00
2017-12-20 22:54:32 +00:00
{
PyObject * pyInertiaDiag = PyTuple_New ( 3 ) ;
2018-01-04 03:17:28 +00:00
PyTuple_SetItem ( pyInertiaDiag , 0 , PyFloat_FromDouble ( info . m_localInertialDiagonal [ 0 ] ) ) ;
PyTuple_SetItem ( pyInertiaDiag , 1 , PyFloat_FromDouble ( info . m_localInertialDiagonal [ 1 ] ) ) ;
PyTuple_SetItem ( pyInertiaDiag , 2 , PyFloat_FromDouble ( info . m_localInertialDiagonal [ 2 ] ) ) ;
2017-12-20 22:54:32 +00:00
PyTuple_SetItem ( pyDynamicsInfo , 2 , pyInertiaDiag ) ;
}
2018-01-04 03:17:28 +00:00
{
2018-09-23 21:17:31 +00:00
PyObject * pyInertiaPos = PyTuple_New ( 3 ) ;
2018-01-04 03:17:28 +00:00
PyTuple_SetItem ( pyInertiaPos , 0 , PyFloat_FromDouble ( info . m_localInertialFrame [ 0 ] ) ) ;
PyTuple_SetItem ( pyInertiaPos , 1 , PyFloat_FromDouble ( info . m_localInertialFrame [ 1 ] ) ) ;
PyTuple_SetItem ( pyInertiaPos , 2 , PyFloat_FromDouble ( info . m_localInertialFrame [ 2 ] ) ) ;
PyTuple_SetItem ( pyDynamicsInfo , 3 , pyInertiaPos ) ;
}
{
2018-09-23 21:17:31 +00:00
PyObject * pyInertiaOrn = PyTuple_New ( 4 ) ;
2018-01-04 03:17:28 +00:00
PyTuple_SetItem ( pyInertiaOrn , 0 , PyFloat_FromDouble ( info . m_localInertialFrame [ 3 ] ) ) ;
PyTuple_SetItem ( pyInertiaOrn , 1 , PyFloat_FromDouble ( info . m_localInertialFrame [ 4 ] ) ) ;
PyTuple_SetItem ( pyInertiaOrn , 2 , PyFloat_FromDouble ( info . m_localInertialFrame [ 5 ] ) ) ;
PyTuple_SetItem ( pyInertiaOrn , 3 , PyFloat_FromDouble ( info . m_localInertialFrame [ 6 ] ) ) ;
PyTuple_SetItem ( pyDynamicsInfo , 4 , pyInertiaOrn ) ;
}
PyTuple_SetItem ( pyDynamicsInfo , 5 , PyFloat_FromDouble ( info . m_restitution ) ) ;
PyTuple_SetItem ( pyDynamicsInfo , 6 , PyFloat_FromDouble ( info . m_rollingFrictionCoeff ) ) ;
PyTuple_SetItem ( pyDynamicsInfo , 7 , PyFloat_FromDouble ( info . m_spinningFrictionCoeff ) ) ;
PyTuple_SetItem ( pyDynamicsInfo , 8 , PyFloat_FromDouble ( info . m_contactDamping ) ) ;
PyTuple_SetItem ( pyDynamicsInfo , 9 , PyFloat_FromDouble ( info . m_contactStiffness ) ) ;
2017-05-09 17:31:28 +00:00
return pyDynamicsInfo ;
2017-05-08 05:41:05 +00:00
}
}
}
2017-05-09 17:31:28 +00:00
PyErr_SetString ( SpamError , " Couldn't get dynamics info " ) ;
2017-05-08 05:41:05 +00:00
return NULL ;
}
2017-10-05 18:43:14 +00:00
static PyObject * pybullet_getPhysicsEngineParameters ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
PyObject * val = 0 ;
2017-10-05 18:43:14 +00:00
int physicsClientId = 0 ;
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
b3SharedMemoryCommandHandle command = b3InitRequestPhysicsParamCommand ( sm ) ;
b3SharedMemoryStatusHandle statusHandle ;
struct b3PhysicsSimulationParameters params ;
int statusType ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2018-09-23 21:17:31 +00:00
if ( statusType ! = CMD_REQUEST_PHYSICS_SIMULATION_PARAMETERS_COMPLETED )
2017-10-05 18:43:14 +00:00
{
PyErr_SetString ( SpamError , " Couldn't get physics simulation parameters. " ) ;
return NULL ;
}
2018-09-23 21:17:31 +00:00
b3GetStatusPhysicsSimulationParameters ( statusHandle , & params ) ;
2017-10-05 18:43:14 +00:00
//for now, return a subset, expose more/all on request
val = Py_BuildValue ( " {s:d,s:i,s:i,s:i,s:d,s:d,s:d} " ,
2018-09-23 21:17:31 +00:00
" fixedTimeStep " , params . m_deltaTime ,
" numSubSteps " , params . m_numSimulationSubSteps ,
" numSolverIterations " , params . m_numSolverIterations ,
" useRealTimeSimulation " , params . m_useRealTimeSimulation ,
" gravityAccelerationX " , params . m_gravityAcceleration [ 0 ] ,
" gravityAccelerationY " , params . m_gravityAcceleration [ 1 ] ,
" gravityAccelerationZ " , params . m_gravityAcceleration [ 2 ] ) ;
2017-10-05 18:43:14 +00:00
return val ;
}
2018-09-11 20:24:35 +00:00
//"fixedTimeStep", "numSolverIterations", "useSplitImpulse", "splitImpulsePenetrationThreshold", "numSubSteps", "collisionFilterMode", "contactBreakingThreshold", "maxNumCmdPer1ms", "enableFileCaching","restitutionVelocityThreshold", "erp", "contactERP", "frictionERP",
2017-10-05 18:43:14 +00:00
//val = Py_BuildValue("{s:i,s:i}","isConnected", isConnected, "connectionMethod", method);
}
2017-05-08 05:41:05 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_setPhysicsEngineParameter ( PyObject * self , PyObject * args , PyObject * keywds )
2016-12-01 06:24:20 +00:00
{
double fixedTimeStep = - 1 ;
int numSolverIterations = - 1 ;
int useSplitImpulse = - 1 ;
double splitImpulsePenetrationThreshold = - 1 ;
2016-12-02 01:54:52 +00:00
int numSubSteps = - 1 ;
2017-01-17 02:17:18 +00:00
int collisionFilterMode = - 1 ;
2017-02-16 22:19:09 +00:00
double contactBreakingThreshold = - 1 ;
2017-03-04 20:59:21 +00:00
int maxNumCmdPer1ms = - 2 ;
2017-05-18 02:29:12 +00:00
int enableFileCaching = - 1 ;
2018-09-23 21:17:31 +00:00
double restitutionVelocityThreshold = - 1 ;
2017-06-13 15:24:35 +00:00
double erp = - 1 ;
2017-06-07 16:37:28 +00:00
double contactERP = - 1 ;
double frictionERP = - 1 ;
2018-02-17 03:44:33 +00:00
double allowedCcdPenetration = - 1 ;
2017-12-01 18:07:07 +00:00
int enableConeFriction = - 1 ;
2016-12-28 04:25:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2018-01-09 18:10:36 +00:00
int deterministicOverlappingPairs = - 1 ;
2018-09-23 21:17:31 +00:00
int jointFeedbackMode = - 1 ;
2018-05-23 03:26:00 +00:00
double solverResidualThreshold = - 1 ;
double contactSlop = - 1 ;
2018-06-12 23:08:46 +00:00
int enableSAT = - 1 ;
2018-09-23 21:17:31 +00:00
int constraintSolverType = - 1 ;
double globalCFM = - 1 ;
2018-09-11 20:24:35 +00:00
2018-08-26 23:14:36 +00:00
int minimumSolverIslandSize = - 1 ;
2018-09-11 20:24:35 +00:00
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " fixedTimeStep " , " numSolverIterations " , " useSplitImpulse " , " splitImpulsePenetrationThreshold " , " numSubSteps " , " collisionFilterMode " , " contactBreakingThreshold " , " maxNumCmdPer1ms " , " enableFileCaching " , " restitutionVelocityThreshold " , " erp " , " contactERP " , " frictionERP " , " enableConeFriction " , " deterministicOverlappingPairs " , " allowedCcdPenetration " , " jointFeedbackMode " , " solverResidualThreshold " , " contactSlop " , " enableSAT " , " constraintSolverType " , " globalCFM " , " minimumSolverIslandSize " , " physicsClientId " , NULL } ;
2016-12-28 04:25:52 +00:00
2018-08-26 23:14:36 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |diidiidiiddddiididdiiddi " , kwlist , & fixedTimeStep , & numSolverIterations , & useSplitImpulse , & splitImpulsePenetrationThreshold , & numSubSteps ,
& collisionFilterMode , & contactBreakingThreshold , & maxNumCmdPer1ms , & enableFileCaching , & restitutionVelocityThreshold , & erp , & contactERP , & frictionERP , & enableConeFriction , & deterministicOverlappingPairs , & allowedCcdPenetration , & jointFeedbackMode , & solverResidualThreshold , & contactSlop , & enableSAT , & constraintSolverType , & globalCFM , & minimumSolverIslandSize , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
2016-12-01 06:24:20 +00:00
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-01 06:24:20 +00:00
{
2016-12-28 04:25:52 +00:00
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
2016-12-01 06:24:20 +00:00
return NULL ;
}
2016-12-28 04:25:52 +00:00
2016-12-01 06:24:20 +00:00
{
b3SharedMemoryCommandHandle command = b3InitPhysicsParamCommand ( sm ) ;
b3SharedMemoryStatusHandle statusHandle ;
if ( numSolverIterations > = 0 )
{
b3PhysicsParamSetNumSolverIterations ( command , numSolverIterations ) ;
}
2017-02-16 22:19:09 +00:00
2018-08-26 23:14:36 +00:00
if ( minimumSolverIslandSize > = 0 )
{
b3PhysicsParameterSetMinimumSolverIslandSize ( command , minimumSolverIslandSize ) ;
}
2018-09-23 21:17:31 +00:00
if ( solverResidualThreshold > = 0 )
2018-05-23 03:26:00 +00:00
{
b3PhysicsParamSetSolverResidualThreshold ( command , solverResidualThreshold ) ;
}
2017-03-13 23:06:52 +00:00
if ( collisionFilterMode > = 0 )
2017-01-17 02:17:18 +00:00
{
b3PhysicsParamSetCollisionFilterMode ( command , collisionFilterMode ) ;
}
2016-12-05 19:54:56 +00:00
if ( numSubSteps > = 0 )
{
b3PhysicsParamSetNumSubSteps ( command , numSubSteps ) ;
}
2016-12-01 06:24:20 +00:00
if ( fixedTimeStep > = 0 )
{
b3PhysicsParamSetTimeStep ( command , fixedTimeStep ) ;
}
if ( useSplitImpulse > = 0 )
{
2017-03-13 23:06:52 +00:00
b3PhysicsParamSetUseSplitImpulse ( command , useSplitImpulse ) ;
2016-12-01 06:24:20 +00:00
}
if ( splitImpulsePenetrationThreshold > = 0 )
{
b3PhysicsParamSetSplitImpulsePenetrationThreshold ( command , splitImpulsePenetrationThreshold ) ;
}
2017-03-13 23:06:52 +00:00
if ( contactBreakingThreshold > = 0 )
2017-02-16 22:19:09 +00:00
{
2017-03-13 23:06:52 +00:00
b3PhysicsParamSetContactBreakingThreshold ( command , contactBreakingThreshold ) ;
2017-02-16 22:19:09 +00:00
}
2018-05-23 03:26:00 +00:00
if ( contactSlop > = 0 )
{
b3PhysicsParamSetContactSlop ( command , contactSlop ) ;
}
2017-03-04 20:59:21 +00:00
//-1 is disables the maxNumCmdPer1ms feature, allow it
2017-03-13 23:06:52 +00:00
if ( maxNumCmdPer1ms > = - 1 )
2017-03-01 21:48:57 +00:00
{
2017-03-13 23:06:52 +00:00
b3PhysicsParamSetMaxNumCommandsPer1ms ( command , maxNumCmdPer1ms ) ;
2017-03-01 21:48:57 +00:00
}
2016-12-01 06:24:20 +00:00
2018-09-23 21:17:31 +00:00
if ( restitutionVelocityThreshold > = 0 )
2017-05-27 01:14:38 +00:00
{
b3PhysicsParamSetRestitutionVelocityThreshold ( command , restitutionVelocityThreshold ) ;
}
2018-09-23 21:17:31 +00:00
if ( enableFileCaching > = 0 )
2017-05-18 02:29:12 +00:00
{
b3PhysicsParamSetEnableFileCaching ( command , enableFileCaching ) ;
}
2018-09-23 21:17:31 +00:00
if ( erp > = 0 )
2017-06-07 16:37:28 +00:00
{
2018-09-23 21:17:31 +00:00
b3PhysicsParamSetDefaultNonContactERP ( command , erp ) ;
2017-06-07 16:37:28 +00:00
}
2018-09-23 21:17:31 +00:00
if ( contactERP > = 0 )
2017-06-07 16:37:28 +00:00
{
2018-09-23 21:17:31 +00:00
b3PhysicsParamSetDefaultContactERP ( command , contactERP ) ;
2017-06-07 16:37:28 +00:00
}
2018-09-23 21:17:31 +00:00
if ( frictionERP > = 0 )
2017-06-07 16:37:28 +00:00
{
2018-09-23 21:17:31 +00:00
b3PhysicsParamSetDefaultFrictionERP ( command , frictionERP ) ;
2017-06-07 16:37:28 +00:00
}
2017-12-01 18:07:07 +00:00
if ( enableConeFriction > = 0 )
{
b3PhysicsParamSetEnableConeFriction ( command , enableConeFriction ) ;
}
2018-09-23 21:17:31 +00:00
if ( deterministicOverlappingPairs > = 0 )
2018-01-09 18:10:36 +00:00
{
2018-09-23 21:17:31 +00:00
b3PhysicsParameterSetDeterministicOverlappingPairs ( command , deterministicOverlappingPairs ) ;
2018-01-09 18:10:36 +00:00
}
2016-12-01 06:24:20 +00:00
2018-09-23 21:17:31 +00:00
if ( allowedCcdPenetration > = 0 )
2018-02-17 03:44:33 +00:00
{
2018-09-23 21:17:31 +00:00
b3PhysicsParameterSetAllowedCcdPenetration ( command , allowedCcdPenetration ) ;
2018-05-12 02:52:06 +00:00
}
2018-09-23 21:17:31 +00:00
if ( jointFeedbackMode > = 0 )
2018-05-12 02:52:06 +00:00
{
2018-09-23 21:17:31 +00:00
b3PhysicsParameterSetJointFeedbackMode ( command , jointFeedbackMode ) ;
2018-02-17 03:44:33 +00:00
}
2018-09-23 21:17:31 +00:00
if ( enableSAT > = 0 )
2018-06-12 23:08:46 +00:00
{
b3PhysicsParameterSetEnableSAT ( command , enableSAT ) ;
}
2018-09-23 21:17:31 +00:00
if ( constraintSolverType > = 0 )
{
b3PhysicsParameterSetConstraintSolverType ( command , constraintSolverType ) ;
}
if ( globalCFM > = 0 )
{
b3PhysicsParamSetDefaultGlobalCFM ( command , globalCFM ) ;
}
2016-12-01 06:24:20 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
}
2017-10-05 16:57:17 +00:00
2016-12-01 06:24:20 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2016-11-11 22:44:50 +00:00
// Load a robot from a URDF file (universal robot description format)
2016-06-10 22:07:41 +00:00
// function can be called without arguments and will default
// to position (0,0,1) with orientation(0,0,0,1)
2016-06-15 21:21:04 +00:00
// els(x,y,z) or
2016-06-10 22:07:41 +00:00
// loadURDF(pos_x, pos_y, pos_z, orn_x, orn_y, orn_z, orn_w)
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_loadURDF ( PyObject * self , PyObject * args , PyObject * keywds )
2016-12-01 06:24:20 +00:00
{
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
2017-03-27 15:30:20 +00:00
int flags = 0 ;
2016-09-08 18:12:58 +00:00
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " fileName " , " basePosition " , " baseOrientation " , " useMaximalCoordinates " , " useFixedBase " , " flags " , " globalScaling " , " physicsClientId " , NULL } ;
2017-03-13 23:06:52 +00:00
static char * kwlistBackwardCompatible4 [ ] = { " fileName " , " startPosX " , " startPosY " , " startPosZ " , NULL } ;
static char * kwlistBackwardCompatible8 [ ] = { " fileName " , " startPosX " , " startPosY " , " startPosZ " , " startOrnX " , " startOrnY " , " startOrnZ " , " startOrnW " , NULL } ;
2016-12-28 04:25:52 +00:00
2018-09-23 21:17:31 +00:00
int bodyUniqueId = - 1 ;
2017-03-13 23:06:52 +00:00
const char * urdfFileName = " " ;
2017-08-14 21:59:41 +00:00
double globalScaling = - 1 ;
2017-03-13 23:06:52 +00:00
double startPosX = 0.0 ;
double startPosY = 0.0 ;
double startPosZ = 0.0 ;
double startOrnX = 0.0 ;
double startOrnY = 0.0 ;
double startOrnZ = 0.0 ;
double startOrnW = 1.0 ;
2017-05-04 04:53:29 +00:00
int useMaximalCoordinates = - 1 ;
2017-03-13 23:06:52 +00:00
int useFixedBase = 0 ;
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
int backwardsCompatibilityArgs = 0 ;
b3PhysicsClientHandle sm = 0 ;
if ( PyArg_ParseTupleAndKeywords ( args , keywds , " sddd " , kwlistBackwardCompatible4 , & urdfFileName , & startPosX ,
& startPosY , & startPosZ ) )
2016-12-01 06:24:20 +00:00
{
2017-03-13 23:06:52 +00:00
backwardsCompatibilityArgs = 1 ;
2016-12-01 06:24:20 +00:00
}
2017-03-13 23:06:52 +00:00
else
2016-12-01 06:24:20 +00:00
{
2017-03-13 23:06:52 +00:00
PyErr_Clear ( ) ;
2016-12-01 06:24:20 +00:00
}
2017-03-13 23:06:52 +00:00
if ( PyArg_ParseTupleAndKeywords ( args , keywds , " sddddddd " , kwlistBackwardCompatible8 , & urdfFileName , & startPosX ,
& startPosY , & startPosZ , & startOrnX , & startOrnY , & startOrnZ , & startOrnW ) )
{
backwardsCompatibilityArgs = 1 ;
}
else
{
PyErr_Clear ( ) ;
}
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
if ( ! backwardsCompatibilityArgs )
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
PyObject * basePosObj = 0 ;
PyObject * baseOrnObj = 0 ;
double basePos [ 3 ] ;
double baseOrn [ 4 ] ;
2017-08-14 21:59:41 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|OOiiidi " , kwlist , & urdfFileName , & basePosObj , & baseOrnObj , & useMaximalCoordinates , & useFixedBase , & flags , & globalScaling , & physicsClientId ) )
2017-03-13 23:06:52 +00:00
{
return NULL ;
}
else
{
if ( basePosObj )
{
if ( ! pybullet_internalSetVectord ( basePosObj , basePos ) )
{
PyErr_SetString ( SpamError , " Cannot convert basePosition. " ) ;
return NULL ;
}
startPosX = basePos [ 0 ] ;
startPosY = basePos [ 1 ] ;
startPosZ = basePos [ 2 ] ;
}
if ( baseOrnObj )
{
if ( ! pybullet_internalSetVector4d ( baseOrnObj , baseOrn ) )
{
PyErr_SetString ( SpamError , " Cannot convert baseOrientation. " ) ;
return NULL ;
}
startOrnX = baseOrn [ 0 ] ;
startOrnY = baseOrn [ 1 ] ;
startOrnZ = baseOrn [ 2 ] ;
startOrnW = baseOrn [ 3 ] ;
}
}
2016-12-28 04:25:52 +00:00
}
2017-03-13 23:06:52 +00:00
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
if ( strlen ( urdfFileName ) )
{
// printf("(%f, %f, %f) (%f, %f, %f, %f)\n",
// startPosX,startPosY,startPosZ,startOrnX, startOrnY,startOrnZ, startOrnW);
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
b3SharedMemoryCommandHandle command =
b3LoadUrdfCommandInit ( sm , urdfFileName ) ;
2018-09-23 21:17:31 +00:00
b3LoadUrdfCommandSetFlags ( command , flags ) ;
2017-03-27 15:30:20 +00:00
2017-03-13 23:06:52 +00:00
// setting the initial position, orientation and other arguments are
// optional
b3LoadUrdfCommandSetStartPosition ( command , startPosX , startPosY , startPosZ ) ;
b3LoadUrdfCommandSetStartOrientation ( command , startOrnX , startOrnY ,
startOrnZ , startOrnW ) ;
2018-09-23 21:17:31 +00:00
if ( useMaximalCoordinates > = 0 )
2017-03-13 23:06:52 +00:00
{
2018-09-23 21:17:31 +00:00
b3LoadUrdfCommandSetUseMultiBody ( command , useMaximalCoordinates = = 0 ) ;
2017-03-13 23:06:52 +00:00
}
if ( useFixedBase )
{
b3LoadUrdfCommandSetUseFixedBase ( command , 1 ) ;
}
2018-09-23 21:17:31 +00:00
if ( globalScaling > 0 )
2017-08-14 21:59:41 +00:00
{
2018-09-23 21:17:31 +00:00
b3LoadUrdfCommandSetGlobalScaling ( command , globalScaling ) ;
2017-08-14 21:59:41 +00:00
}
2017-03-13 23:06:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType ! = CMD_URDF_LOADING_COMPLETED )
{
PyErr_SetString ( SpamError , " Cannot load URDF file. " ) ;
return NULL ;
}
2017-05-28 20:30:20 +00:00
bodyUniqueId = b3GetStatusBodyIndex ( statusHandle ) ;
2017-03-13 23:06:52 +00:00
}
else
{
PyErr_SetString ( SpamError ,
" Empty filename, method expects 1, 4 or 8 arguments. " ) ;
return NULL ;
}
2017-05-28 20:30:20 +00:00
return PyLong_FromLong ( bodyUniqueId ) ;
2016-06-13 17:11:28 +00:00
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_loadSDF ( PyObject * self , PyObject * args , PyObject * keywds )
{
const char * sdfFileName = " " ;
int numBodies = 0 ;
int i ;
int bodyIndicesOut [ MAX_SDF_BODIES ] ;
2017-06-05 05:04:16 +00:00
int useMaximalCoordinates = - 1 ;
2017-03-13 23:06:52 +00:00
PyObject * pylist = 0 ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
b3SharedMemoryCommandHandle commandHandle ;
2016-12-28 04:25:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2017-08-14 21:59:41 +00:00
double globalScaling = - 1 ;
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
2017-08-14 21:59:41 +00:00
static char * kwlist [ ] = { " sdfFileName " , " useMaximalCoordinates " , " globalScaling " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|idi " , kwlist , & sdfFileName , & useMaximalCoordinates , & globalScaling , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-12-29 05:51:54 +00:00
2017-03-13 23:06:52 +00:00
commandHandle = b3LoadSdfCommandInit ( sm , sdfFileName ) ;
2018-09-23 21:17:31 +00:00
if ( useMaximalCoordinates > 0 )
2017-06-05 05:04:16 +00:00
{
2018-09-23 21:17:31 +00:00
b3LoadSdfCommandSetUseMultiBody ( commandHandle , 0 ) ;
2017-06-05 05:04:16 +00:00
}
2017-08-14 21:59:41 +00:00
if ( globalScaling > 0 )
{
2018-09-23 21:17:31 +00:00
b3LoadSdfCommandSetUseGlobalScaling ( commandHandle , globalScaling ) ;
2017-08-14 21:59:41 +00:00
}
2017-03-13 23:06:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType ! = CMD_SDF_LOADING_COMPLETED )
2016-12-29 05:51:54 +00:00
{
2017-03-13 23:06:52 +00:00
PyErr_SetString ( SpamError , " Cannot load SDF file. " ) ;
2016-12-29 05:51:54 +00:00
return NULL ;
}
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
numBodies =
b3GetStatusBodyIndices ( statusHandle , bodyIndicesOut , MAX_SDF_BODIES ) ;
if ( numBodies > MAX_SDF_BODIES )
2016-12-28 04:25:52 +00:00
{
2017-11-04 19:51:13 +00:00
char str [ 1024 ] ;
2018-09-23 21:17:31 +00:00
sprintf ( str , " SDF exceeds body capacity: %d > %d " , numBodies , MAX_SDF_BODIES ) ;
2017-11-04 19:51:13 +00:00
PyErr_SetString ( SpamError , str ) ;
2016-12-28 04:25:52 +00:00
return NULL ;
}
2017-03-13 23:06:52 +00:00
pylist = PyTuple_New ( numBodies ) ;
if ( numBodies > 0 & & numBodies < = MAX_SDF_BODIES )
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
for ( i = 0 ; i < numBodies ; i + + )
{
PyTuple_SetItem ( pylist , i , PyInt_FromLong ( bodyIndicesOut [ i ] ) ) ;
}
2016-12-28 04:25:52 +00:00
}
2017-03-13 23:06:52 +00:00
return pylist ;
2016-12-28 04:25:52 +00:00
}
2018-01-09 02:10:28 +00:00
# ifndef SKIP_SOFT_BODY_MULTI_BODY_DYNAMICS_WORLD
// Load a softbody from an obj file
static PyObject * pybullet_loadSoftBody ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
int flags = 0 ;
2018-09-11 20:24:35 +00:00
2018-01-09 02:10:28 +00:00
static char * kwlist [ ] = { " fileName " , " scale " , " mass " , " collisionMargin " , " physicsClientId " , NULL } ;
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
int bodyUniqueId = - 1 ;
2018-01-09 02:10:28 +00:00
const char * fileName = " " ;
double scale = - 1 ;
double mass = - 1 ;
double collisionMargin = - 1 ;
2018-09-11 20:24:35 +00:00
2018-01-09 02:10:28 +00:00
b3PhysicsClientHandle sm = 0 ;
2018-09-11 20:24:35 +00:00
2018-01-09 02:10:28 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|dddi " , kwlist , & fileName , & scale , & mass , & collisionMargin , & physicsClientId ) )
{
return NULL ;
}
2018-09-11 20:24:35 +00:00
2018-01-09 02:10:28 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2018-01-09 02:10:28 +00:00
if ( strlen ( fileName ) )
{
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
b3SharedMemoryCommandHandle command =
2018-09-23 21:17:31 +00:00
b3LoadSoftBodyCommandInit ( sm , fileName ) ;
2018-01-09 02:10:28 +00:00
2018-09-23 21:17:31 +00:00
if ( scale > 0 )
2018-01-09 02:10:28 +00:00
{
2018-09-23 21:17:31 +00:00
b3LoadSoftBodySetScale ( command , scale ) ;
2018-01-09 02:10:28 +00:00
}
2018-09-23 21:17:31 +00:00
if ( mass > 0 )
2018-01-09 02:10:28 +00:00
{
2018-09-23 21:17:31 +00:00
b3LoadSoftBodySetMass ( command , mass ) ;
2018-01-09 02:10:28 +00:00
}
2018-09-23 21:17:31 +00:00
if ( collisionMargin > 0 )
2018-01-09 02:10:28 +00:00
{
2018-09-23 21:17:31 +00:00
b3LoadSoftBodySetCollisionMargin ( command , collisionMargin ) ;
2018-01-09 02:10:28 +00:00
}
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2018-01-10 06:47:56 +00:00
if ( statusType ! = CMD_LOAD_SOFT_BODY_COMPLETED )
2018-01-09 02:10:28 +00:00
{
PyErr_SetString ( SpamError , " Cannot load soft body. " ) ;
return NULL ;
}
bodyUniqueId = b3GetStatusBodyIndex ( statusHandle ) ;
}
return PyLong_FromLong ( bodyUniqueId ) ;
}
# endif
2017-03-13 23:06:52 +00:00
// Reset the simulation to remove all loaded objects
static PyObject * pybullet_resetSimulation ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
2016-12-28 04:25:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-07-18 06:50:11 +00:00
2017-03-13 23:06:52 +00:00
{
b3SharedMemoryStatusHandle statusHandle ;
statusHandle = b3SubmitClientCommandAndWaitStatus (
sm , b3InitResetSimulationCommand ( sm ) ) ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
//this method is obsolete, use pybullet_setJointMotorControl2 instead
static PyObject * pybullet_setJointMotorControl ( PyObject * self , PyObject * args )
{
int size ;
2017-05-28 20:30:20 +00:00
int bodyUniqueId , jointIndex , controlMode ;
2017-03-13 23:06:52 +00:00
double targetPosition = 0.0 ;
double targetVelocity = 0.0 ;
double maxForce = 100000.0 ;
double appliedForce = 0.0 ;
double kp = 0.1 ;
double kd = 1.0 ;
int valid = 0 ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm ;
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-10-23 14:14:50 +00:00
2017-03-13 23:06:52 +00:00
size = PySequence_Size ( args ) ;
if ( size = = 4 )
{
double targetValue = 0.0 ;
// see switch statement below for convertsions dependent on controlMode
2017-05-28 20:30:20 +00:00
if ( ! PyArg_ParseTuple ( args , " iiid " , & bodyUniqueId , & jointIndex , & controlMode ,
2017-03-13 23:06:52 +00:00
& targetValue ) )
{
PyErr_SetString ( SpamError , " Error parsing arguments " ) ;
return NULL ;
}
valid = 1 ;
switch ( controlMode )
{
case CONTROL_MODE_POSITION_VELOCITY_PD :
{
targetPosition = targetValue ;
break ;
}
case CONTROL_MODE_VELOCITY :
{
targetVelocity = targetValue ;
break ;
}
case CONTROL_MODE_TORQUE :
{
appliedForce = targetValue ;
break ;
}
default :
{
valid = 0 ;
}
}
}
if ( size = = 5 )
{
double targetValue = 0.0 ;
// See switch statement for conversions
2017-05-28 20:30:20 +00:00
if ( ! PyArg_ParseTuple ( args , " iiidd " , & bodyUniqueId , & jointIndex , & controlMode ,
2017-03-13 23:06:52 +00:00
& targetValue , & maxForce ) )
{
PyErr_SetString ( SpamError , " Error parsing arguments " ) ;
return NULL ;
}
valid = 1 ;
2016-10-23 14:14:50 +00:00
2017-03-13 23:06:52 +00:00
switch ( controlMode )
{
case CONTROL_MODE_POSITION_VELOCITY_PD :
{
targetPosition = targetValue ;
break ;
}
case CONTROL_MODE_VELOCITY :
{
targetVelocity = targetValue ;
break ;
}
case CONTROL_MODE_TORQUE :
{
valid = 0 ;
break ;
}
default :
{
valid = 0 ;
}
}
}
if ( size = = 6 )
{
double gain = 0.0 ;
double targetValue = 0.0 ;
2017-05-28 20:30:20 +00:00
if ( ! PyArg_ParseTuple ( args , " iiiddd " , & bodyUniqueId , & jointIndex , & controlMode ,
2017-03-13 23:06:52 +00:00
& targetValue , & maxForce , & gain ) )
{
PyErr_SetString ( SpamError , " Error parsing arguments " ) ;
return NULL ;
}
valid = 1 ;
2016-12-28 04:25:52 +00:00
2017-03-13 23:06:52 +00:00
switch ( controlMode )
{
case CONTROL_MODE_POSITION_VELOCITY_PD :
{
targetPosition = targetValue ;
kp = gain ;
break ;
}
case CONTROL_MODE_VELOCITY :
{
targetVelocity = targetValue ;
kd = gain ;
break ;
}
case CONTROL_MODE_TORQUE :
{
valid = 0 ;
break ;
}
default :
{
valid = 0 ;
}
}
}
if ( size = = 8 )
{
// only applicable for CONTROL_MODE_POSITION_VELOCITY_PD.
2017-05-28 20:30:20 +00:00
if ( ! PyArg_ParseTuple ( args , " iiiddddd " , & bodyUniqueId , & jointIndex ,
2017-03-13 23:06:52 +00:00
& controlMode , & targetPosition , & targetVelocity ,
& maxForce , & kp , & kd ) )
{
PyErr_SetString ( SpamError , " Error parsing arguments " ) ;
return NULL ;
}
valid = 1 ;
}
if ( valid )
{
int numJoints ;
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
struct b3JointInfo info ;
2017-05-28 20:30:20 +00:00
numJoints = b3GetNumJoints ( sm , bodyUniqueId ) ;
2017-03-13 23:06:52 +00:00
if ( ( jointIndex > = numJoints ) | | ( jointIndex < 0 ) )
{
PyErr_SetString ( SpamError , " Joint index out-of-range. " ) ;
return NULL ;
}
if ( ( controlMode ! = CONTROL_MODE_VELOCITY ) & &
( controlMode ! = CONTROL_MODE_TORQUE ) & &
( controlMode ! = CONTROL_MODE_POSITION_VELOCITY_PD ) )
{
PyErr_SetString ( SpamError , " Illegral control mode. " ) ;
return NULL ;
}
2017-05-28 20:30:20 +00:00
commandHandle = b3JointControlCommandInit2 ( sm , bodyUniqueId , controlMode ) ;
2017-03-13 23:06:52 +00:00
2017-05-28 20:30:20 +00:00
b3GetJointInfo ( sm , bodyUniqueId , jointIndex , & info ) ;
2017-03-13 23:06:52 +00:00
switch ( controlMode )
{
case CONTROL_MODE_VELOCITY :
{
b3JointControlSetDesiredVelocity ( commandHandle , info . m_uIndex ,
targetVelocity ) ;
b3JointControlSetKd ( commandHandle , info . m_uIndex , kd ) ;
b3JointControlSetMaximumForce ( commandHandle , info . m_uIndex , maxForce ) ;
break ;
}
case CONTROL_MODE_TORQUE :
{
b3JointControlSetDesiredForceTorque ( commandHandle , info . m_uIndex ,
appliedForce ) ;
break ;
}
case CONTROL_MODE_POSITION_VELOCITY_PD :
{
b3JointControlSetDesiredPosition ( commandHandle , info . m_qIndex ,
targetPosition ) ;
b3JointControlSetKp ( commandHandle , info . m_uIndex , kp ) ;
b3JointControlSetDesiredVelocity ( commandHandle , info . m_uIndex ,
targetVelocity ) ;
b3JointControlSetKd ( commandHandle , info . m_uIndex , kd ) ;
b3JointControlSetMaximumForce ( commandHandle , info . m_uIndex , maxForce ) ;
break ;
}
default :
{
}
} ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
PyErr_SetString ( SpamError , " Error parsing arguments in setJointControl. " ) ;
return NULL ;
}
2017-05-08 20:41:07 +00:00
static PyObject * pybullet_setJointMotorControlArray ( PyObject * self , PyObject * args , PyObject * keywds )
{
2018-09-23 21:17:31 +00:00
int bodyUniqueId , controlMode ;
2017-05-08 20:41:07 +00:00
PyObject * jointIndicesObj = 0 ;
PyObject * targetPositionsObj = 0 ;
PyObject * targetVelocitiesObj = 0 ;
PyObject * forcesObj = 0 ;
PyObject * kpsObj = 0 ;
PyObject * kdsObj = 0 ;
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
2017-05-28 20:30:20 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " jointIndices " , " controlMode " , " targetPositions " , " targetVelocities " , " forces " , " positionGains " , " velocityGains " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iOi|OOOOOi " , kwlist , & bodyUniqueId , & jointIndicesObj , & controlMode ,
2017-05-08 20:41:07 +00:00
& targetPositionsObj , & targetVelocitiesObj , & forcesObj , & kpsObj , & kdsObj , & physicsClientId ) )
{
2017-05-28 20:30:20 +00:00
static char * kwlist2 [ ] = { " bodyIndex " , " jointIndices " , " controlMode " , " targetPositions " , " targetVelocities " , " forces " , " positionGains " , " velocityGains " , " physicsClientId " , NULL } ;
PyErr_Clear ( ) ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iOi|OOOOOi " , kwlist2 , & bodyUniqueId , & jointIndicesObj , & controlMode ,
2018-09-23 21:17:31 +00:00
& targetPositionsObj , & targetVelocitiesObj , & forcesObj , & kpsObj , & kdsObj , & physicsClientId ) )
2017-05-28 20:30:20 +00:00
{
return NULL ;
}
2017-05-08 20:41:07 +00:00
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
int numJoints ;
int i ;
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
struct b3JointInfo info ;
int numControlledDofs = 0 ;
PyObject * jointIndicesSeq = 0 ;
PyObject * targetVelocitiesSeq = 0 ;
PyObject * targetPositionsSeq = 0 ;
PyObject * forcesSeq = 0 ;
PyObject * kpsSeq = 0 ;
PyObject * kdsSeq = 0 ;
2017-05-28 20:30:20 +00:00
numJoints = b3GetNumJoints ( sm , bodyUniqueId ) ;
2018-09-11 20:24:35 +00:00
2017-05-08 20:41:07 +00:00
if ( ( controlMode ! = CONTROL_MODE_VELOCITY ) & &
( controlMode ! = CONTROL_MODE_TORQUE ) & &
( controlMode ! = CONTROL_MODE_POSITION_VELOCITY_PD ) )
{
PyErr_SetString ( SpamError , " Illegral control mode. " ) ;
return NULL ;
}
2018-09-23 21:17:31 +00:00
jointIndicesSeq = PySequence_Fast ( jointIndicesObj , " expected a sequence of joint indices " ) ;
2017-05-08 20:41:07 +00:00
2018-09-23 21:17:31 +00:00
if ( jointIndicesSeq = = 0 )
2017-05-08 20:41:07 +00:00
{
PyErr_SetString ( SpamError , " expected a sequence of joint indices " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2017-05-08 20:41:07 +00:00
numControlledDofs = PySequence_Size ( jointIndicesObj ) ;
2018-09-23 21:17:31 +00:00
if ( numControlledDofs = = 0 )
2017-05-08 20:41:07 +00:00
{
Py_DECREF ( jointIndicesSeq ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2018-09-11 20:24:35 +00:00
2017-05-08 20:41:07 +00:00
{
int i ;
for ( i = 0 ; i < numControlledDofs ; i + + )
{
2017-07-01 02:11:43 +00:00
int jointIndex = pybullet_internalGetIntFromSequence ( jointIndicesSeq , i ) ;
2017-05-08 20:41:07 +00:00
if ( ( jointIndex > = numJoints ) | | ( jointIndex < 0 ) )
{
Py_DECREF ( jointIndicesSeq ) ;
PyErr_SetString ( SpamError , " Joint index out-of-range. " ) ;
return NULL ;
}
}
}
if ( targetVelocitiesObj )
{
int num = PySequence_Size ( targetVelocitiesObj ) ;
if ( num ! = numControlledDofs )
{
Py_DECREF ( jointIndicesSeq ) ;
PyErr_SetString ( SpamError , " number of target velocies should match the number of joint indices " ) ;
return NULL ;
}
2018-09-23 21:17:31 +00:00
targetVelocitiesSeq = PySequence_Fast ( targetVelocitiesObj , " expected a sequence of target velocities " ) ;
2017-05-08 20:41:07 +00:00
}
2018-09-11 20:24:35 +00:00
2017-05-08 20:41:07 +00:00
if ( targetPositionsObj )
{
int num = PySequence_Size ( targetPositionsObj ) ;
if ( num ! = numControlledDofs )
{
Py_DECREF ( jointIndicesSeq ) ;
if ( targetVelocitiesSeq )
{
Py_DECREF ( targetVelocitiesSeq ) ;
}
PyErr_SetString ( SpamError , " number of target positions should match the number of joint indices " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
targetPositionsSeq = PySequence_Fast ( targetPositionsObj , " expected a sequence of target positions " ) ;
2017-05-08 20:41:07 +00:00
}
2018-09-11 20:24:35 +00:00
2017-05-08 20:41:07 +00:00
if ( forcesObj )
{
int num = PySequence_Size ( forcesObj ) ;
if ( num ! = numControlledDofs )
{
Py_DECREF ( jointIndicesSeq ) ;
if ( targetVelocitiesSeq )
{
Py_DECREF ( targetVelocitiesSeq ) ;
}
if ( targetPositionsSeq )
{
Py_DECREF ( targetPositionsSeq ) ;
}
2018-09-11 20:24:35 +00:00
2017-05-08 20:41:07 +00:00
PyErr_SetString ( SpamError , " number of forces should match the joint indices " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
forcesSeq = PySequence_Fast ( forcesObj , " expected a sequence of forces " ) ;
2017-05-08 20:41:07 +00:00
}
if ( kpsObj )
{
int num = PySequence_Size ( kpsObj ) ;
if ( num ! = numControlledDofs )
{
Py_DECREF ( jointIndicesSeq ) ;
if ( targetVelocitiesSeq )
{
Py_DECREF ( targetVelocitiesSeq ) ;
}
if ( targetPositionsSeq )
{
Py_DECREF ( targetPositionsSeq ) ;
}
if ( forcesSeq )
{
Py_DECREF ( forcesSeq ) ;
}
PyErr_SetString ( SpamError , " number of kps should match the joint indices " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
kpsSeq = PySequence_Fast ( kpsObj , " expected a sequence of kps " ) ;
2017-05-08 20:41:07 +00:00
}
if ( kdsObj )
{
int num = PySequence_Size ( kdsObj ) ;
if ( num ! = numControlledDofs )
{
Py_DECREF ( jointIndicesSeq ) ;
if ( targetVelocitiesSeq )
{
Py_DECREF ( targetVelocitiesSeq ) ;
}
if ( targetPositionsSeq )
{
Py_DECREF ( targetPositionsSeq ) ;
}
if ( forcesSeq )
{
Py_DECREF ( forcesSeq ) ;
}
if ( kpsSeq )
{
Py_DECREF ( kpsSeq ) ;
}
2018-09-11 20:24:35 +00:00
2017-05-08 20:41:07 +00:00
PyErr_SetString ( SpamError , " number of kds should match the number of joint indices " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
kdsSeq = PySequence_Fast ( kdsObj , " expected a sequence of kds " ) ;
2017-05-08 20:41:07 +00:00
}
2017-05-28 20:30:20 +00:00
commandHandle = b3JointControlCommandInit2 ( sm , bodyUniqueId , controlMode ) ;
2017-05-08 20:41:07 +00:00
2018-09-23 21:17:31 +00:00
for ( i = 0 ; i < numControlledDofs ; i + + )
2017-05-08 20:41:07 +00:00
{
double targetVelocity = 0.0 ;
2017-05-28 16:48:12 +00:00
double targetPosition = 0.0 ;
double force = 100000.0 ;
double kp = 0.1 ;
double kd = 1.0 ;
int jointIndex ;
2017-05-08 20:41:07 +00:00
if ( targetVelocitiesSeq )
{
targetVelocity = pybullet_internalGetFloatFromSequence ( targetVelocitiesSeq , i ) ;
}
2017-05-28 16:48:12 +00:00
2017-05-08 20:41:07 +00:00
if ( targetPositionsSeq )
{
targetPosition = pybullet_internalGetFloatFromSequence ( targetPositionsSeq , i ) ;
}
if ( forcesSeq )
{
force = pybullet_internalGetFloatFromSequence ( forcesSeq , i ) ;
}
2018-09-11 20:24:35 +00:00
2017-05-08 20:41:07 +00:00
if ( kpsSeq )
{
kp = pybullet_internalGetFloatFromSequence ( kpsSeq , i ) ;
}
2018-09-11 20:24:35 +00:00
2017-05-08 20:41:07 +00:00
if ( kdsSeq )
{
kd = pybullet_internalGetFloatFromSequence ( kdsSeq , i ) ;
}
2017-05-28 16:48:12 +00:00
jointIndex = pybullet_internalGetFloatFromSequence ( jointIndicesSeq , i ) ;
2017-05-28 20:30:20 +00:00
b3GetJointInfo ( sm , bodyUniqueId , jointIndex , & info ) ;
2017-05-08 20:41:07 +00:00
switch ( controlMode )
{
case CONTROL_MODE_VELOCITY :
{
b3JointControlSetDesiredVelocity ( commandHandle , info . m_uIndex ,
targetVelocity ) ;
b3JointControlSetKd ( commandHandle , info . m_uIndex , kd ) ;
b3JointControlSetMaximumForce ( commandHandle , info . m_uIndex , force ) ;
break ;
}
case CONTROL_MODE_TORQUE :
{
b3JointControlSetDesiredForceTorque ( commandHandle , info . m_uIndex ,
force ) ;
break ;
}
case CONTROL_MODE_POSITION_VELOCITY_PD :
{
b3JointControlSetDesiredPosition ( commandHandle , info . m_qIndex ,
targetPosition ) ;
b3JointControlSetKp ( commandHandle , info . m_uIndex , kp ) ;
b3JointControlSetDesiredVelocity ( commandHandle , info . m_uIndex ,
targetVelocity ) ;
b3JointControlSetKd ( commandHandle , info . m_uIndex , kd ) ;
b3JointControlSetMaximumForce ( commandHandle , info . m_uIndex , force ) ;
break ;
}
default :
{
}
} ;
}
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
2018-04-12 19:43:29 +00:00
if ( targetVelocitiesSeq )
{
Py_DECREF ( targetVelocitiesSeq ) ;
}
if ( targetPositionsSeq )
{
Py_DECREF ( targetPositionsSeq ) ;
}
if ( forcesSeq )
{
Py_DECREF ( forcesSeq ) ;
}
if ( kpsSeq )
{
Py_DECREF ( kpsSeq ) ;
}
if ( kdsSeq )
{
Py_DECREF ( kdsSeq ) ;
}
2017-05-08 20:41:07 +00:00
Py_DECREF ( jointIndicesSeq ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
// PyErr_SetString(SpamError, "Error parsing arguments in setJointControl.");
// return NULL;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_setJointMotorControl2 ( PyObject * self , PyObject * args , PyObject * keywds )
{
2017-05-28 20:30:20 +00:00
int bodyUniqueId , jointIndex , controlMode ;
2017-03-13 23:06:52 +00:00
double targetPosition = 0.0 ;
double targetVelocity = 0.0 ;
double force = 100000.0 ;
double kp = 0.1 ;
double kd = 1.0 ;
2017-11-22 01:05:28 +00:00
double maxVelocity = - 1 ;
2017-03-13 23:06:52 +00:00
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
2017-11-22 01:05:28 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " jointIndex " , " controlMode " , " targetPosition " , " targetVelocity " , " force " , " positionGain " , " velocityGain " , " maxVelocity " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iii|ddddddi " , kwlist , & bodyUniqueId , & jointIndex , & controlMode ,
& targetPosition , & targetVelocity , & force , & kp , & kd , & maxVelocity , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
2017-05-28 20:30:20 +00:00
//backward compatibility, bodyIndex -> bodyUniqueId, don't need to update this function: people have to migrate to bodyUniqueId
2018-09-23 21:17:31 +00:00
static char * kwlist2 [ ] = { " bodyIndex " , " jointIndex " , " controlMode " , " targetPosition " , " targetVelocity " , " force " , " positionGain " , " velocityGain " , " maxVelocity " , " physicsClientId " , NULL } ;
2017-05-28 20:30:20 +00:00
PyErr_Clear ( ) ;
2018-01-15 16:33:19 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iii|ddddddi " , kwlist2 , & bodyUniqueId , & jointIndex , & controlMode ,
2018-09-23 21:17:31 +00:00
& targetPosition , & targetVelocity , & force , & kp , & kd , & maxVelocity , & physicsClientId ) )
2017-05-28 20:30:20 +00:00
{
return NULL ;
}
2016-12-28 04:25:52 +00:00
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-10-23 14:14:50 +00:00
2017-03-13 23:06:52 +00:00
{
int numJoints ;
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
struct b3JointInfo info ;
2016-10-23 14:14:50 +00:00
2017-05-28 20:30:20 +00:00
numJoints = b3GetNumJoints ( sm , bodyUniqueId ) ;
2017-03-13 23:06:52 +00:00
if ( ( jointIndex > = numJoints ) | | ( jointIndex < 0 ) )
{
PyErr_SetString ( SpamError , " Joint index out-of-range. " ) ;
return NULL ;
}
if ( ( controlMode ! = CONTROL_MODE_VELOCITY ) & &
( controlMode ! = CONTROL_MODE_TORQUE ) & &
2018-06-16 00:59:26 +00:00
( controlMode ! = CONTROL_MODE_POSITION_VELOCITY_PD ) & &
2018-09-23 21:17:31 +00:00
( controlMode ! = CONTROL_MODE_PD ) )
2017-03-13 23:06:52 +00:00
{
PyErr_SetString ( SpamError , " Illegral control mode. " ) ;
return NULL ;
}
2016-10-23 14:14:50 +00:00
2017-05-28 20:30:20 +00:00
commandHandle = b3JointControlCommandInit2 ( sm , bodyUniqueId , controlMode ) ;
2016-10-23 14:14:50 +00:00
2017-05-28 20:30:20 +00:00
b3GetJointInfo ( sm , bodyUniqueId , jointIndex , & info ) ;
2017-03-13 23:06:52 +00:00
switch ( controlMode )
{
case CONTROL_MODE_VELOCITY :
{
b3JointControlSetDesiredVelocity ( commandHandle , info . m_uIndex ,
targetVelocity ) ;
b3JointControlSetKd ( commandHandle , info . m_uIndex , kd ) ;
b3JointControlSetMaximumForce ( commandHandle , info . m_uIndex , force ) ;
break ;
}
case CONTROL_MODE_TORQUE :
{
b3JointControlSetDesiredForceTorque ( commandHandle , info . m_uIndex ,
force ) ;
break ;
}
case CONTROL_MODE_POSITION_VELOCITY_PD :
2018-09-23 21:17:31 +00:00
case CONTROL_MODE_PD :
2017-03-13 23:06:52 +00:00
{
2018-09-23 21:17:31 +00:00
if ( maxVelocity > 0 )
2017-11-22 01:05:28 +00:00
{
b3JointControlSetMaximumVelocity ( commandHandle , info . m_uIndex , maxVelocity ) ;
}
2017-03-13 23:06:52 +00:00
b3JointControlSetDesiredPosition ( commandHandle , info . m_qIndex ,
targetPosition ) ;
b3JointControlSetKp ( commandHandle , info . m_uIndex , kp ) ;
b3JointControlSetDesiredVelocity ( commandHandle , info . m_uIndex ,
targetVelocity ) ;
b3JointControlSetKd ( commandHandle , info . m_uIndex , kd ) ;
b3JointControlSetMaximumForce ( commandHandle , info . m_uIndex , force ) ;
break ;
}
default :
{
}
} ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
// PyErr_SetString(SpamError, "Error parsing arguments in setJointControl.");
// return NULL;
2016-10-23 14:14:50 +00:00
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_setRealTimeSimulation ( PyObject * self ,
PyObject * args ,
PyObject * keywds )
{
int enableRealTimeSimulation = 0 ;
int ret ;
b3PhysicsClientHandle sm = 0 ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " enableRealTimeSimulation " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & enableRealTimeSimulation , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-05-24 22:29:26 +00:00
2017-03-13 23:06:52 +00:00
{
b3SharedMemoryCommandHandle command = b3InitPhysicsParamCommand ( sm ) ;
b3SharedMemoryStatusHandle statusHandle ;
ret =
b3PhysicsParamSetRealTimeSimulation ( command , enableRealTimeSimulation ) ;
2016-05-10 07:57:54 +00:00
2017-03-13 23:06:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
// ASSERT_EQ(b3GetStatusType(statusHandle), CMD_CLIENT_COMMAND_COMPLETED);
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-05-24 22:29:26 +00:00
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_setInternalSimFlags ( PyObject * self ,
PyObject * args , PyObject * keywds )
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
int flags = 0 ;
2016-12-28 04:25:52 +00:00
int ret ;
int physicsClientId = 0 ;
2016-12-29 05:51:54 +00:00
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " flags " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & flags , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
b3SharedMemoryCommandHandle command = b3InitPhysicsParamCommand ( sm ) ;
b3SharedMemoryStatusHandle statusHandle ;
2016-09-08 22:22:41 +00:00
2017-03-13 23:06:52 +00:00
ret =
b3PhysicsParamSetInternalSimFlags ( command , flags ) ;
2016-05-24 22:29:26 +00:00
2017-03-13 23:06:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
// ASSERT_EQ(b3GetStatusType(statusHandle), CMD_CLIENT_COMMAND_COMPLETED);
}
2016-09-08 18:12:58 +00:00
2016-12-28 04:25:52 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-03-13 23:06:52 +00:00
// Set the gravity of the world with (x, y, z) arguments
static PyObject * pybullet_setGravity ( PyObject * self , PyObject * args , PyObject * keywds )
{
{
double gravX = 0.0 ;
double gravY = 0.0 ;
double gravZ = - 10.0 ;
int ret ;
b3PhysicsClientHandle sm = 0 ;
b3SharedMemoryCommandHandle command ;
b3SharedMemoryStatusHandle statusHandle ;
int physicsClientId = 0 ;
static char * kwlist [ ] = { " gravX " , " gravY " , " gravZ " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ddd|i " , kwlist , & gravX , & gravY , & gravZ , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
command = b3InitPhysicsParamCommand ( sm ) ;
ret = b3PhysicsParamSetGravity ( command , gravX , gravY , gravZ ) ;
// ret = b3PhysicsParamSetTimeStep(command, timeStep);
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
// ASSERT_EQ(b3GetStatusType(statusHandle), CMD_CLIENT_COMMAND_COMPLETED);
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-06-27 01:18:30 +00:00
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_setTimeStep ( PyObject * self , PyObject * args , PyObject * keywds )
{
double timeStep = 0.001 ;
int ret ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
2016-12-29 05:51:54 +00:00
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " timeStep " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " d|i " , kwlist , & timeStep , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
b3SharedMemoryCommandHandle command = b3InitPhysicsParamCommand ( sm ) ;
2017-03-13 23:06:52 +00:00
b3SharedMemoryStatusHandle statusHandle ;
2016-09-08 22:15:58 +00:00
2017-03-13 23:06:52 +00:00
ret = b3PhysicsParamSetTimeStep ( command , timeStep ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
}
static PyObject *
pybullet_setDefaultContactERP ( PyObject * self , PyObject * args , PyObject * keywds )
{
double defaultContactERP = 0.005 ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " defaultContactERP " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " d|i " , kwlist , & defaultContactERP , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
int ret ;
b3SharedMemoryStatusHandle statusHandle ;
b3SharedMemoryCommandHandle command = b3InitPhysicsParamCommand ( sm ) ;
ret = b3PhysicsParamSetDefaultContactERP ( command , defaultContactERP ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-09-08 22:15:58 +00:00
}
2016-11-28 23:11:34 +00:00
static int pybullet_internalGetBaseVelocity (
2017-05-28 20:30:20 +00:00
int bodyUniqueId , double baseLinearVelocity [ 3 ] , double baseAngularVelocity [ 3 ] , b3PhysicsClientHandle sm )
2017-03-13 23:06:52 +00:00
{
2016-11-28 23:11:34 +00:00
baseLinearVelocity [ 0 ] = 0. ;
baseLinearVelocity [ 1 ] = 0. ;
baseLinearVelocity [ 2 ] = 0. ;
baseAngularVelocity [ 0 ] = 0. ;
baseAngularVelocity [ 1 ] = 0. ;
baseAngularVelocity [ 2 ] = 0. ;
2017-03-13 23:06:52 +00:00
if ( 0 = = sm )
{
2016-11-28 23:11:34 +00:00
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return 0 ;
}
{
{
b3SharedMemoryCommandHandle cmd_handle =
2017-05-28 20:30:20 +00:00
b3RequestActualStateCommandInit ( sm , bodyUniqueId ) ;
2016-11-28 23:11:34 +00:00
b3SharedMemoryStatusHandle status_handle =
b3SubmitClientCommandAndWaitStatus ( sm , cmd_handle ) ;
const int status_type = b3GetStatusType ( status_handle ) ;
const double * actualStateQdot ;
// const double* jointReactionForces[];
2017-03-13 23:06:52 +00:00
if ( status_type ! = CMD_ACTUAL_STATE_UPDATE_COMPLETED )
{
2016-11-28 23:11:34 +00:00
PyErr_SetString ( SpamError , " getBaseVelocity failed. " ) ;
return 0 ;
}
b3GetStatusActualState (
status_handle , 0 /* body_unique_id */ ,
0 /* num_degree_of_freedom_q */ , 0 /* num_degree_of_freedom_u */ ,
0 /*root_local_inertial_frame*/ , 0 ,
& actualStateQdot , 0 /* joint_reaction_forces */ ) ;
// printf("joint reaction forces=");
// for (i=0; i < (sizeof(jointReactionForces)/sizeof(double)); i++) {
// printf("%f ", jointReactionForces[i]);
// }
// now, position x,y,z = actualStateQ[0],actualStateQ[1],actualStateQ[2]
// and orientation x,y,z,w =
// actualStateQ[3],actualStateQ[4],actualStateQ[5],actualStateQ[6]
baseLinearVelocity [ 0 ] = actualStateQdot [ 0 ] ;
baseLinearVelocity [ 1 ] = actualStateQdot [ 1 ] ;
baseLinearVelocity [ 2 ] = actualStateQdot [ 2 ] ;
baseAngularVelocity [ 0 ] = actualStateQdot [ 3 ] ;
baseAngularVelocity [ 1 ] = actualStateQdot [ 4 ] ;
baseAngularVelocity [ 2 ] = actualStateQdot [ 5 ] ;
}
}
return 1 ;
}
2016-05-24 22:29:26 +00:00
2016-06-10 22:07:41 +00:00
// Internal function used to get the base position and orientation
// Orientation is returned in quaternions
2016-09-08 18:12:58 +00:00
static int pybullet_internalGetBasePositionAndOrientation (
2017-05-28 20:30:20 +00:00
int bodyUniqueId , double basePosition [ 3 ] , double baseOrientation [ 4 ] , b3PhysicsClientHandle sm )
2017-03-13 23:06:52 +00:00
{
basePosition [ 0 ] = 0. ;
basePosition [ 1 ] = 0. ;
basePosition [ 2 ] = 0. ;
baseOrientation [ 0 ] = 0. ;
baseOrientation [ 1 ] = 0. ;
baseOrientation [ 2 ] = 0. ;
baseOrientation [ 3 ] = 1. ;
if ( 0 = = sm )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return 0 ;
}
{
{
b3SharedMemoryCommandHandle cmd_handle =
2017-05-28 20:30:20 +00:00
b3RequestActualStateCommandInit ( sm , bodyUniqueId ) ;
2017-03-13 23:06:52 +00:00
b3SharedMemoryStatusHandle status_handle =
b3SubmitClientCommandAndWaitStatus ( sm , cmd_handle ) ;
const int status_type = b3GetStatusType ( status_handle ) ;
const double * actualStateQ ;
// const double* jointReactionForces[];
if ( status_type ! = CMD_ACTUAL_STATE_UPDATE_COMPLETED )
{
PyErr_SetString ( SpamError , " getBasePositionAndOrientation failed. " ) ;
return 0 ;
}
b3GetStatusActualState (
status_handle , 0 /* body_unique_id */ ,
0 /* num_degree_of_freedom_q */ , 0 /* num_degree_of_freedom_u */ ,
0 /*root_local_inertial_frame*/ , & actualStateQ ,
0 /* actual_state_q_dot */ , 0 /* joint_reaction_forces */ ) ;
// printf("joint reaction forces=");
// for (i=0; i < (sizeof(jointReactionForces)/sizeof(double)); i++) {
// printf("%f ", jointReactionForces[i]);
// }
// now, position x,y,z = actualStateQ[0],actualStateQ[1],actualStateQ[2]
// and orientation x,y,z,w =
// actualStateQ[3],actualStateQ[4],actualStateQ[5],actualStateQ[6]
basePosition [ 0 ] = actualStateQ [ 0 ] ;
basePosition [ 1 ] = actualStateQ [ 1 ] ;
basePosition [ 2 ] = actualStateQ [ 2 ] ;
baseOrientation [ 0 ] = actualStateQ [ 3 ] ;
baseOrientation [ 1 ] = actualStateQ [ 4 ] ;
baseOrientation [ 2 ] = actualStateQ [ 5 ] ;
baseOrientation [ 3 ] = actualStateQ [ 6 ] ;
}
}
return 1 ;
2016-05-24 22:29:26 +00:00
}
2016-05-10 07:57:54 +00:00
2017-06-16 02:46:27 +00:00
static PyObject * pybullet_getAABB ( PyObject * self , PyObject * args , PyObject * keywds )
{
int bodyUniqueId = - 1 ;
int linkIndex = - 1 ;
2018-09-11 20:24:35 +00:00
2017-06-16 02:46:27 +00:00
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
static char * kwlist [ ] = { " bodyUniqueId " , " linkIndex " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|ii " , kwlist , & bodyUniqueId , & linkIndex , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
int status_type = 0 ;
b3SharedMemoryCommandHandle cmd_handle ;
b3SharedMemoryStatusHandle status_handle ;
if ( bodyUniqueId < 0 )
{
PyErr_SetString ( SpamError , " getAABB failed; invalid bodyUniqueId " ) ;
return NULL ;
}
if ( linkIndex < - 1 )
{
PyErr_SetString ( SpamError , " getAABB failed; invalid linkIndex " ) ;
return NULL ;
}
cmd_handle =
2017-06-17 01:10:10 +00:00
b3RequestCollisionInfoCommandInit ( sm , bodyUniqueId ) ;
2017-06-16 02:46:27 +00:00
status_handle =
b3SubmitClientCommandAndWaitStatus ( sm , cmd_handle ) ;
status_type = b3GetStatusType ( status_handle ) ;
2017-06-17 01:10:10 +00:00
if ( status_type ! = CMD_REQUEST_COLLISION_INFO_COMPLETED )
2017-06-16 02:46:27 +00:00
{
PyErr_SetString ( SpamError , " getAABB failed. " ) ;
return NULL ;
}
{
2018-09-23 21:17:31 +00:00
PyObject * pyListAabb = 0 ;
PyObject * pyListAabbMin = 0 ;
PyObject * pyListAabbMax = 0 ;
2017-06-16 02:46:27 +00:00
double aabbMin [ 3 ] ;
double aabbMax [ 3 ] ;
2018-09-23 21:17:31 +00:00
int i = 0 ;
2017-06-16 02:46:27 +00:00
if ( b3GetStatusAABB ( status_handle , linkIndex , aabbMin , aabbMax ) )
{
pyListAabb = PyTuple_New ( 2 ) ;
pyListAabbMin = PyTuple_New ( 3 ) ;
pyListAabbMax = PyTuple_New ( 3 ) ;
2018-09-23 21:17:31 +00:00
for ( i = 0 ; i < 3 ; i + + )
2017-06-16 02:46:27 +00:00
{
PyTuple_SetItem ( pyListAabbMin , i , PyFloat_FromDouble ( aabbMin [ i ] ) ) ;
PyTuple_SetItem ( pyListAabbMax , i , PyFloat_FromDouble ( aabbMax [ i ] ) ) ;
}
PyTuple_SetItem ( pyListAabb , 0 , pyListAabbMin ) ;
PyTuple_SetItem ( pyListAabb , 1 , pyListAabbMax ) ;
//PyFloat_FromDouble(basePosition[i]);
return pyListAabb ;
}
}
}
PyErr_SetString ( SpamError , " getAABB failed. " ) ;
return NULL ;
}
2016-06-10 22:07:41 +00:00
// Get the positions (x,y,z) and orientation (x,y,z,w) in quaternion
// values for the base link of your object
// Object is retrieved based on body index, which is the order
// the object was loaded into the simulation (0-based)
2016-09-08 18:12:58 +00:00
static PyObject * pybullet_getBasePositionAndOrientation ( PyObject * self ,
2017-03-13 23:06:52 +00:00
PyObject * args , PyObject * keywds )
{
int bodyUniqueId = - 1 ;
double basePosition [ 3 ] ;
double baseOrientation [ 4 ] ;
PyObject * pylistPos ;
PyObject * pylistOrientation ;
b3PhysicsClientHandle sm = 0 ;
2016-06-13 17:11:28 +00:00
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
static char * kwlist [ ] = { " bodyUniqueId " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & bodyUniqueId , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-04-30 18:18:54 +00:00
2017-03-13 23:06:52 +00:00
if ( 0 = = pybullet_internalGetBasePositionAndOrientation (
bodyUniqueId , basePosition , baseOrientation , sm ) )
{
PyErr_SetString ( SpamError ,
" GetBasePositionAndOrientation failed. " ) ;
return NULL ;
}
{
PyObject * item ;
int i ;
int num = 3 ;
pylistPos = PyTuple_New ( num ) ;
for ( i = 0 ; i < num ; i + + )
{
item = PyFloat_FromDouble ( basePosition [ i ] ) ;
PyTuple_SetItem ( pylistPos , i , item ) ;
}
}
{
PyObject * item ;
int i ;
int num = 4 ;
pylistOrientation = PyTuple_New ( num ) ;
for ( i = 0 ; i < num ; i + + )
{
item = PyFloat_FromDouble ( baseOrientation [ i ] ) ;
PyTuple_SetItem ( pylistOrientation , i , item ) ;
}
}
{
PyObject * pylist ;
pylist = PyTuple_New ( 2 ) ;
PyTuple_SetItem ( pylist , 0 , pylistPos ) ;
PyTuple_SetItem ( pylist , 1 , pylistOrientation ) ;
return pylist ;
}
}
2016-11-28 23:11:34 +00:00
static PyObject * pybullet_getBaseVelocity ( PyObject * self ,
2017-03-13 23:06:52 +00:00
PyObject * args , PyObject * keywds )
{
2016-12-28 04:25:52 +00:00
int bodyUniqueId = - 1 ;
2016-11-28 23:11:34 +00:00
double baseLinearVelocity [ 3 ] ;
double baseAngularVelocity [ 3 ] ;
2017-03-13 23:06:52 +00:00
PyObject * pylistLinVel = 0 ;
PyObject * pylistAngVel = 0 ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2016-11-28 23:11:34 +00:00
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & bodyUniqueId , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
2016-11-28 23:11:34 +00:00
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
2016-11-28 23:11:34 +00:00
return NULL ;
}
2017-03-13 23:06:52 +00:00
2016-11-28 23:11:34 +00:00
if ( 0 = = pybullet_internalGetBaseVelocity (
2017-03-13 23:06:52 +00:00
bodyUniqueId , baseLinearVelocity , baseAngularVelocity , sm ) )
{
2016-11-28 23:11:34 +00:00
PyErr_SetString ( SpamError ,
2017-03-13 23:06:52 +00:00
" getBaseVelocity failed. " ) ;
2016-11-28 23:11:34 +00:00
return NULL ;
}
{
PyObject * item ;
int i ;
int num = 3 ;
pylistLinVel = PyTuple_New ( num ) ;
2017-03-13 23:06:52 +00:00
for ( i = 0 ; i < num ; i + + )
{
2016-11-28 23:11:34 +00:00
item = PyFloat_FromDouble ( baseLinearVelocity [ i ] ) ;
PyTuple_SetItem ( pylistLinVel , i , item ) ;
}
}
{
PyObject * item ;
int i ;
int num = 3 ;
pylistAngVel = PyTuple_New ( num ) ;
2017-03-13 23:06:52 +00:00
for ( i = 0 ; i < num ; i + + )
{
2016-11-28 23:11:34 +00:00
item = PyFloat_FromDouble ( baseAngularVelocity [ i ] ) ;
PyTuple_SetItem ( pylistAngVel , i , item ) ;
}
}
{
PyObject * pylist ;
pylist = PyTuple_New ( 2 ) ;
PyTuple_SetItem ( pylist , 0 , pylistLinVel ) ;
PyTuple_SetItem ( pylist , 1 , pylistAngVel ) ;
return pylist ;
}
}
2016-12-28 04:25:52 +00:00
static PyObject * pybullet_getNumBodies ( PyObject * self , PyObject * args , PyObject * keywds )
2016-09-27 19:13:45 +00:00
{
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-09-27 19:13:45 +00:00
2017-03-13 23:06:52 +00:00
{
int numBodies = b3GetNumBodies ( sm ) ;
2016-09-27 19:13:45 +00:00
# if PY_MAJOR_VERSION >= 3
2017-03-13 23:06:52 +00:00
return PyLong_FromLong ( numBodies ) ;
2016-09-27 19:13:45 +00:00
# else
2017-03-13 23:06:52 +00:00
return PyInt_FromLong ( numBodies ) ;
2016-09-27 19:13:45 +00:00
# endif
2017-03-13 23:06:52 +00:00
}
2016-09-27 19:13:45 +00:00
}
2016-12-28 04:25:52 +00:00
static PyObject * pybullet_getBodyUniqueId ( PyObject * self , PyObject * args , PyObject * keywds )
2016-09-27 19:13:45 +00:00
{
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
int serialIndex = - 1 ;
b3PhysicsClientHandle sm = 0 ;
2016-12-28 04:25:52 +00:00
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " serialIndex " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & serialIndex , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-09-27 19:13:45 +00:00
{
2017-03-13 23:06:52 +00:00
int bodyUniqueId = - 1 ;
bodyUniqueId = b3GetBodyUniqueId ( sm , serialIndex ) ;
2016-09-27 19:13:45 +00:00
# if PY_MAJOR_VERSION >= 3
2017-03-13 23:06:52 +00:00
return PyLong_FromLong ( bodyUniqueId ) ;
2016-09-27 19:13:45 +00:00
# else
2017-03-13 23:06:52 +00:00
return PyInt_FromLong ( bodyUniqueId ) ;
2016-09-27 19:13:45 +00:00
# endif
2017-03-13 23:06:52 +00:00
}
2016-09-27 19:13:45 +00:00
}
2018-09-22 21:18:21 +00:00
static PyObject * pybullet_removeCollisionShape ( PyObject * self , PyObject * args , PyObject * keywds )
{
{
2018-09-23 21:17:31 +00:00
int collisionShapeId = - 1 ;
2018-09-22 21:18:21 +00:00
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
static char * kwlist [ ] = { " collisionShapeId " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & collisionShapeId , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-09-23 21:17:31 +00:00
if ( collisionShapeId > = 0 )
2018-09-22 21:18:21 +00:00
{
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
if ( b3CanSubmitCommand ( sm ) )
{
2018-09-23 21:17:31 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , b3InitRemoveCollisionShapeCommand ( sm , collisionShapeId ) ) ;
2018-09-22 21:18:21 +00:00
statusType = b3GetStatusType ( statusHandle ) ;
}
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-05-04 04:53:29 +00:00
static PyObject * pybullet_removeBody ( PyObject * self , PyObject * args , PyObject * keywds )
{
{
int bodyUniqueId = - 1 ;
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
static char * kwlist [ ] = { " bodyUniqueId " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & bodyUniqueId , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-09-23 21:17:31 +00:00
if ( bodyUniqueId > = 0 )
2017-05-04 04:53:29 +00:00
{
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
if ( b3CanSubmitCommand ( sm ) )
{
2018-09-23 21:17:31 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , b3InitRemoveBodyCommand ( sm , bodyUniqueId ) ) ;
2017-05-04 04:53:29 +00:00
statusType = b3GetStatusType ( statusHandle ) ;
}
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2016-12-28 04:25:52 +00:00
static PyObject * pybullet_getBodyInfo ( PyObject * self , PyObject * args , PyObject * keywds )
2016-09-27 19:13:45 +00:00
{
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
int bodyUniqueId = - 1 ;
b3PhysicsClientHandle sm = 0 ;
2016-12-28 04:25:52 +00:00
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
static char * kwlist [ ] = { " bodyUniqueId " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & bodyUniqueId , & physicsClientId ) )
2016-09-27 19:13:45 +00:00
{
2017-03-13 23:06:52 +00:00
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
2016-12-28 04:25:52 +00:00
return NULL ;
2016-09-27 19:13:45 +00:00
}
2017-03-13 23:06:52 +00:00
{
struct b3BodyInfo info ;
if ( b3GetBodyInfo ( sm , bodyUniqueId , & info ) )
{
2017-03-29 21:56:05 +00:00
PyObject * pyListJointInfo = PyTuple_New ( 2 ) ;
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( pyListJointInfo , 0 , PyString_FromString ( info . m_baseName ) ) ;
2017-03-29 22:37:33 +00:00
PyTuple_SetItem ( pyListJointInfo , 1 , PyString_FromString ( info . m_bodyName ) ) ;
2017-03-13 23:06:52 +00:00
return pyListJointInfo ;
}
}
2016-12-28 04:25:52 +00:00
}
2017-03-14 20:13:16 +00:00
PyErr_SetString ( SpamError , " Couldn't get body info " ) ;
2017-03-13 23:06:52 +00:00
return NULL ;
2016-09-27 19:13:45 +00:00
}
2017-01-23 03:08:31 +00:00
static PyObject * pybullet_getConstraintInfo ( PyObject * self , PyObject * args , PyObject * keywds )
{
2017-03-13 23:06:52 +00:00
{
int constraintUniqueId = - 1 ;
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " constraintUniqueId " , " physicsClientId " , NULL } ;
2017-03-13 23:06:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & constraintUniqueId , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
struct b3UserConstraint constraintInfo ;
if ( b3GetUserConstraintInfo ( sm , constraintUniqueId , & constraintInfo ) )
{
2017-10-22 18:03:41 +00:00
PyObject * pyListConstraintInfo = PyTuple_New ( 15 ) ;
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( pyListConstraintInfo , 0 , PyLong_FromLong ( constraintInfo . m_parentBodyIndex ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 1 , PyLong_FromLong ( constraintInfo . m_parentJointIndex ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 2 , PyLong_FromLong ( constraintInfo . m_childBodyIndex ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 3 , PyLong_FromLong ( constraintInfo . m_childJointIndex ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 4 , PyLong_FromLong ( constraintInfo . m_jointType ) ) ;
2017-01-23 03:08:31 +00:00
{
2017-03-13 23:06:52 +00:00
PyObject * axisObj = PyTuple_New ( 3 ) ;
PyTuple_SetItem ( axisObj , 0 , PyFloat_FromDouble ( constraintInfo . m_jointAxis [ 0 ] ) ) ;
PyTuple_SetItem ( axisObj , 1 , PyFloat_FromDouble ( constraintInfo . m_jointAxis [ 1 ] ) ) ;
PyTuple_SetItem ( axisObj , 2 , PyFloat_FromDouble ( constraintInfo . m_jointAxis [ 2 ] ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 5 , axisObj ) ;
2017-01-23 03:08:31 +00:00
}
2017-03-13 23:06:52 +00:00
{
PyObject * parentFramePositionObj = PyTuple_New ( 3 ) ;
PyTuple_SetItem ( parentFramePositionObj , 0 , PyFloat_FromDouble ( constraintInfo . m_parentFrame [ 0 ] ) ) ;
PyTuple_SetItem ( parentFramePositionObj , 1 , PyFloat_FromDouble ( constraintInfo . m_parentFrame [ 1 ] ) ) ;
PyTuple_SetItem ( parentFramePositionObj , 2 , PyFloat_FromDouble ( constraintInfo . m_parentFrame [ 2 ] ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 6 , parentFramePositionObj ) ;
2017-01-23 03:08:31 +00:00
}
2017-03-13 23:06:52 +00:00
{
PyObject * childFramePositionObj = PyTuple_New ( 3 ) ;
PyTuple_SetItem ( childFramePositionObj , 0 , PyFloat_FromDouble ( constraintInfo . m_childFrame [ 0 ] ) ) ;
PyTuple_SetItem ( childFramePositionObj , 1 , PyFloat_FromDouble ( constraintInfo . m_childFrame [ 1 ] ) ) ;
PyTuple_SetItem ( childFramePositionObj , 2 , PyFloat_FromDouble ( constraintInfo . m_childFrame [ 2 ] ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 7 , childFramePositionObj ) ;
}
{
PyObject * parentFrameOrientationObj = PyTuple_New ( 4 ) ;
PyTuple_SetItem ( parentFrameOrientationObj , 0 , PyFloat_FromDouble ( constraintInfo . m_parentFrame [ 3 ] ) ) ;
PyTuple_SetItem ( parentFrameOrientationObj , 1 , PyFloat_FromDouble ( constraintInfo . m_parentFrame [ 4 ] ) ) ;
PyTuple_SetItem ( parentFrameOrientationObj , 2 , PyFloat_FromDouble ( constraintInfo . m_parentFrame [ 5 ] ) ) ;
PyTuple_SetItem ( parentFrameOrientationObj , 3 , PyFloat_FromDouble ( constraintInfo . m_parentFrame [ 6 ] ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 8 , parentFrameOrientationObj ) ;
}
{
PyObject * childFrameOrientation = PyTuple_New ( 4 ) ;
PyTuple_SetItem ( childFrameOrientation , 0 , PyFloat_FromDouble ( constraintInfo . m_childFrame [ 3 ] ) ) ;
PyTuple_SetItem ( childFrameOrientation , 1 , PyFloat_FromDouble ( constraintInfo . m_childFrame [ 4 ] ) ) ;
PyTuple_SetItem ( childFrameOrientation , 2 , PyFloat_FromDouble ( constraintInfo . m_childFrame [ 5 ] ) ) ;
PyTuple_SetItem ( childFrameOrientation , 3 , PyFloat_FromDouble ( constraintInfo . m_childFrame [ 6 ] ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 9 , childFrameOrientation ) ;
}
PyTuple_SetItem ( pyListConstraintInfo , 10 , PyFloat_FromDouble ( constraintInfo . m_maxAppliedForce ) ) ;
2017-10-22 18:03:41 +00:00
PyTuple_SetItem ( pyListConstraintInfo , 11 , PyFloat_FromDouble ( constraintInfo . m_gearRatio ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 12 , PyLong_FromLong ( constraintInfo . m_gearAuxLink ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 13 , PyFloat_FromDouble ( constraintInfo . m_relativePositionTarget ) ) ;
PyTuple_SetItem ( pyListConstraintInfo , 14 , PyFloat_FromDouble ( constraintInfo . m_erp ) ) ;
2017-01-23 03:08:31 +00:00
2017-03-13 23:06:52 +00:00
return pyListConstraintInfo ;
}
}
}
2017-01-23 03:08:31 +00:00
2017-03-14 20:13:16 +00:00
PyErr_SetString ( SpamError , " Couldn't get user constraint info " ) ;
2017-03-13 23:06:52 +00:00
return NULL ;
2017-01-23 03:08:31 +00:00
}
2017-10-19 02:15:35 +00:00
static PyObject * pybullet_getConstraintState ( PyObject * self , PyObject * args , PyObject * keywds )
{
{
int constraintUniqueId = - 1 ;
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " constraintUniqueId " , " physicsClientId " , NULL } ;
2017-10-19 02:15:35 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & constraintUniqueId , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
b3SharedMemoryCommandHandle cmd_handle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
if ( b3CanSubmitCommand ( sm ) )
{
struct b3UserConstraintState constraintState ;
cmd_handle = b3InitGetUserConstraintStateCommand ( sm , constraintUniqueId ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , cmd_handle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( b3GetStatusUserConstraintState ( statusHandle , & constraintState ) )
{
if ( constraintState . m_numDofs )
{
PyObject * appliedConstraintForces = PyTuple_New ( constraintState . m_numDofs ) ;
int i = 0 ;
for ( i = 0 ; i < constraintState . m_numDofs ; i + + )
{
PyTuple_SetItem ( appliedConstraintForces , i , PyFloat_FromDouble ( constraintState . m_appliedConstraintForces [ i ] ) ) ;
}
return appliedConstraintForces ;
}
}
}
}
}
PyErr_SetString ( SpamError , " Couldn't getConstraintState. " ) ;
return NULL ;
}
2017-05-04 01:25:25 +00:00
static PyObject * pybullet_getConstraintUniqueId ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
int serialIndex = - 1 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-11 20:24:35 +00:00
2017-05-04 01:25:25 +00:00
static char * kwlist [ ] = { " serialIndex " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & serialIndex , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2017-05-04 01:25:25 +00:00
{
int userConstraintId = - 1 ;
userConstraintId = b3GetUserConstraintId ( sm , serialIndex ) ;
2018-09-11 20:24:35 +00:00
2017-05-04 01:25:25 +00:00
# if PY_MAJOR_VERSION >= 3
return PyLong_FromLong ( userConstraintId ) ;
# else
return PyInt_FromLong ( userConstraintId ) ;
# endif
}
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getNumConstraints ( PyObject * self , PyObject * args , PyObject * keywds )
2016-09-27 19:13:45 +00:00
{
2017-03-13 23:06:52 +00:00
int numConstraints = 0 ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
numConstraints = b3GetNumUserConstraints ( sm ) ;
2016-05-10 07:57:54 +00:00
# if PY_MAJOR_VERSION >= 3
2017-03-13 23:06:52 +00:00
return PyLong_FromLong ( numConstraints ) ;
2016-05-10 07:57:54 +00:00
# else
2017-03-13 23:06:52 +00:00
return PyInt_FromLong ( numConstraints ) ;
2016-05-10 07:57:54 +00:00
# endif
}
2017-06-16 02:46:27 +00:00
// Return the number of joints in an object based on
// body index; body index is based on order of sequence
// the object is loaded into simulation
static PyObject * pybullet_getAPIVersion ( PyObject * self , PyObject * args , PyObject * keywds )
{
2017-08-25 21:04:45 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
{
return NULL ;
}
2017-06-16 02:46:27 +00:00
# if PY_MAJOR_VERSION >= 3
return PyLong_FromLong ( SHARED_MEMORY_MAGIC_NUMBER ) ;
# else
return PyInt_FromLong ( SHARED_MEMORY_MAGIC_NUMBER ) ;
# endif
}
2017-03-13 23:06:52 +00:00
// Return the number of joints in an object based on
// body index; body index is based on order of sequence
// the object is loaded into simulation
static PyObject * pybullet_getNumJoints ( PyObject * self , PyObject * args , PyObject * keywds )
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
int bodyUniqueId = - 1 ;
int numJoints = 0 ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
2017-03-13 23:06:52 +00:00
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " bodyUniqueId " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & bodyUniqueId , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-06-23 06:21:47 +00:00
2017-03-13 23:06:52 +00:00
numJoints = b3GetNumJoints ( sm , bodyUniqueId ) ;
# if PY_MAJOR_VERSION >= 3
return PyLong_FromLong ( numJoints ) ;
# else
return PyInt_FromLong ( numJoints ) ;
# endif
}
2016-06-14 21:58:36 +00:00
2017-03-13 23:06:52 +00:00
// Initalize all joint positions given a list of values
static PyObject * pybullet_resetJointState ( PyObject * self , PyObject * args , PyObject * keywds )
{
{
int bodyUniqueId ;
int jointIndex ;
double targetValue ;
2017-03-23 17:29:16 +00:00
double targetVelocity = 0 ;
2017-03-13 23:06:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
2017-03-23 17:29:16 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " jointIndex " , " targetValue " , " targetVelocity " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iid|di " , kwlist , & bodyUniqueId , & jointIndex , & targetValue , & targetVelocity , & physicsClientId ) )
2017-03-13 23:06:52 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
{
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int numJoints ;
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
numJoints = b3GetNumJoints ( sm , bodyUniqueId ) ;
if ( ( jointIndex > = numJoints ) | | ( jointIndex < 0 ) )
{
PyErr_SetString ( SpamError , " Joint index out-of-range. " ) ;
return NULL ;
}
2016-06-15 21:21:04 +00:00
2017-03-13 23:06:52 +00:00
commandHandle = b3CreatePoseCommandInit ( sm , bodyUniqueId ) ;
2016-11-28 23:11:34 +00:00
2017-03-13 23:06:52 +00:00
b3CreatePoseCommandSetJointPosition ( sm , commandHandle , jointIndex ,
targetValue ) ;
2016-11-28 23:11:34 +00:00
2017-03-23 17:29:16 +00:00
b3CreatePoseCommandSetJointVelocity ( sm , commandHandle , jointIndex ,
targetVelocity ) ;
2017-03-13 23:06:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
}
}
2017-03-14 20:13:16 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2017-03-13 23:06:52 +00:00
}
2016-11-28 23:11:34 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_resetBaseVelocity ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-28 23:11:34 +00:00
{
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " objectUniqueId " , " linearVelocity " , " angularVelocity " , " physicsClientId " , NULL } ;
2016-11-28 23:11:34 +00:00
{
2017-05-28 20:30:20 +00:00
int bodyUniqueId = 0 ;
2017-03-13 23:06:52 +00:00
PyObject * linVelObj = 0 ;
PyObject * angVelObj = 0 ;
double linVel [ 3 ] = { 0 , 0 , 0 } ;
double angVel [ 3 ] = { 0 , 0 , 0 } ;
int physicsClientId = 0 ;
2016-12-28 04:25:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2017-05-28 20:30:20 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|OOi " , kwlist , & bodyUniqueId , & linVelObj , & angVelObj , & physicsClientId ) )
2016-11-28 23:11:34 +00:00
{
return NULL ;
}
2016-12-28 04:25:52 +00:00
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-12-28 04:25:52 +00:00
2016-11-28 23:11:34 +00:00
if ( linVelObj | | angVelObj )
{
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
2017-05-28 20:30:20 +00:00
commandHandle = b3CreatePoseCommandInit ( sm , bodyUniqueId ) ;
2016-11-28 23:11:34 +00:00
if ( linVelObj )
{
pybullet_internalSetVectord ( linVelObj , linVel ) ;
b3CreatePoseCommandSetBaseLinearVelocity ( commandHandle , linVel ) ;
}
if ( angVelObj )
{
pybullet_internalSetVectord ( angVelObj , angVel ) ;
b3CreatePoseCommandSetBaseAngularVelocity ( commandHandle , angVel ) ;
}
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
else
{
PyErr_SetString ( SpamError , " expected at least linearVelocity and/or angularVelocity. " ) ;
return NULL ;
}
}
PyErr_SetString ( SpamError , " error in resetJointState. " ) ;
return NULL ;
}
2016-09-08 18:12:58 +00:00
// Reset the position and orientation of the base/root link, position [x,y,z]
// and orientation quaternion [x,y,z,w]
static PyObject * pybullet_resetBasePositionAndOrientation ( PyObject * self ,
2017-03-13 23:06:52 +00:00
PyObject * args , PyObject * keywds )
{
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
int bodyUniqueId ;
PyObject * posObj ;
PyObject * ornObj ;
double pos [ 3 ] ;
double orn [ 4 ] ; // as a quaternion
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
static char * kwlist [ ] = { " bodyUniqueId " , " posObj " , " ornObj " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iOO|i " , kwlist , & bodyUniqueId , & posObj , & ornObj , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
{
PyObject * seq ;
int len , i ;
seq = PySequence_Fast ( posObj , " expected a sequence " ) ;
len = PySequence_Size ( posObj ) ;
if ( len = = 3 )
{
for ( i = 0 ; i < 3 ; i + + )
{
pos [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
}
else
{
PyErr_SetString ( SpamError , " position needs a 3 coordinates [x,y,z]. " ) ;
Py_DECREF ( seq ) ;
return NULL ;
}
Py_DECREF ( seq ) ;
}
{
PyObject * seq ;
int len , i ;
seq = PySequence_Fast ( ornObj , " expected a sequence " ) ;
len = PySequence_Size ( ornObj ) ;
if ( len = = 4 )
{
for ( i = 0 ; i < 4 ; i + + )
{
orn [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
}
else
{
PyErr_SetString (
SpamError ,
" orientation needs a 4 coordinates, quaternion [x,y,z,w]. " ) ;
Py_DECREF ( seq ) ;
return NULL ;
}
Py_DECREF ( seq ) ;
}
commandHandle = b3CreatePoseCommandInit ( sm , bodyUniqueId ) ;
b3CreatePoseCommandSetBasePosition ( commandHandle , pos [ 0 ] , pos [ 1 ] , pos [ 2 ] ) ;
b3CreatePoseCommandSetBaseOrientation ( commandHandle , orn [ 0 ] , orn [ 1 ] ,
orn [ 2 ] , orn [ 3 ] ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
}
2016-12-28 04:25:52 +00:00
}
2017-03-14 20:13:16 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-06-14 21:08:24 +00:00
}
2016-06-27 01:18:30 +00:00
2017-05-28 20:30:20 +00:00
// Get the a single joint info for a specific bodyUniqueId
2016-06-14 21:58:36 +00:00
//
2016-06-15 21:21:04 +00:00
// Args:
2017-05-28 20:30:20 +00:00
// bodyUniqueId - integer indicating body in simulation
2016-06-15 21:21:04 +00:00
// jointIndex - integer indicating joint for a specific body
//
2016-06-14 21:58:36 +00:00
// Joint information includes:
// index, name, type, q-index, u-index,
// flags, joint damping, joint friction
//
2016-09-08 18:12:58 +00:00
// The format of the returned list is
2016-06-14 21:58:36 +00:00
// [int, str, int, int, int, int, float, float]
//
2016-06-14 21:08:24 +00:00
// TODO(hellojas): get joint positions for a body
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getJointInfo ( PyObject * self , PyObject * args , PyObject * keywds )
{
PyObject * pyListJointInfo ;
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
struct b3JointInfo info ;
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
int bodyUniqueId = - 1 ;
int jointIndex = - 1 ;
2018-01-04 03:17:28 +00:00
int jointInfoSize = 17 ; // size of struct b3JointInfo
2017-03-13 23:06:52 +00:00
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
static char * kwlist [ ] = { " bodyUniqueId " , " jointIndex " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|i " , kwlist , & bodyUniqueId , & jointIndex , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
{
{
2017-05-28 20:30:20 +00:00
// printf("body index = %d, joint index =%d\n", bodyUniqueId, jointIndex);
2017-03-13 23:06:52 +00:00
pyListJointInfo = PyTuple_New ( jointInfoSize ) ;
if ( b3GetJointInfo ( sm , bodyUniqueId , jointIndex , & info ) )
{
// printf("Joint%d %s, type %d, at q-index %d and u-index %d\n",
// info.m_jointIndex,
// info.m_jointName,
// info.m_jointType,
// info.m_qIndex,
// info.m_uIndex);
// printf(" flags=%d jointDamping=%f jointFriction=%f\n",
// info.m_flags,
// info.m_jointDamping,
// info.m_jointFriction);
PyTuple_SetItem ( pyListJointInfo , 0 , PyInt_FromLong ( info . m_jointIndex ) ) ;
2018-09-11 20:24:35 +00:00
2017-10-06 23:00:33 +00:00
if ( info . m_jointName [ 0 ] )
2017-08-30 02:14:27 +00:00
{
PyTuple_SetItem ( pyListJointInfo , 1 ,
2018-09-23 21:17:31 +00:00
PyString_FromString ( info . m_jointName ) ) ;
}
else
2017-08-30 02:14:27 +00:00
{
PyTuple_SetItem ( pyListJointInfo , 1 ,
2018-09-23 21:17:31 +00:00
PyString_FromString ( " not available " ) ) ;
2017-08-30 02:14:27 +00:00
}
2018-09-11 20:24:35 +00:00
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( pyListJointInfo , 2 , PyInt_FromLong ( info . m_jointType ) ) ;
PyTuple_SetItem ( pyListJointInfo , 3 , PyInt_FromLong ( info . m_qIndex ) ) ;
PyTuple_SetItem ( pyListJointInfo , 4 , PyInt_FromLong ( info . m_uIndex ) ) ;
PyTuple_SetItem ( pyListJointInfo , 5 , PyInt_FromLong ( info . m_flags ) ) ;
PyTuple_SetItem ( pyListJointInfo , 6 ,
PyFloat_FromDouble ( info . m_jointDamping ) ) ;
PyTuple_SetItem ( pyListJointInfo , 7 ,
PyFloat_FromDouble ( info . m_jointFriction ) ) ;
2017-03-26 20:06:46 +00:00
PyTuple_SetItem ( pyListJointInfo , 8 ,
PyFloat_FromDouble ( info . m_jointLowerLimit ) ) ;
PyTuple_SetItem ( pyListJointInfo , 9 ,
PyFloat_FromDouble ( info . m_jointUpperLimit ) ) ;
PyTuple_SetItem ( pyListJointInfo , 10 ,
PyFloat_FromDouble ( info . m_jointMaxForce ) ) ;
PyTuple_SetItem ( pyListJointInfo , 11 ,
PyFloat_FromDouble ( info . m_jointMaxVelocity ) ) ;
2017-10-06 23:00:33 +00:00
if ( info . m_linkName [ 0 ] )
2017-08-30 02:14:27 +00:00
{
PyTuple_SetItem ( pyListJointInfo , 12 ,
PyString_FromString ( info . m_linkName ) ) ;
2018-09-23 21:17:31 +00:00
}
else
2017-08-30 02:14:27 +00:00
{
PyTuple_SetItem ( pyListJointInfo , 12 ,
PyString_FromString ( " not available " ) ) ;
}
2018-01-04 03:17:28 +00:00
{
PyObject * axis = PyTuple_New ( 3 ) ;
PyTuple_SetItem ( axis , 0 , PyFloat_FromDouble ( info . m_jointAxis [ 0 ] ) ) ;
PyTuple_SetItem ( axis , 1 , PyFloat_FromDouble ( info . m_jointAxis [ 1 ] ) ) ;
PyTuple_SetItem ( axis , 2 , PyFloat_FromDouble ( info . m_jointAxis [ 2 ] ) ) ;
PyTuple_SetItem ( pyListJointInfo , 13 , axis ) ;
}
{
PyObject * pos = PyTuple_New ( 3 ) ;
PyTuple_SetItem ( pos , 0 , PyFloat_FromDouble ( info . m_parentFrame [ 0 ] ) ) ;
PyTuple_SetItem ( pos , 1 , PyFloat_FromDouble ( info . m_parentFrame [ 1 ] ) ) ;
PyTuple_SetItem ( pos , 2 , PyFloat_FromDouble ( info . m_parentFrame [ 2 ] ) ) ;
PyTuple_SetItem ( pyListJointInfo , 14 , pos ) ;
}
{
PyObject * orn = PyTuple_New ( 4 ) ;
PyTuple_SetItem ( orn , 0 , PyFloat_FromDouble ( info . m_parentFrame [ 3 ] ) ) ;
PyTuple_SetItem ( orn , 1 , PyFloat_FromDouble ( info . m_parentFrame [ 4 ] ) ) ;
PyTuple_SetItem ( orn , 2 , PyFloat_FromDouble ( info . m_parentFrame [ 5 ] ) ) ;
PyTuple_SetItem ( orn , 3 , PyFloat_FromDouble ( info . m_parentFrame [ 6 ] ) ) ;
PyTuple_SetItem ( pyListJointInfo , 15 , orn ) ;
}
PyTuple_SetItem ( pyListJointInfo , 16 , PyInt_FromLong ( info . m_parentIndex ) ) ;
2017-03-13 23:06:52 +00:00
return pyListJointInfo ;
}
else
{
PyErr_SetString ( SpamError , " GetJointInfo failed. " ) ;
return NULL ;
}
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-09-08 18:12:58 +00:00
}
2016-06-14 21:08:24 +00:00
2017-05-28 20:30:20 +00:00
// Returns the state of a specific joint in a given bodyUniqueId
2016-06-15 21:21:04 +00:00
//
// Args:
2017-05-28 20:30:20 +00:00
// bodyUniqueId - integer indicating body in simulation
2016-06-15 21:21:04 +00:00
// jointIndex - integer indicating joint for a specific body
//
2016-06-14 21:08:24 +00:00
// The state of a joint includes the following:
// position, velocity, force torque (6 values), and motor torque
// The returned pylist is an array of [float, float, float[6], float]
2016-09-08 18:12:58 +00:00
// TODO(hellojas): check accuracy of position and velocity
2016-06-14 21:08:24 +00:00
// TODO(hellojas): check force torque values
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getJointState ( PyObject * self , PyObject * args , PyObject * keywds )
{
PyObject * pyListJointForceTorque ;
PyObject * pyListJointState ;
2016-09-27 19:13:45 +00:00
2017-03-13 23:06:52 +00:00
struct b3JointSensorState sensorState ;
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
int bodyUniqueId = - 1 ;
int jointIndex = - 1 ;
int sensorStateSize = 4 ; // size of struct b3JointSensorState
int forceTorqueSize = 6 ; // size of force torque list from b3JointSensorState
int j ;
2016-06-14 21:08:24 +00:00
2016-12-28 04:25:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
static char * kwlist [ ] = { " bodyUniqueId " , " jointIndex " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|i " , kwlist , & bodyUniqueId , & jointIndex , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-06-24 14:31:17 +00:00
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
{
int status_type = 0 ;
b3SharedMemoryCommandHandle cmd_handle ;
b3SharedMemoryStatusHandle status_handle ;
2016-09-24 18:25:05 +00:00
2017-03-13 23:06:52 +00:00
if ( bodyUniqueId < 0 )
{
2017-05-28 20:30:20 +00:00
PyErr_SetString ( SpamError , " getJointState failed; invalid bodyUniqueId " ) ;
2017-03-13 23:06:52 +00:00
return NULL ;
}
if ( jointIndex < 0 )
{
PyErr_SetString ( SpamError , " getJointState failed; invalid jointIndex " ) ;
return NULL ;
}
2016-09-23 22:57:35 +00:00
2017-03-13 23:06:52 +00:00
cmd_handle =
b3RequestActualStateCommandInit ( sm , bodyUniqueId ) ;
status_handle =
b3SubmitClientCommandAndWaitStatus ( sm , cmd_handle ) ;
2016-06-14 21:08:24 +00:00
2017-03-13 23:06:52 +00:00
status_type = b3GetStatusType ( status_handle ) ;
if ( status_type ! = CMD_ACTUAL_STATE_UPDATE_COMPLETED )
{
PyErr_SetString ( SpamError , " getJointState failed. " ) ;
return NULL ;
}
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
pyListJointState = PyTuple_New ( sensorStateSize ) ;
pyListJointForceTorque = PyTuple_New ( forceTorqueSize ) ;
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
if ( b3GetJointState ( sm , status_handle , jointIndex , & sensorState ) )
{
PyTuple_SetItem ( pyListJointState , 0 ,
PyFloat_FromDouble ( sensorState . m_jointPosition ) ) ;
PyTuple_SetItem ( pyListJointState , 1 ,
PyFloat_FromDouble ( sensorState . m_jointVelocity ) ) ;
2017-01-21 02:13:24 +00:00
2017-03-13 23:06:52 +00:00
for ( j = 0 ; j < forceTorqueSize ; j + + )
{
PyTuple_SetItem ( pyListJointForceTorque , j ,
PyFloat_FromDouble ( sensorState . m_jointForceTorque [ j ] ) ) ;
}
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( pyListJointState , 2 , pyListJointForceTorque ) ;
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( pyListJointState , 3 ,
PyFloat_FromDouble ( sensorState . m_jointMotorTorque ) ) ;
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
return pyListJointState ;
}
else
{
PyErr_SetString ( SpamError , " getJointState failed (2). " ) ;
return NULL ;
}
}
}
2016-06-14 21:08:24 +00:00
2017-03-13 23:06:52 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-09-08 18:12:58 +00:00
}
2016-06-17 01:46:34 +00:00
2017-05-14 01:07:49 +00:00
static PyObject * pybullet_getJointStates ( PyObject * self , PyObject * args , PyObject * keywds )
{
PyObject * pyListJointForceTorque ;
PyObject * pyListJointState ;
2018-09-23 21:17:31 +00:00
PyObject * jointIndicesObj = 0 ;
2017-05-14 01:07:49 +00:00
struct b3JointSensorState sensorState ;
int bodyUniqueId = - 1 ;
int sensorStateSize = 4 ; // size of struct b3JointSensorState
int forceTorqueSize = 6 ; // size of force torque list from b3JointSensorState
int j ;
b3PhysicsClientHandle sm = 0 ;
int physicsClientId = 0 ;
static char * kwlist [ ] = { " bodyUniqueId " , " jointIndices " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iO|i " , kwlist , & bodyUniqueId , & jointIndicesObj , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
{
int i ;
int status_type = 0 ;
int numRequestedJoints = 0 ;
PyObject * jointIndicesSeq = 0 ;
int numJoints = 0 ;
2018-09-23 21:17:31 +00:00
PyObject * resultListJointState = 0 ;
2017-05-14 01:07:49 +00:00
b3SharedMemoryCommandHandle cmd_handle ;
b3SharedMemoryStatusHandle status_handle ;
if ( bodyUniqueId < 0 )
{
2017-05-28 20:30:20 +00:00
PyErr_SetString ( SpamError , " getJointState failed; invalid bodyUniqueId " ) ;
2017-05-14 01:07:49 +00:00
return NULL ;
}
numJoints = b3GetNumJoints ( sm , bodyUniqueId ) ;
2018-09-23 21:17:31 +00:00
jointIndicesSeq = PySequence_Fast ( jointIndicesObj , " expected a sequence of joint indices " ) ;
2017-05-14 01:07:49 +00:00
2018-09-23 21:17:31 +00:00
if ( jointIndicesSeq = = 0 )
2017-05-14 01:07:49 +00:00
{
PyErr_SetString ( SpamError , " expected a sequence of joint indices " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2017-05-14 01:07:49 +00:00
numRequestedJoints = PySequence_Size ( jointIndicesObj ) ;
2018-09-23 21:17:31 +00:00
if ( numRequestedJoints = = 0 )
2017-05-14 01:07:49 +00:00
{
Py_DECREF ( jointIndicesSeq ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2018-09-11 20:24:35 +00:00
2017-05-14 01:07:49 +00:00
cmd_handle =
b3RequestActualStateCommandInit ( sm , bodyUniqueId ) ;
status_handle =
b3SubmitClientCommandAndWaitStatus ( sm , cmd_handle ) ;
status_type = b3GetStatusType ( status_handle ) ;
if ( status_type ! = CMD_ACTUAL_STATE_UPDATE_COMPLETED )
{
PyErr_SetString ( SpamError , " getJointState failed. " ) ;
return NULL ;
}
resultListJointState = PyTuple_New ( numRequestedJoints ) ;
for ( i = 0 ; i < numRequestedJoints ; i + + )
{
int jointIndex = pybullet_internalGetFloatFromSequence ( jointIndicesSeq , i ) ;
if ( ( jointIndex > = numJoints ) | | ( jointIndex < 0 ) )
{
Py_DECREF ( jointIndicesSeq ) ;
PyErr_SetString ( SpamError , " Joint index out-of-range. " ) ;
return NULL ;
}
pyListJointState = PyTuple_New ( sensorStateSize ) ;
pyListJointForceTorque = PyTuple_New ( forceTorqueSize ) ;
if ( b3GetJointState ( sm , status_handle , jointIndex , & sensorState ) )
{
PyTuple_SetItem ( pyListJointState , 0 ,
PyFloat_FromDouble ( sensorState . m_jointPosition ) ) ;
PyTuple_SetItem ( pyListJointState , 1 ,
PyFloat_FromDouble ( sensorState . m_jointVelocity ) ) ;
for ( j = 0 ; j < forceTorqueSize ; j + + )
{
PyTuple_SetItem ( pyListJointForceTorque , j ,
PyFloat_FromDouble ( sensorState . m_jointForceTorque [ j ] ) ) ;
}
PyTuple_SetItem ( pyListJointState , 2 , pyListJointForceTorque ) ;
PyTuple_SetItem ( pyListJointState , 3 ,
PyFloat_FromDouble ( sensorState . m_jointMotorTorque ) ) ;
PyTuple_SetItem ( resultListJointState , i , pyListJointState ) ;
}
else
{
PyErr_SetString ( SpamError , " getJointState failed (2). " ) ;
return NULL ;
}
}
2018-05-02 20:12:25 +00:00
Py_DECREF ( jointIndicesSeq ) ;
2017-05-14 01:07:49 +00:00
return resultListJointState ;
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getLinkState ( PyObject * self , PyObject * args , PyObject * keywds )
{
PyObject * pyLinkState ;
PyObject * pyLinkStateWorldPosition ;
PyObject * pyLinkStateWorldOrientation ;
PyObject * pyLinkStateLocalInertialPosition ;
PyObject * pyLinkStateLocalInertialOrientation ;
PyObject * pyLinkStateWorldLinkFramePosition ;
PyObject * pyLinkStateWorldLinkFrameOrientation ;
2017-03-26 20:06:46 +00:00
PyObject * pyLinkStateWorldLinkLinearVelocity ;
PyObject * pyLinkStateWorldLinkAngularVelocity ;
2016-09-23 22:57:35 +00:00
2017-03-13 23:06:52 +00:00
struct b3LinkState linkState ;
2016-09-23 22:57:35 +00:00
2017-03-13 23:06:52 +00:00
int bodyUniqueId = - 1 ;
int linkIndex = - 1 ;
2017-03-26 20:06:46 +00:00
int computeLinkVelocity = 0 ;
2017-09-26 17:05:17 +00:00
int computeForwardKinematics = 0 ;
2017-03-26 20:06:46 +00:00
2017-03-13 23:06:52 +00:00
int i ;
b3PhysicsClientHandle sm = 0 ;
2016-09-23 22:57:35 +00:00
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
2017-09-26 17:05:17 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " linkIndex " , " computeLinkVelocity " , " computeForwardKinematics " , " physicsClientId " , NULL } ;
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|iii " , kwlist , & bodyUniqueId , & linkIndex , & computeLinkVelocity , & computeForwardKinematics , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-09-23 22:57:35 +00:00
2017-03-13 23:06:52 +00:00
{
{
int status_type = 0 ;
b3SharedMemoryCommandHandle cmd_handle ;
b3SharedMemoryStatusHandle status_handle ;
2016-11-14 15:39:34 +00:00
2017-03-13 23:06:52 +00:00
if ( bodyUniqueId < 0 )
{
2017-05-28 20:30:20 +00:00
PyErr_SetString ( SpamError , " getLinkState failed; invalid bodyUniqueId " ) ;
2017-03-13 23:06:52 +00:00
return NULL ;
}
if ( linkIndex < 0 )
{
PyErr_SetString ( SpamError , " getLinkState failed; invalid linkIndex " ) ;
return NULL ;
}
cmd_handle =
b3RequestActualStateCommandInit ( sm , bodyUniqueId ) ;
2017-03-26 20:06:46 +00:00
if ( computeLinkVelocity )
{
2018-09-23 21:17:31 +00:00
b3RequestActualStateCommandComputeLinkVelocity ( cmd_handle , computeLinkVelocity ) ;
2017-03-26 20:06:46 +00:00
}
2017-09-26 17:05:17 +00:00
if ( computeForwardKinematics )
{
2018-09-23 21:17:31 +00:00
b3RequestActualStateCommandComputeForwardKinematics ( cmd_handle , computeForwardKinematics ) ;
2017-09-26 17:05:17 +00:00
}
2017-03-13 23:06:52 +00:00
status_handle =
b3SubmitClientCommandAndWaitStatus ( sm , cmd_handle ) ;
status_type = b3GetStatusType ( status_handle ) ;
if ( status_type ! = CMD_ACTUAL_STATE_UPDATE_COMPLETED )
{
PyErr_SetString ( SpamError , " getLinkState failed. " ) ;
return NULL ;
}
if ( b3GetLinkState ( sm , status_handle , linkIndex , & linkState ) )
{
pyLinkStateWorldPosition = PyTuple_New ( 3 ) ;
for ( i = 0 ; i < 3 ; + + i )
{
PyTuple_SetItem ( pyLinkStateWorldPosition , i ,
PyFloat_FromDouble ( linkState . m_worldPosition [ i ] ) ) ;
}
pyLinkStateWorldOrientation = PyTuple_New ( 4 ) ;
for ( i = 0 ; i < 4 ; + + i )
{
PyTuple_SetItem ( pyLinkStateWorldOrientation , i ,
PyFloat_FromDouble ( linkState . m_worldOrientation [ i ] ) ) ;
}
pyLinkStateLocalInertialPosition = PyTuple_New ( 3 ) ;
for ( i = 0 ; i < 3 ; + + i )
{
PyTuple_SetItem ( pyLinkStateLocalInertialPosition , i ,
PyFloat_FromDouble ( linkState . m_localInertialPosition [ i ] ) ) ;
}
pyLinkStateLocalInertialOrientation = PyTuple_New ( 4 ) ;
for ( i = 0 ; i < 4 ; + + i )
{
PyTuple_SetItem ( pyLinkStateLocalInertialOrientation , i ,
PyFloat_FromDouble ( linkState . m_localInertialOrientation [ i ] ) ) ;
}
pyLinkStateWorldLinkFramePosition = PyTuple_New ( 3 ) ;
for ( i = 0 ; i < 3 ; + + i )
{
PyTuple_SetItem ( pyLinkStateWorldLinkFramePosition , i ,
PyFloat_FromDouble ( linkState . m_worldLinkFramePosition [ i ] ) ) ;
}
pyLinkStateWorldLinkFrameOrientation = PyTuple_New ( 4 ) ;
for ( i = 0 ; i < 4 ; + + i )
{
PyTuple_SetItem ( pyLinkStateWorldLinkFrameOrientation , i ,
PyFloat_FromDouble ( linkState . m_worldLinkFrameOrientation [ i ] ) ) ;
}
2017-03-26 20:06:46 +00:00
if ( computeLinkVelocity )
{
pyLinkState = PyTuple_New ( 8 ) ;
2018-09-23 21:17:31 +00:00
}
else
2017-03-26 20:06:46 +00:00
{
pyLinkState = PyTuple_New ( 6 ) ;
}
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( pyLinkState , 0 , pyLinkStateWorldPosition ) ;
PyTuple_SetItem ( pyLinkState , 1 , pyLinkStateWorldOrientation ) ;
PyTuple_SetItem ( pyLinkState , 2 , pyLinkStateLocalInertialPosition ) ;
PyTuple_SetItem ( pyLinkState , 3 , pyLinkStateLocalInertialOrientation ) ;
PyTuple_SetItem ( pyLinkState , 4 , pyLinkStateWorldLinkFramePosition ) ;
PyTuple_SetItem ( pyLinkState , 5 , pyLinkStateWorldLinkFrameOrientation ) ;
2017-03-26 20:06:46 +00:00
if ( computeLinkVelocity )
{
pyLinkStateWorldLinkLinearVelocity = PyTuple_New ( 3 ) ;
pyLinkStateWorldLinkAngularVelocity = PyTuple_New ( 3 ) ;
for ( i = 0 ; i < 3 ; + + i )
{
PyTuple_SetItem ( pyLinkStateWorldLinkLinearVelocity , i ,
PyFloat_FromDouble ( linkState . m_worldLinearVelocity [ i ] ) ) ;
PyTuple_SetItem ( pyLinkStateWorldLinkAngularVelocity , i ,
PyFloat_FromDouble ( linkState . m_worldAngularVelocity [ i ] ) ) ;
}
PyTuple_SetItem ( pyLinkState , 6 , pyLinkStateWorldLinkLinearVelocity ) ;
PyTuple_SetItem ( pyLinkState , 7 , pyLinkStateWorldLinkAngularVelocity ) ;
}
2017-03-13 23:06:52 +00:00
return pyLinkState ;
}
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-01-17 23:42:32 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_readUserDebugParameter ( PyObject * self , PyObject * args , PyObject * keywds )
{
2017-01-17 23:42:32 +00:00
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
int itemUniqueId ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " itemUniqueId " , " physicsClientId " , NULL } ;
2017-01-17 23:42:32 +00:00
2017-03-13 23:06:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & itemUniqueId , & physicsClientId ) )
2017-01-17 23:42:32 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2017-01-17 23:42:32 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
commandHandle = b3InitUserDebugReadParameter ( sm , itemUniqueId ) ;
2017-01-17 23:42:32 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2017-03-13 23:06:52 +00:00
if ( statusType = = CMD_USER_DEBUG_DRAW_PARAMETER_COMPLETED )
2017-01-17 23:42:32 +00:00
{
2017-03-13 23:06:52 +00:00
double paramValue = 0.f ;
int ok = b3GetStatusDebugParameterValue ( statusHandle , & paramValue ) ;
2017-01-17 23:42:32 +00:00
if ( ok )
{
PyObject * item = PyFloat_FromDouble ( paramValue ) ;
return item ;
}
}
PyErr_SetString ( SpamError , " Failed to read parameter. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_addUserDebugParameter ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
char * text ;
double rangeMin = 0.f ;
double rangeMax = 1.f ;
double startValue = 0.f ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " paramName " , " rangeMin " , " rangeMax " , " startValue " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|dddi " , kwlist , & text , & rangeMin , & rangeMax , & startValue , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
commandHandle = b3InitUserDebugAddParameter ( sm , text , rangeMin , rangeMax , startValue ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_USER_DEBUG_DRAW_COMPLETED )
{
int debugItemUniqueId = b3GetDebugItemUniqueId ( statusHandle ) ;
PyObject * item = PyInt_FromLong ( debugItemUniqueId ) ;
return item ;
}
PyErr_SetString ( SpamError , " Error in addUserDebugParameter. " ) ;
return NULL ;
}
2017-01-17 23:42:32 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_addUserDebugText ( PyObject * self , PyObject * args , PyObject * keywds )
2017-01-17 23:42:32 +00:00
{
2017-03-13 23:06:52 +00:00
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
int res = 0 ;
char * text ;
double posXYZ [ 3 ] ;
double colorRGB [ 3 ] = { 1 , 1 , 1 } ;
PyObject * textPositionObj = 0 ;
PyObject * textColorRGBObj = 0 ;
Improve debug text/line rendering, can be use to draw frames and text in local coordinate of an object / link.
example:
kuka = p.loadURDF("kuka_iiwa/model.urdf")
p.getNumJoints(kuka)
pybullet.addUserDebugLine([0,0,0],[0,0,0.1],[0,0,1],trackObjectUniqueId=2,trackLinkIndex=6)
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],trackObjectUniqueId=2,trackLinkIndex=6)
Also allow to render text using a given orientation (instead of pointing to the camera), example:
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],textOrientation=[0,0,0,1], trackObjectUniqueId=2,trackLinkIndex=6)
Add drawTexturedTriangleMesh, for drawing 3d text.
Expose readSingleInstanceTransformToCPU, to extract position/orientation from graphics index.
updateTexture: allow to not flip texels around up axis
2017-05-24 05:05:26 +00:00
PyObject * textOrientationObj = 0 ;
double textOrientation [ 4 ] ;
2018-09-23 21:17:31 +00:00
int parentObjectUniqueId = - 1 ;
int parentLinkIndex = - 1 ;
Improve debug text/line rendering, can be use to draw frames and text in local coordinate of an object / link.
example:
kuka = p.loadURDF("kuka_iiwa/model.urdf")
p.getNumJoints(kuka)
pybullet.addUserDebugLine([0,0,0],[0,0,0.1],[0,0,1],trackObjectUniqueId=2,trackLinkIndex=6)
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],trackObjectUniqueId=2,trackLinkIndex=6)
Also allow to render text using a given orientation (instead of pointing to the camera), example:
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],textOrientation=[0,0,0,1], trackObjectUniqueId=2,trackLinkIndex=6)
Add drawTexturedTriangleMesh, for drawing 3d text.
Expose readSingleInstanceTransformToCPU, to extract position/orientation from graphics index.
updateTexture: allow to not flip texels around up axis
2017-05-24 05:05:26 +00:00
2017-03-13 23:06:52 +00:00
double textSize = 1.f ;
double lifeTime = 0.f ;
int physicsClientId = 0 ;
2017-09-26 18:40:38 +00:00
int debugItemUniqueId = - 1 ;
2017-10-25 15:15:01 +00:00
int replaceItemUniqueId = - 1 ;
2017-09-26 18:40:38 +00:00
2017-03-13 23:06:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2017-10-25 15:15:01 +00:00
static char * kwlist [ ] = { " text " , " textPosition " , " textColorRGB " , " textSize " , " lifeTime " , " textOrientation " , " parentObjectUniqueId " , " parentLinkIndex " , " replaceItemUniqueId " , " physicsClientId " , NULL } ;
2017-03-13 23:06:52 +00:00
2017-10-25 15:15:01 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " sO|OddOiiii " , kwlist , & text , & textPositionObj , & textColorRGBObj , & textSize , & lifeTime , & textOrientationObj , & parentObjectUniqueId , & parentLinkIndex , & replaceItemUniqueId , & physicsClientId ) )
2017-03-13 23:06:52 +00:00
{
return NULL ;
}
2017-01-17 23:42:32 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
res = pybullet_internalSetVectord ( textPositionObj , posXYZ ) ;
if ( ! res )
2017-01-17 23:42:32 +00:00
{
2017-03-13 23:06:52 +00:00
PyErr_SetString ( SpamError , " Error converting textPositionObj[3] " ) ;
2017-01-17 23:42:32 +00:00
return NULL ;
}
2017-03-13 23:06:52 +00:00
if ( textColorRGBObj )
{
res = pybullet_internalSetVectord ( textColorRGBObj , colorRGB ) ;
if ( ! res )
{
PyErr_SetString ( SpamError , " Error converting textColorRGBObj[3] " ) ;
return NULL ;
}
}
commandHandle = b3InitUserDebugDrawAddText3D ( sm , text , posXYZ , colorRGB , textSize , lifeTime ) ;
2018-09-23 21:17:31 +00:00
if ( parentObjectUniqueId > = 0 )
Improve debug text/line rendering, can be use to draw frames and text in local coordinate of an object / link.
example:
kuka = p.loadURDF("kuka_iiwa/model.urdf")
p.getNumJoints(kuka)
pybullet.addUserDebugLine([0,0,0],[0,0,0.1],[0,0,1],trackObjectUniqueId=2,trackLinkIndex=6)
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],trackObjectUniqueId=2,trackLinkIndex=6)
Also allow to render text using a given orientation (instead of pointing to the camera), example:
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],textOrientation=[0,0,0,1], trackObjectUniqueId=2,trackLinkIndex=6)
Add drawTexturedTriangleMesh, for drawing 3d text.
Expose readSingleInstanceTransformToCPU, to extract position/orientation from graphics index.
updateTexture: allow to not flip texels around up axis
2017-05-24 05:05:26 +00:00
{
2018-09-23 21:17:31 +00:00
b3UserDebugItemSetParentObject ( commandHandle , parentObjectUniqueId , parentLinkIndex ) ;
Improve debug text/line rendering, can be use to draw frames and text in local coordinate of an object / link.
example:
kuka = p.loadURDF("kuka_iiwa/model.urdf")
p.getNumJoints(kuka)
pybullet.addUserDebugLine([0,0,0],[0,0,0.1],[0,0,1],trackObjectUniqueId=2,trackLinkIndex=6)
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],trackObjectUniqueId=2,trackLinkIndex=6)
Also allow to render text using a given orientation (instead of pointing to the camera), example:
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],textOrientation=[0,0,0,1], trackObjectUniqueId=2,trackLinkIndex=6)
Add drawTexturedTriangleMesh, for drawing 3d text.
Expose readSingleInstanceTransformToCPU, to extract position/orientation from graphics index.
updateTexture: allow to not flip texels around up axis
2017-05-24 05:05:26 +00:00
}
if ( textOrientationObj )
{
res = pybullet_internalSetVector4d ( textOrientationObj , textOrientation ) ;
if ( ! res )
{
PyErr_SetString ( SpamError , " Error converting textOrientation[4] " ) ;
return NULL ;
2018-09-23 21:17:31 +00:00
}
else
Improve debug text/line rendering, can be use to draw frames and text in local coordinate of an object / link.
example:
kuka = p.loadURDF("kuka_iiwa/model.urdf")
p.getNumJoints(kuka)
pybullet.addUserDebugLine([0,0,0],[0,0,0.1],[0,0,1],trackObjectUniqueId=2,trackLinkIndex=6)
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],trackObjectUniqueId=2,trackLinkIndex=6)
Also allow to render text using a given orientation (instead of pointing to the camera), example:
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],textOrientation=[0,0,0,1], trackObjectUniqueId=2,trackLinkIndex=6)
Add drawTexturedTriangleMesh, for drawing 3d text.
Expose readSingleInstanceTransformToCPU, to extract position/orientation from graphics index.
updateTexture: allow to not flip texels around up axis
2017-05-24 05:05:26 +00:00
{
2018-09-23 21:17:31 +00:00
b3UserDebugTextSetOrientation ( commandHandle , textOrientation ) ;
Improve debug text/line rendering, can be use to draw frames and text in local coordinate of an object / link.
example:
kuka = p.loadURDF("kuka_iiwa/model.urdf")
p.getNumJoints(kuka)
pybullet.addUserDebugLine([0,0,0],[0,0,0.1],[0,0,1],trackObjectUniqueId=2,trackLinkIndex=6)
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],trackObjectUniqueId=2,trackLinkIndex=6)
Also allow to render text using a given orientation (instead of pointing to the camera), example:
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],textOrientation=[0,0,0,1], trackObjectUniqueId=2,trackLinkIndex=6)
Add drawTexturedTriangleMesh, for drawing 3d text.
Expose readSingleInstanceTransformToCPU, to extract position/orientation from graphics index.
updateTexture: allow to not flip texels around up axis
2017-05-24 05:05:26 +00:00
}
}
2018-09-23 21:17:31 +00:00
if ( replaceItemUniqueId > = 0 )
2017-10-25 15:15:01 +00:00
{
2018-09-23 21:17:31 +00:00
b3UserDebugItemSetReplaceItemUniqueId ( commandHandle , replaceItemUniqueId ) ;
2017-10-25 15:15:01 +00:00
}
2017-03-13 23:06:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2018-09-11 20:24:35 +00:00
2017-03-13 23:06:52 +00:00
if ( statusType = = CMD_USER_DEBUG_DRAW_COMPLETED )
2017-01-17 23:42:32 +00:00
{
2017-09-26 18:40:38 +00:00
debugItemUniqueId = b3GetDebugItemUniqueId ( statusHandle ) ;
2017-01-17 23:42:32 +00:00
}
2017-09-27 02:58:24 +00:00
{
2018-09-23 21:17:31 +00:00
PyObject * item = PyInt_FromLong ( debugItemUniqueId ) ;
return item ;
2017-09-27 02:58:24 +00:00
}
2017-01-17 23:42:32 +00:00
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_addUserDebugLine ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-14 15:39:34 +00:00
{
2017-03-13 23:06:52 +00:00
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
int res = 0 ;
double fromXYZ [ 3 ] ;
double toXYZ [ 3 ] ;
double colorRGB [ 3 ] = { 1 , 1 , 1 } ;
2018-09-23 21:17:31 +00:00
int parentObjectUniqueId = - 1 ;
int parentLinkIndex = - 1 ;
2017-03-13 23:06:52 +00:00
PyObject * lineFromObj = 0 ;
PyObject * lineToObj = 0 ;
PyObject * lineColorRGBObj = 0 ;
double lineWidth = 1.f ;
double lifeTime = 0.f ;
int physicsClientId = 0 ;
2017-09-26 18:40:38 +00:00
int debugItemUniqueId = - 1 ;
2018-06-22 23:47:20 +00:00
int replaceItemUniqueId = - 1 ;
2017-03-13 23:06:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2018-06-22 23:47:20 +00:00
static char * kwlist [ ] = { " lineFromXYZ " , " lineToXYZ " , " lineColorRGB " , " lineWidth " , " lifeTime " , " parentObjectUniqueId " , " parentLinkIndex " , " replaceItemUniqueId " , " physicsClientId " , NULL } ;
2017-03-13 23:06:52 +00:00
2018-06-22 23:47:20 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " OO|Oddiiii " , kwlist , & lineFromObj , & lineToObj , & lineColorRGBObj , & lineWidth , & lifeTime , & parentObjectUniqueId , & parentLinkIndex , & replaceItemUniqueId , & physicsClientId ) )
2017-03-13 23:06:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
res = pybullet_internalSetVectord ( lineFromObj , fromXYZ ) ;
if ( ! res )
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
PyErr_SetString ( SpamError , " Error converting lineFrom[3] " ) ;
2016-12-28 04:25:52 +00:00
return NULL ;
}
2016-11-14 15:39:34 +00:00
2017-03-13 23:06:52 +00:00
res = pybullet_internalSetVectord ( lineToObj , toXYZ ) ;
if ( ! res )
{
PyErr_SetString ( SpamError , " Error converting lineTo[3] " ) ;
return NULL ;
}
if ( lineColorRGBObj )
{
res = pybullet_internalSetVectord ( lineColorRGBObj , colorRGB ) ;
}
2016-11-14 15:39:34 +00:00
2017-03-13 23:06:52 +00:00
commandHandle = b3InitUserDebugDrawAddLine3D ( sm , fromXYZ , toXYZ , colorRGB , lineWidth , lifeTime ) ;
2016-11-14 15:39:34 +00:00
2018-09-23 21:17:31 +00:00
if ( parentObjectUniqueId > = 0 )
Improve debug text/line rendering, can be use to draw frames and text in local coordinate of an object / link.
example:
kuka = p.loadURDF("kuka_iiwa/model.urdf")
p.getNumJoints(kuka)
pybullet.addUserDebugLine([0,0,0],[0,0,0.1],[0,0,1],trackObjectUniqueId=2,trackLinkIndex=6)
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],trackObjectUniqueId=2,trackLinkIndex=6)
Also allow to render text using a given orientation (instead of pointing to the camera), example:
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],textOrientation=[0,0,0,1], trackObjectUniqueId=2,trackLinkIndex=6)
Add drawTexturedTriangleMesh, for drawing 3d text.
Expose readSingleInstanceTransformToCPU, to extract position/orientation from graphics index.
updateTexture: allow to not flip texels around up axis
2017-05-24 05:05:26 +00:00
{
2018-09-23 21:17:31 +00:00
b3UserDebugItemSetParentObject ( commandHandle , parentObjectUniqueId , parentLinkIndex ) ;
Improve debug text/line rendering, can be use to draw frames and text in local coordinate of an object / link.
example:
kuka = p.loadURDF("kuka_iiwa/model.urdf")
p.getNumJoints(kuka)
pybullet.addUserDebugLine([0,0,0],[0,0,0.1],[0,0,1],trackObjectUniqueId=2,trackLinkIndex=6)
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],trackObjectUniqueId=2,trackLinkIndex=6)
Also allow to render text using a given orientation (instead of pointing to the camera), example:
pybullet.addUserDebugText("tip", [0,0,0.1],textColorRGB=[1,0,0],textOrientation=[0,0,0,1], trackObjectUniqueId=2,trackLinkIndex=6)
Add drawTexturedTriangleMesh, for drawing 3d text.
Expose readSingleInstanceTransformToCPU, to extract position/orientation from graphics index.
updateTexture: allow to not flip texels around up axis
2017-05-24 05:05:26 +00:00
}
2018-09-23 21:17:31 +00:00
if ( replaceItemUniqueId > = 0 )
2018-06-22 23:47:20 +00:00
{
2018-09-23 21:17:31 +00:00
b3UserDebugItemSetReplaceItemUniqueId ( commandHandle , replaceItemUniqueId ) ;
2018-06-22 23:47:20 +00:00
}
2017-03-13 23:06:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_USER_DEBUG_DRAW_COMPLETED )
{
2017-09-26 18:40:38 +00:00
debugItemUniqueId = b3GetDebugItemUniqueId ( statusHandle ) ;
2017-03-13 23:06:52 +00:00
}
2017-09-27 02:58:24 +00:00
{
2018-09-23 21:17:31 +00:00
PyObject * item = PyInt_FromLong ( debugItemUniqueId ) ;
return item ;
2017-03-13 23:06:52 +00:00
}
}
2016-11-14 15:39:34 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_removeUserDebugItem ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-14 15:39:34 +00:00
{
2017-03-13 23:06:52 +00:00
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
int itemUniqueId ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2016-12-28 04:25:52 +00:00
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " itemUniqueId " , " physicsClientId " , NULL } ;
2016-12-28 04:25:52 +00:00
2017-03-13 23:06:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & itemUniqueId , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-11-14 15:39:34 +00:00
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-11-14 15:39:34 +00:00
2017-03-13 23:06:52 +00:00
commandHandle = b3InitUserDebugDrawRemove ( sm , itemUniqueId ) ;
2016-11-14 15:39:34 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_removeAllUserDebugItems ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-14 15:39:34 +00:00
{
2017-03-13 23:06:52 +00:00
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-11-14 15:39:34 +00:00
commandHandle = b3InitUserDebugDrawRemoveAll ( sm ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_startStateLogging ( PyObject * self , PyObject * args , PyObject * keywds )
2017-02-17 18:47:55 +00:00
{
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
b3PhysicsClientHandle sm = 0 ;
int loggingType = - 1 ;
char * fileName = 0 ;
PyObject * objectUniqueIdsObj = 0 ;
2017-03-13 23:06:52 +00:00
int maxLogDof = - 1 ;
2017-04-04 17:38:25 +00:00
int bodyUniqueIdA = - 1 ;
int bodyUniqueIdB = - 1 ;
2017-04-02 23:03:20 +00:00
int linkIndexA = - 2 ;
int linkIndexB = - 2 ;
2017-04-08 18:48:12 +00:00
int deviceTypeFilter = - 1 ;
2017-08-31 02:41:15 +00:00
int logFlags = - 1 ;
2017-02-17 18:47:55 +00:00
2017-08-31 02:41:15 +00:00
static char * kwlist [ ] = { " loggingType " , " fileName " , " objectUniqueIds " , " maxLogDof " , " bodyUniqueIdA " , " bodyUniqueIdB " , " linkIndexA " , " linkIndexB " , " deviceTypeFilter " , " logFlags " , " physicsClientId " , NULL } ;
2017-02-17 18:47:55 +00:00
int physicsClientId = 0 ;
2017-03-13 23:06:52 +00:00
2017-08-31 02:41:15 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " is|Oiiiiiiii " , kwlist ,
& loggingType , & fileName , & objectUniqueIdsObj , & maxLogDof , & bodyUniqueIdA , & bodyUniqueIdB , & linkIndexA , & linkIndexB , & deviceTypeFilter , & logFlags , & physicsClientId ) )
2017-02-17 18:47:55 +00:00
return NULL ;
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2017-02-17 18:47:55 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-02-17 22:25:53 +00:00
{
b3SharedMemoryCommandHandle commandHandle ;
commandHandle = b3StateLoggingCommandInit ( sm ) ;
2017-03-13 23:06:52 +00:00
b3StateLoggingStart ( commandHandle , loggingType , fileName ) ;
2017-02-17 22:25:53 +00:00
if ( objectUniqueIdsObj )
{
PyObject * seq = PySequence_Fast ( objectUniqueIdsObj , " expected a sequence of object unique ids " ) ;
if ( seq )
{
int len = PySequence_Size ( objectUniqueIdsObj ) ;
2017-02-17 23:15:13 +00:00
int i ;
2017-03-13 23:06:52 +00:00
for ( i = 0 ; i < len ; i + + )
2017-02-17 22:25:53 +00:00
{
int objectUid = pybullet_internalGetFloatFromSequence ( seq , i ) ;
2017-03-13 23:06:52 +00:00
b3StateLoggingAddLoggingObjectUniqueId ( commandHandle , objectUid ) ;
2017-02-17 22:25:53 +00:00
}
Py_DECREF ( seq ) ;
}
}
2017-03-13 23:06:52 +00:00
if ( maxLogDof > 0 )
2017-03-04 23:30:57 +00:00
{
b3StateLoggingSetMaxLogDof ( commandHandle , maxLogDof ) ;
}
2018-09-11 20:24:35 +00:00
2017-04-04 17:38:25 +00:00
if ( bodyUniqueIdA > - 1 )
2017-04-02 23:03:20 +00:00
{
2017-04-04 17:38:25 +00:00
b3StateLoggingSetBodyAUniqueId ( commandHandle , bodyUniqueIdA ) ;
2017-04-02 23:03:20 +00:00
}
2017-04-04 17:38:25 +00:00
if ( bodyUniqueIdB > - 1 )
2017-04-02 23:03:20 +00:00
{
2017-04-04 17:38:25 +00:00
b3StateLoggingSetBodyBUniqueId ( commandHandle , bodyUniqueIdB ) ;
2017-04-02 23:03:20 +00:00
}
if ( linkIndexA > - 2 )
{
b3StateLoggingSetLinkIndexA ( commandHandle , linkIndexA ) ;
}
if ( linkIndexB > - 2 )
{
b3StateLoggingSetLinkIndexB ( commandHandle , linkIndexB ) ;
}
2017-03-13 23:06:52 +00:00
2018-09-23 21:17:31 +00:00
if ( deviceTypeFilter > = 0 )
2017-04-08 18:48:12 +00:00
{
2018-09-23 21:17:31 +00:00
b3StateLoggingSetDeviceTypeFilter ( commandHandle , deviceTypeFilter ) ;
2017-04-08 18:48:12 +00:00
}
2018-09-23 21:17:31 +00:00
if ( logFlags > 0 )
2017-08-31 02:41:15 +00:00
{
b3StateLoggingSetLogFlags ( commandHandle , logFlags ) ;
}
2017-02-17 22:25:53 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2017-03-13 23:06:52 +00:00
if ( statusType = = CMD_STATE_LOGGING_START_COMPLETED )
2017-02-17 22:25:53 +00:00
{
int loggingUniqueId = b3GetStatusLoggingUniqueId ( statusHandle ) ;
PyObject * loggingUidObj = PyInt_FromLong ( loggingUniqueId ) ;
return loggingUidObj ;
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2017-02-17 18:47:55 +00:00
}
2017-05-05 00:51:40 +00:00
static PyObject * pybullet_submitProfileTiming ( PyObject * self , PyObject * args , PyObject * keywds )
{
2018-09-23 21:17:31 +00:00
// b3SharedMemoryStatusHandle statusHandle;
// int statusType;
2017-05-05 00:51:40 +00:00
char * eventName = 0 ;
2018-09-23 21:17:31 +00:00
int duractionInMicroSeconds = - 1 ;
2017-05-05 00:51:40 +00:00
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " eventName " , " duraction " , " physicsClientId " , NULL } ;
int physicsClientId = 0 ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|ii " , kwlist ,
& eventName , & duractionInMicroSeconds , & physicsClientId ) )
return NULL ;
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
if ( eventName )
{
b3SharedMemoryCommandHandle commandHandle ;
commandHandle = b3ProfileTimingCommandInit ( sm , eventName ) ;
2018-09-23 21:17:31 +00:00
if ( duractionInMicroSeconds > = 0 )
2017-05-05 00:51:40 +00:00
{
b3SetProfileTimingDuractionInMicroSeconds ( commandHandle , duractionInMicroSeconds ) ;
}
b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_stopStateLogging ( PyObject * self , PyObject * args , PyObject * keywds )
2017-02-17 18:47:55 +00:00
{
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2017-03-13 23:06:52 +00:00
int loggingId = - 1 ;
2017-02-17 22:25:53 +00:00
2017-02-17 18:47:55 +00:00
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " loggingId " , " physicsClientId " , NULL } ;
int physicsClientId = 0 ;
2017-02-17 22:25:53 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist ,
2017-03-13 23:06:52 +00:00
& loggingId , & physicsClientId ) )
2017-02-17 18:47:55 +00:00
return NULL ;
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2017-02-17 18:47:55 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
if ( loggingId > = 0 )
2017-02-17 22:25:53 +00:00
{
b3SharedMemoryCommandHandle commandHandle ;
commandHandle = b3StateLoggingCommandInit ( sm ) ;
b3StateLoggingStop ( commandHandle , loggingId ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2017-02-17 18:47:55 +00:00
}
2017-08-28 02:34:00 +00:00
static PyObject * pybullet_setAdditionalSearchPath ( PyObject * self , PyObject * args , PyObject * keywds )
{
static char * kwlist [ ] = { " path " , " physicsClientId " , NULL } ;
char * path = 0 ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|i " , kwlist ,
& path , & physicsClientId ) )
return NULL ;
if ( path )
{
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
commandHandle = b3SetAdditionalSearchPath ( sm , path ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_setTimeOut ( PyObject * self , PyObject * args , PyObject * keywds )
2017-02-24 23:34:11 +00:00
{
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " timeOutInSeconds " , " physicsClientId " , NULL } ;
2017-02-24 23:34:11 +00:00
double timeOutInSeconds = - 1 ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " d|i " , kwlist ,
2017-03-13 23:06:52 +00:00
& timeOutInSeconds , & physicsClientId ) )
2017-02-24 23:34:11 +00:00
return NULL ;
2017-03-13 23:06:52 +00:00
if ( timeOutInSeconds > = 0 )
2017-02-24 23:34:11 +00:00
{
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2017-02-24 23:34:11 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
b3SetTimeOut ( sm , timeOutInSeconds ) ;
2017-02-24 23:34:11 +00:00
}
2017-02-17 18:47:55 +00:00
2017-02-24 23:34:11 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2016-12-27 03:40:09 +00:00
2017-04-05 22:21:26 +00:00
static PyObject * pybullet_rayTestObsolete ( PyObject * self , PyObject * args , PyObject * keywds )
2016-12-27 03:40:09 +00:00
{
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2017-03-13 23:06:52 +00:00
PyObject * rayFromObj = 0 ;
PyObject * rayToObj = 0 ;
2016-12-27 03:40:09 +00:00
double from [ 3 ] ;
double to [ 3 ] ;
2016-12-28 04:25:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " rayFromPosition " , " rayToPosition " , " physicsClientId " , NULL } ;
int physicsClientId = 0 ;
2016-12-28 04:25:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " OO|i " , kwlist ,
2017-03-13 23:06:52 +00:00
& rayFromObj , & rayToObj , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
return NULL ;
2016-12-27 03:40:09 +00:00
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
2016-12-27 03:40:09 +00:00
return NULL ;
2016-12-28 04:25:52 +00:00
}
2016-12-27 03:40:09 +00:00
2017-03-13 23:06:52 +00:00
pybullet_internalSetVectord ( rayFromObj , from ) ;
pybullet_internalSetVectord ( rayToObj , to ) ;
2016-12-27 03:40:09 +00:00
2017-03-13 23:06:52 +00:00
commandHandle = b3CreateRaycastCommandInit ( sm , from [ 0 ] , from [ 1 ] , from [ 2 ] ,
to [ 0 ] , to [ 1 ] , to [ 2 ] ) ;
2016-12-27 03:40:09 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2017-03-13 23:06:52 +00:00
if ( statusType = = CMD_REQUEST_RAY_CAST_INTERSECTIONS_COMPLETED )
2016-12-27 03:40:09 +00:00
{
struct b3RaycastInformation raycastInfo ;
PyObject * rayHitsObj = 0 ;
int i ;
b3GetRaycastInformation ( sm , & raycastInfo ) ;
2017-03-13 23:06:52 +00:00
2016-12-27 03:40:09 +00:00
rayHitsObj = PyTuple_New ( raycastInfo . m_numRayHits ) ;
2017-03-13 23:06:52 +00:00
for ( i = 0 ; i < raycastInfo . m_numRayHits ; i + + )
2016-12-27 03:40:09 +00:00
{
2017-03-13 23:06:52 +00:00
PyObject * singleHitObj = PyTuple_New ( 5 ) ;
2016-12-27 03:40:09 +00:00
{
PyObject * ob = PyInt_FromLong ( raycastInfo . m_rayHits [ i ] . m_hitObjectUniqueId ) ;
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( singleHitObj , 0 , ob ) ;
2016-12-27 03:40:09 +00:00
}
{
PyObject * ob = PyInt_FromLong ( raycastInfo . m_rayHits [ i ] . m_hitObjectLinkIndex ) ;
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( singleHitObj , 1 , ob ) ;
2016-12-27 03:40:09 +00:00
}
{
PyObject * ob = PyFloat_FromDouble ( raycastInfo . m_rayHits [ i ] . m_hitFraction ) ;
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( singleHitObj , 2 , ob ) ;
2016-12-27 03:40:09 +00:00
}
{
2017-03-13 23:06:52 +00:00
PyObject * posObj = PyTuple_New ( 3 ) ;
2016-12-27 03:40:09 +00:00
int p ;
2017-03-13 23:06:52 +00:00
for ( p = 0 ; p < 3 ; p + + )
2016-12-27 03:40:09 +00:00
{
PyObject * ob = PyFloat_FromDouble ( raycastInfo . m_rayHits [ i ] . m_hitPositionWorld [ p ] ) ;
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( posObj , p , ob ) ;
2016-12-27 03:40:09 +00:00
}
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( singleHitObj , 3 , posObj ) ;
2016-12-27 03:40:09 +00:00
}
{
2017-03-13 23:06:52 +00:00
PyObject * normalObj = PyTuple_New ( 3 ) ;
2016-12-27 03:40:09 +00:00
int p ;
2017-03-13 23:06:52 +00:00
for ( p = 0 ; p < 3 ; p + + )
2016-12-27 03:40:09 +00:00
{
PyObject * ob = PyFloat_FromDouble ( raycastInfo . m_rayHits [ i ] . m_hitNormalWorld [ p ] ) ;
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( normalObj , p , ob ) ;
2016-12-27 03:40:09 +00:00
}
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( singleHitObj , 4 , normalObj ) ;
2016-12-27 03:40:09 +00:00
}
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( rayHitsObj , i , singleHitObj ) ;
2016-12-27 03:40:09 +00:00
}
return rayHitsObj ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-04-05 22:21:26 +00:00
static PyObject * pybullet_rayTestBatch ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
PyObject * rayFromObjList = 0 ;
PyObject * rayToObjList = 0 ;
2018-06-15 14:47:04 +00:00
int numThreads = 1 ;
2017-04-05 22:21:26 +00:00
b3PhysicsClientHandle sm = 0 ;
int sizeFrom = 0 ;
int sizeTo = 0 ;
2018-10-11 06:31:50 +00:00
int parentObjectUniqueId = - 1 ;
int parentLinkIndex = - 1 ;
static char * kwlist [ ] = { " rayFromPositions " , " rayToPositions " , " numThreads " , " parentObjectUniqueId " , " parentLinkIndex " , " physicsClientId " , NULL } ;
2017-04-05 22:21:26 +00:00
int physicsClientId = 0 ;
2018-10-11 06:31:50 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " OO|iiii " , kwlist ,
& rayFromObjList , & rayToObjList , & numThreads , & parentObjectUniqueId , & parentLinkIndex , & physicsClientId ) )
2017-04-05 22:21:26 +00:00
return NULL ;
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
commandHandle = b3CreateRaycastBatchCommandInit ( sm ) ;
2018-06-15 14:47:04 +00:00
b3RaycastBatchSetNumThreads ( commandHandle , numThreads ) ;
2017-04-05 22:21:26 +00:00
if ( rayFromObjList )
{
PyObject * seqRayFromObj = PySequence_Fast ( rayFromObjList , " expected a sequence of rayFrom positions " ) ;
PyObject * seqRayToObj = PySequence_Fast ( rayToObjList , " expected a sequence of 'rayTo' positions " ) ;
if ( seqRayFromObj & & seqRayToObj )
{
int lenFrom = PySequence_Size ( rayFromObjList ) ;
2018-09-23 21:17:31 +00:00
int lenTo = PySequence_Size ( seqRayToObj ) ;
if ( lenFrom ! = lenTo )
2017-04-05 22:21:26 +00:00
{
2018-09-23 21:17:31 +00:00
PyErr_SetString ( SpamError , " Size of from_positions need to be equal to size of to_positions. " ) ;
Py_DECREF ( seqRayFromObj ) ;
Py_DECREF ( seqRayToObj ) ;
return NULL ;
}
else
2017-04-05 22:21:26 +00:00
{
int i ;
2018-09-11 20:24:35 +00:00
2018-06-16 19:28:21 +00:00
if ( lenFrom > MAX_RAY_INTERSECTION_BATCH_SIZE_STREAMING )
2017-04-05 22:21:26 +00:00
{
PyErr_SetString ( SpamError , " Number of rays exceed the maximum batch size. " ) ;
Py_DECREF ( seqRayFromObj ) ;
Py_DECREF ( seqRayToObj ) ;
return NULL ;
}
2018-06-16 13:19:49 +00:00
b3PushProfileTiming ( sm , " extractPythonFromToSequenceToC " ) ;
2017-04-05 22:21:26 +00:00
for ( i = 0 ; i < lenFrom ; i + + )
{
2018-09-23 21:17:31 +00:00
PyObject * rayFromObj = PySequence_GetItem ( rayFromObjList , i ) ;
PyObject * rayToObj = PySequence_GetItem ( seqRayToObj , i ) ;
2017-04-05 22:21:26 +00:00
double rayFromWorld [ 3 ] ;
double rayToWorld [ 3 ] ;
2018-09-11 20:24:35 +00:00
2017-04-05 22:21:26 +00:00
if ( ( pybullet_internalSetVectord ( rayFromObj , rayFromWorld ) ) & &
( pybullet_internalSetVectord ( rayToObj , rayToWorld ) ) )
{
2018-06-16 19:28:21 +00:00
//todo: better to upload all rays at once
2018-09-11 20:24:35 +00:00
//b3RaycastBatchAddRay(commandHandle, rayFromWorld, rayToWorld);
2018-09-23 21:17:31 +00:00
b3RaycastBatchAddRays ( sm , commandHandle , rayFromWorld , rayToWorld , 1 ) ;
}
else
2017-04-05 22:21:26 +00:00
{
PyErr_SetString ( SpamError , " Items in the from/to positions need to be an [x,y,z] list of 3 floats/doubles " ) ;
Py_DECREF ( seqRayFromObj ) ;
Py_DECREF ( seqRayToObj ) ;
Py_DECREF ( rayFromObj ) ;
Py_DECREF ( rayToObj ) ;
2018-06-16 13:19:49 +00:00
b3PopProfileTiming ( sm ) ;
2017-04-05 22:21:26 +00:00
return NULL ;
}
Py_DECREF ( rayFromObj ) ;
Py_DECREF ( rayToObj ) ;
}
2018-06-16 13:19:49 +00:00
b3PopProfileTiming ( sm ) ;
2017-04-05 22:21:26 +00:00
}
2018-09-23 21:17:31 +00:00
}
else
2017-04-05 22:21:26 +00:00
{
}
if ( seqRayFromObj )
{
Py_DECREF ( seqRayFromObj ) ;
}
if ( seqRayToObj )
{
Py_DECREF ( seqRayToObj ) ;
}
}
2018-10-11 06:31:50 +00:00
if ( parentObjectUniqueId > = 0 )
{
b3RaycastBatchSetParentObject ( commandHandle , parentObjectUniqueId , parentLinkIndex ) ;
}
2017-04-05 22:21:26 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_REQUEST_RAY_CAST_INTERSECTIONS_COMPLETED )
{
struct b3RaycastInformation raycastInfo ;
PyObject * rayHitsObj = 0 ;
int i ;
2018-06-16 13:19:49 +00:00
b3PushProfileTiming ( sm , " convertRaycastInformationToPython " ) ;
2017-04-05 22:21:26 +00:00
b3GetRaycastInformation ( sm , & raycastInfo ) ;
2018-09-11 20:24:35 +00:00
2017-04-05 22:21:26 +00:00
rayHitsObj = PyTuple_New ( raycastInfo . m_numRayHits ) ;
for ( i = 0 ; i < raycastInfo . m_numRayHits ; i + + )
{
PyObject * singleHitObj = PyTuple_New ( 5 ) ;
{
PyObject * ob = PyInt_FromLong ( raycastInfo . m_rayHits [ i ] . m_hitObjectUniqueId ) ;
PyTuple_SetItem ( singleHitObj , 0 , ob ) ;
}
{
PyObject * ob = PyInt_FromLong ( raycastInfo . m_rayHits [ i ] . m_hitObjectLinkIndex ) ;
PyTuple_SetItem ( singleHitObj , 1 , ob ) ;
}
{
PyObject * ob = PyFloat_FromDouble ( raycastInfo . m_rayHits [ i ] . m_hitFraction ) ;
PyTuple_SetItem ( singleHitObj , 2 , ob ) ;
}
{
PyObject * posObj = PyTuple_New ( 3 ) ;
int p ;
for ( p = 0 ; p < 3 ; p + + )
{
PyObject * ob = PyFloat_FromDouble ( raycastInfo . m_rayHits [ i ] . m_hitPositionWorld [ p ] ) ;
PyTuple_SetItem ( posObj , p , ob ) ;
}
PyTuple_SetItem ( singleHitObj , 3 , posObj ) ;
}
{
PyObject * normalObj = PyTuple_New ( 3 ) ;
int p ;
for ( p = 0 ; p < 3 ; p + + )
{
PyObject * ob = PyFloat_FromDouble ( raycastInfo . m_rayHits [ i ] . m_hitNormalWorld [ p ] ) ;
PyTuple_SetItem ( normalObj , p , ob ) ;
}
PyTuple_SetItem ( singleHitObj , 4 , normalObj ) ;
}
PyTuple_SetItem ( rayHitsObj , i , singleHitObj ) ;
}
2018-06-16 13:19:49 +00:00
b3PopProfileTiming ( sm ) ;
2017-04-05 22:21:26 +00:00
return rayHitsObj ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-08-28 01:08:46 +00:00
static PyObject * pybullet_getMatrixFromQuaternion ( PyObject * self , PyObject * args , PyObject * keywds )
2016-12-27 03:40:09 +00:00
{
PyObject * quatObj ;
double quat [ 4 ] ;
2018-09-23 21:17:31 +00:00
int physicsClientId = 0 ;
static char * kwlist [ ] = { " quaternion " , " physicsClientId " , NULL } ;
2017-08-28 01:08:46 +00:00
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " O|i " , kwlist , & quatObj , & physicsClientId ) )
2017-08-28 01:08:46 +00:00
{
return NULL ;
}
if ( quatObj )
2016-12-27 03:40:09 +00:00
{
2017-03-13 23:06:52 +00:00
if ( pybullet_internalSetVector4d ( quatObj , quat ) )
2016-12-27 03:40:09 +00:00
{
///see btMatrix3x3::setRotation
int i ;
2017-03-13 23:06:52 +00:00
double d = quat [ 0 ] * quat [ 0 ] + quat [ 1 ] * quat [ 1 ] + quat [ 2 ] * quat [ 2 ] + quat [ 3 ] * quat [ 3 ] ;
2016-12-27 03:40:09 +00:00
double s = 2.0 / d ;
2017-03-13 23:06:52 +00:00
double xs = quat [ 0 ] * s , ys = quat [ 1 ] * s , zs = quat [ 2 ] * s ;
double wx = quat [ 3 ] * xs , wy = quat [ 3 ] * ys , wz = quat [ 3 ] * zs ;
double xx = quat [ 0 ] * xs , xy = quat [ 0 ] * ys , xz = quat [ 0 ] * zs ;
double yy = quat [ 1 ] * ys , yz = quat [ 1 ] * zs , zz = quat [ 2 ] * zs ;
2016-12-27 03:40:09 +00:00
double mat3x3 [ 9 ] = {
1.0 - ( yy + zz ) , xy - wz , xz + wy ,
xy + wz , 1.0 - ( xx + zz ) , yz - wx ,
xz - wy , yz + wx , 1.0 - ( xx + yy ) } ;
PyObject * matObj = PyTuple_New ( 9 ) ;
2017-03-13 23:06:52 +00:00
for ( i = 0 ; i < 9 ; i + + )
2016-12-27 03:40:09 +00:00
{
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( matObj , i , PyFloat_FromDouble ( mat3x3 [ i ] ) ) ;
2016-12-27 03:40:09 +00:00
}
return matObj ;
}
}
PyErr_SetString ( SpamError , " Couldn't convert quaternion [x,y,z,w]. " ) ;
return NULL ;
} ;
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_setVRCameraState ( PyObject * self , PyObject * args , PyObject * keywds )
2017-01-06 01:41:58 +00:00
{
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
PyObject * rootPosObj = 0 ;
PyObject * rootOrnObj = 0 ;
int trackObjectUid = - 2 ;
2017-05-18 02:29:12 +00:00
int trackObjectFlag = - 1 ;
2017-01-06 01:41:58 +00:00
double rootPos [ 3 ] ;
double rootOrn [ 4 ] ;
2017-03-13 23:06:52 +00:00
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " rootPosition " , " rootOrientation " , " trackObject " , " trackObjectFlag " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |OOiii " , kwlist , & rootPosObj , & rootOrnObj , & trackObjectUid , & trackObjectFlag , & physicsClientId ) )
2017-01-06 01:41:58 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2017-01-06 01:41:58 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
commandHandle = b3SetVRCameraStateCommandInit ( sm ) ;
2017-03-13 23:06:52 +00:00
if ( pybullet_internalSetVectord ( rootPosObj , rootPos ) )
2017-01-06 01:41:58 +00:00
{
2017-03-13 23:06:52 +00:00
b3SetVRCameraRootPosition ( commandHandle , rootPos ) ;
2017-01-06 01:41:58 +00:00
}
2017-03-13 23:06:52 +00:00
if ( pybullet_internalSetVector4d ( rootOrnObj , rootOrn ) )
2017-01-06 01:41:58 +00:00
{
2017-03-13 23:06:52 +00:00
b3SetVRCameraRootOrientation ( commandHandle , rootOrn ) ;
2017-01-06 01:41:58 +00:00
}
2017-03-13 23:06:52 +00:00
if ( trackObjectUid > = - 1 )
2017-01-06 01:41:58 +00:00
{
2017-03-13 23:06:52 +00:00
b3SetVRCameraTrackingObject ( commandHandle , trackObjectUid ) ;
2017-01-06 01:41:58 +00:00
}
2018-09-23 21:17:31 +00:00
if ( trackObjectFlag > = - 1 )
2017-05-18 02:29:12 +00:00
{
b3SetVRCameraTrackingObjectFlag ( commandHandle , trackObjectFlag ) ;
}
2017-01-06 01:41:58 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getKeyboardEvents ( PyObject * self , PyObject * args , PyObject * keywds )
2017-03-02 20:33:22 +00:00
{
b3SharedMemoryCommandHandle commandHandle ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
struct b3KeyboardEventsData keyboardEventsData ;
PyObject * keyEventsObj = 0 ;
2017-03-13 23:06:52 +00:00
int i = 0 ;
2017-03-02 20:33:22 +00:00
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
2017-03-02 20:33:22 +00:00
{
return NULL ;
}
2017-03-13 23:06:52 +00:00
2017-03-02 20:33:22 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2017-03-02 20:33:22 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
commandHandle = b3RequestKeyboardEventsCommandInit ( sm ) ;
b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
2017-03-13 23:06:52 +00:00
b3GetKeyboardEventsData ( sm , & keyboardEventsData ) ;
2017-03-02 20:33:22 +00:00
keyEventsObj = PyDict_New ( ) ;
2017-03-13 23:06:52 +00:00
for ( i = 0 ; i < keyboardEventsData . m_numKeyboardEvents ; i + + )
2017-03-02 20:33:22 +00:00
{
PyObject * keyObj = PyLong_FromLong ( keyboardEventsData . m_keyboardEvents [ i ] . m_keyCode ) ;
PyObject * valObj = PyLong_FromLong ( keyboardEventsData . m_keyboardEvents [ i ] . m_keyState ) ;
PyDict_SetItem ( keyEventsObj , keyObj , valObj ) ;
}
return keyEventsObj ;
}
2017-01-06 01:41:58 +00:00
2017-06-17 20:29:14 +00:00
static PyObject * pybullet_getMouseEvents ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3SharedMemoryCommandHandle commandHandle ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
struct b3MouseEventsData mouseEventsData ;
PyObject * mouseEventsObj = 0 ;
int i = 0 ;
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
commandHandle = b3RequestMouseEventsCommandInit ( sm ) ;
b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
b3GetMouseEventsData ( sm , & mouseEventsData ) ;
mouseEventsObj = PyTuple_New ( mouseEventsData . m_numMouseEvents ) ;
for ( i = 0 ; i < mouseEventsData . m_numMouseEvents ; i + + )
{
PyObject * mouseEventObj = PyTuple_New ( 5 ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( mouseEventObj , 0 , PyInt_FromLong ( mouseEventsData . m_mouseEvents [ i ] . m_eventType ) ) ;
PyTuple_SetItem ( mouseEventObj , 1 , PyFloat_FromDouble ( mouseEventsData . m_mouseEvents [ i ] . m_mousePosX ) ) ;
PyTuple_SetItem ( mouseEventObj , 2 , PyFloat_FromDouble ( mouseEventsData . m_mouseEvents [ i ] . m_mousePosY ) ) ;
PyTuple_SetItem ( mouseEventObj , 3 , PyInt_FromLong ( mouseEventsData . m_mouseEvents [ i ] . m_buttonIndex ) ) ;
PyTuple_SetItem ( mouseEventObj , 4 , PyInt_FromLong ( mouseEventsData . m_mouseEvents [ i ] . m_buttonState ) ) ;
PyTuple_SetItem ( mouseEventsObj , i , mouseEventObj ) ;
2017-06-17 20:29:14 +00:00
}
return mouseEventsObj ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getVREvents ( PyObject * self , PyObject * args , PyObject * keywds )
2016-12-27 03:40:09 +00:00
{
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2017-04-08 05:53:36 +00:00
int deviceTypeFilter = VR_DEVICE_CONTROLLER ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
2017-10-05 19:59:58 +00:00
int allAnalogAxes = 0 ;
2016-12-28 04:25:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2017-10-05 19:59:58 +00:00
static char * kwlist [ ] = { " deviceTypeFilter " , " allAnalogAxes " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |iii " , kwlist , & deviceTypeFilter , & allAnalogAxes , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2017-03-13 23:06:52 +00:00
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-12-27 03:40:09 +00:00
commandHandle = b3RequestVREventsCommandInit ( sm ) ;
2017-04-08 05:53:36 +00:00
b3VREventsSetDeviceTypeFilter ( commandHandle , deviceTypeFilter ) ;
2016-12-27 03:40:09 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2017-03-13 23:06:52 +00:00
if ( statusType = = CMD_REQUEST_VR_EVENTS_DATA_COMPLETED )
2016-12-27 03:40:09 +00:00
{
struct b3VREventsData vrEvents ;
PyObject * vrEventsObj ;
2017-03-13 23:06:52 +00:00
int i = 0 ;
b3GetVREventsData ( sm , & vrEvents ) ;
2016-12-27 03:40:09 +00:00
vrEventsObj = PyTuple_New ( vrEvents . m_numControllerEvents ) ;
2017-03-13 23:06:52 +00:00
for ( i = 0 ; i < vrEvents . m_numControllerEvents ; i + + )
2016-12-27 03:40:09 +00:00
{
2018-09-23 21:17:31 +00:00
int numFields = allAnalogAxes ? 9 : 8 ;
2017-10-05 19:59:58 +00:00
PyObject * vrEventObj = PyTuple_New ( numFields ) ;
2016-12-27 03:40:09 +00:00
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( vrEventObj , 0 , PyInt_FromLong ( vrEvents . m_controllerEvents [ i ] . m_controllerId ) ) ;
2016-12-27 03:40:09 +00:00
{
PyObject * posObj = PyTuple_New ( 3 ) ;
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( posObj , 0 , PyFloat_FromDouble ( vrEvents . m_controllerEvents [ i ] . m_pos [ 0 ] ) ) ;
PyTuple_SetItem ( posObj , 1 , PyFloat_FromDouble ( vrEvents . m_controllerEvents [ i ] . m_pos [ 1 ] ) ) ;
PyTuple_SetItem ( posObj , 2 , PyFloat_FromDouble ( vrEvents . m_controllerEvents [ i ] . m_pos [ 2 ] ) ) ;
PyTuple_SetItem ( vrEventObj , 1 , posObj ) ;
2016-12-27 03:40:09 +00:00
}
{
PyObject * ornObj = PyTuple_New ( 4 ) ;
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( ornObj , 0 , PyFloat_FromDouble ( vrEvents . m_controllerEvents [ i ] . m_orn [ 0 ] ) ) ;
PyTuple_SetItem ( ornObj , 1 , PyFloat_FromDouble ( vrEvents . m_controllerEvents [ i ] . m_orn [ 1 ] ) ) ;
PyTuple_SetItem ( ornObj , 2 , PyFloat_FromDouble ( vrEvents . m_controllerEvents [ i ] . m_orn [ 2 ] ) ) ;
PyTuple_SetItem ( ornObj , 3 , PyFloat_FromDouble ( vrEvents . m_controllerEvents [ i ] . m_orn [ 3 ] ) ) ;
PyTuple_SetItem ( vrEventObj , 2 , ornObj ) ;
2016-12-27 03:40:09 +00:00
}
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( vrEventObj , 3 , PyFloat_FromDouble ( vrEvents . m_controllerEvents [ i ] . m_analogAxis ) ) ;
PyTuple_SetItem ( vrEventObj , 4 , PyInt_FromLong ( vrEvents . m_controllerEvents [ i ] . m_numButtonEvents ) ) ;
PyTuple_SetItem ( vrEventObj , 5 , PyInt_FromLong ( vrEvents . m_controllerEvents [ i ] . m_numMoveEvents ) ) ;
2016-12-27 03:40:09 +00:00
{
PyObject * buttonsObj = PyTuple_New ( MAX_VR_BUTTONS ) ;
int b ;
2017-03-13 23:06:52 +00:00
for ( b = 0 ; b < MAX_VR_BUTTONS ; b + + )
2016-12-27 03:40:09 +00:00
{
PyObject * button = PyInt_FromLong ( vrEvents . m_controllerEvents [ i ] . m_buttons [ b ] ) ;
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( buttonsObj , b , button ) ;
2016-12-27 03:40:09 +00:00
}
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( vrEventObj , 6 , buttonsObj ) ;
2016-12-27 03:40:09 +00:00
}
2017-04-08 05:53:36 +00:00
PyTuple_SetItem ( vrEventObj , 7 , PyInt_FromLong ( vrEvents . m_controllerEvents [ i ] . m_deviceType ) ) ;
2017-10-05 19:59:58 +00:00
if ( allAnalogAxes )
{
2018-09-23 21:17:31 +00:00
PyObject * buttonsObj = PyTuple_New ( MAX_VR_ANALOG_AXIS * 2 ) ;
2017-10-05 19:59:58 +00:00
int b ;
2018-09-23 21:17:31 +00:00
for ( b = 0 ; b < MAX_VR_ANALOG_AXIS * 2 ; b + + )
2017-10-05 19:59:58 +00:00
{
PyObject * axisVal = PyFloat_FromDouble ( vrEvents . m_controllerEvents [ i ] . m_auxAnalogAxis [ b ] ) ;
PyTuple_SetItem ( buttonsObj , b , axisVal ) ;
}
PyTuple_SetItem ( vrEventObj , 8 , buttonsObj ) ;
}
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( vrEventsObj , i , vrEventObj ) ;
2016-12-27 03:40:09 +00:00
}
2017-03-13 23:06:52 +00:00
return vrEventsObj ;
2016-12-27 03:40:09 +00:00
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-04-10 18:03:41 +00:00
static PyObject * pybullet_getDebugVisualizerCamera ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
b3SharedMemoryCommandHandle commandHandle ;
int hasCamInfo ;
b3SharedMemoryStatusHandle statusHandle ;
struct b3OpenGLVisualizerCameraInfo camera ;
2018-09-23 21:17:31 +00:00
PyObject * pyCameraList = 0 ;
2017-04-10 18:03:41 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
commandHandle = b3InitRequestOpenGLVisualizerCameraCommand ( sm ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
2018-09-23 21:17:31 +00:00
hasCamInfo = b3GetStatusOpenGLVisualizerCamera ( statusHandle , & camera ) ;
2017-04-10 18:03:41 +00:00
if ( hasCamInfo )
{
2018-09-23 21:17:31 +00:00
PyObject * item = 0 ;
2017-06-03 01:24:51 +00:00
pyCameraList = PyTuple_New ( 12 ) ;
2017-04-10 18:03:41 +00:00
item = PyInt_FromLong ( camera . m_width ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( pyCameraList , 0 , item ) ;
2017-04-10 18:03:41 +00:00
item = PyInt_FromLong ( camera . m_height ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( pyCameraList , 1 , item ) ;
2017-04-10 18:03:41 +00:00
{
PyObject * viewMat16 = PyTuple_New ( 16 ) ;
PyObject * projMat16 = PyTuple_New ( 16 ) ;
int i ;
2018-09-23 21:17:31 +00:00
for ( i = 0 ; i < 16 ; i + + )
2017-04-10 18:03:41 +00:00
{
item = PyFloat_FromDouble ( camera . m_viewMatrix [ i ] ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( viewMat16 , i , item ) ;
2017-04-10 18:03:41 +00:00
item = PyFloat_FromDouble ( camera . m_projectionMatrix [ i ] ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( projMat16 , i , item ) ;
2017-04-10 18:03:41 +00:00
}
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( pyCameraList , 2 , viewMat16 ) ;
PyTuple_SetItem ( pyCameraList , 3 , projMat16 ) ;
2017-04-10 18:03:41 +00:00
}
{
2018-09-23 21:17:31 +00:00
PyObject * item = 0 ;
2017-04-10 18:03:41 +00:00
int i ;
PyObject * camUp = PyTuple_New ( 3 ) ;
PyObject * camFwd = PyTuple_New ( 3 ) ;
PyObject * hor = PyTuple_New ( 3 ) ;
2018-09-23 21:17:31 +00:00
PyObject * vert = PyTuple_New ( 3 ) ;
for ( i = 0 ; i < 3 ; i + + )
2017-04-10 18:03:41 +00:00
{
item = PyFloat_FromDouble ( camera . m_camUp [ i ] ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( camUp , i , item ) ;
2017-04-10 18:03:41 +00:00
item = PyFloat_FromDouble ( camera . m_camForward [ i ] ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( camFwd , i , item ) ;
2017-04-10 18:03:41 +00:00
item = PyFloat_FromDouble ( camera . m_horizontal [ i ] ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( hor , i , item ) ;
2017-04-10 18:03:41 +00:00
item = PyFloat_FromDouble ( camera . m_vertical [ i ] ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( vert , i , item ) ;
2017-04-10 18:03:41 +00:00
}
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( pyCameraList , 4 , camUp ) ;
PyTuple_SetItem ( pyCameraList , 5 , camFwd ) ;
PyTuple_SetItem ( pyCameraList , 6 , hor ) ;
PyTuple_SetItem ( pyCameraList , 7 , vert ) ;
2017-04-10 18:03:41 +00:00
}
2017-06-03 01:24:51 +00:00
item = PyFloat_FromDouble ( camera . m_yaw ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( pyCameraList , 8 , item ) ;
2017-06-03 01:24:51 +00:00
item = PyFloat_FromDouble ( camera . m_pitch ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( pyCameraList , 9 , item ) ;
2017-06-03 01:24:51 +00:00
item = PyFloat_FromDouble ( camera . m_dist ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( pyCameraList , 10 , item ) ;
2017-06-03 01:24:51 +00:00
{
2018-09-23 21:17:31 +00:00
PyObject * item = 0 ;
2017-06-03 01:24:51 +00:00
int i ;
PyObject * camTarget = PyTuple_New ( 3 ) ;
2018-09-23 21:17:31 +00:00
for ( i = 0 ; i < 3 ; i + + )
2017-06-03 01:24:51 +00:00
{
item = PyFloat_FromDouble ( camera . m_target [ i ] ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( camTarget , i , item ) ;
2017-06-03 01:24:51 +00:00
}
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( pyCameraList , 11 , camTarget ) ;
2017-06-03 01:24:51 +00:00
}
2017-04-10 18:03:41 +00:00
return pyCameraList ;
}
PyErr_SetString ( SpamError , " Cannot get OpenGL visualizer camera info. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_configureDebugVisualizer ( PyObject * self , PyObject * args , PyObject * keywds )
2017-02-22 01:36:54 +00:00
{
2017-03-13 23:06:52 +00:00
int flag = 1 ;
int enable = - 1 ;
2017-02-22 01:36:54 +00:00
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " flag " , " enable " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|i " , kwlist ,
& flag , & enable , & physicsClientId ) )
return NULL ;
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
b3SharedMemoryCommandHandle commandHandle = b3InitConfigureOpenGLVisualizer ( sm ) ;
b3ConfigureOpenGLVisualizerSetVisualizationFlags ( commandHandle , flag , enable ) ;
b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-02-22 01:36:54 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_resetDebugVisualizerCamera ( PyObject * self , PyObject * args , PyObject * keywds )
2017-03-01 23:04:07 +00:00
{
2017-03-13 23:06:52 +00:00
float cameraDistance = - 1 ;
2017-03-13 17:38:02 +00:00
float cameraYaw = 35 ;
float cameraPitch = 50 ;
2017-03-13 23:06:52 +00:00
PyObject * cameraTargetPosObj = 0 ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " cameraDistance " , " cameraYaw " , " cameraPitch " , " cameraTargetPosition " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " fffO|i " , kwlist ,
& cameraDistance , & cameraYaw , & cameraPitch , & cameraTargetPosObj , & physicsClientId ) )
return NULL ;
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
b3SharedMemoryCommandHandle commandHandle = b3InitConfigureOpenGLVisualizer ( sm ) ;
2017-03-14 01:50:32 +00:00
if ( ( cameraDistance > = 0 ) )
2017-03-01 23:04:07 +00:00
{
float cameraTargetPosition [ 3 ] ;
2017-03-13 23:06:52 +00:00
if ( pybullet_internalSetVector ( cameraTargetPosObj , cameraTargetPosition ) )
2017-03-01 23:04:07 +00:00
{
2017-03-13 23:06:52 +00:00
b3ConfigureOpenGLVisualizerSetViewMatrix ( commandHandle , cameraDistance , cameraPitch , cameraYaw , cameraTargetPosition ) ;
2017-03-01 23:04:07 +00:00
}
}
2017-03-13 23:06:52 +00:00
b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2017-03-01 23:04:07 +00:00
}
2016-12-27 03:40:09 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_setDebugObjectColor ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-21 15:42:11 +00:00
{
PyObject * objectColorRGBObj = 0 ;
double objectColorRGB [ 3 ] ;
int objectUniqueId = - 1 ;
int linkIndex = - 2 ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
2017-03-13 23:06:52 +00:00
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " objectUniqueId " , " linkIndex " , " objectDebugColorRGB " , " physicsClientId " , NULL } ;
2016-11-21 15:42:11 +00:00
2016-12-28 04:25:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|Oi " , kwlist ,
2017-03-13 23:06:52 +00:00
& objectUniqueId , & linkIndex , & objectColorRGBObj , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
return NULL ;
2016-11-21 15:42:11 +00:00
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
2016-11-21 15:42:11 +00:00
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
if ( objectColorRGBObj )
{
if ( pybullet_internalSetVectord ( objectColorRGBObj , objectColorRGB ) )
{
b3SharedMemoryCommandHandle commandHandle = b3InitDebugDrawingCommand ( sm ) ;
b3SetDebugObjectColor ( commandHandle , objectUniqueId , linkIndex , objectColorRGB ) ;
b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
}
}
else
{
b3SharedMemoryCommandHandle commandHandle = b3InitDebugDrawingCommand ( sm ) ;
b3RemoveDebugObjectColor ( commandHandle , objectUniqueId , linkIndex ) ;
b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2016-11-14 15:39:34 +00:00
2018-01-04 03:17:28 +00:00
static PyObject * pybullet_getCollisionShapeData ( PyObject * self , PyObject * args , PyObject * keywds )
{
int objectUniqueId = - 1 ;
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
struct b3CollisionShapeInformation collisionShapeInfo ;
int statusType ;
int i ;
int linkIndex ;
PyObject * pyResultList = 0 ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " objectUniqueId " , " linkIndex " , " physicsClientId " , NULL } ;
2018-01-04 03:17:28 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|i " , kwlist , & objectUniqueId , & linkIndex , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
commandHandle = b3InitRequestCollisionShapeInformation ( sm , objectUniqueId , linkIndex ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_COLLISION_SHAPE_INFO_COMPLETED )
{
b3GetCollisionShapeInformation ( sm , & collisionShapeInfo ) ;
pyResultList = PyTuple_New ( collisionShapeInfo . m_numCollisionShapes ) ;
for ( i = 0 ; i < collisionShapeInfo . m_numCollisionShapes ; i + + )
{
PyObject * collisionShapeObList = PyTuple_New ( 7 ) ;
PyObject * item ;
item = PyInt_FromLong ( collisionShapeInfo . m_collisionShapeData [ i ] . m_objectUniqueId ) ;
PyTuple_SetItem ( collisionShapeObList , 0 , item ) ;
item = PyInt_FromLong ( collisionShapeInfo . m_collisionShapeData [ i ] . m_linkIndex ) ;
PyTuple_SetItem ( collisionShapeObList , 1 , item ) ;
item = PyInt_FromLong ( collisionShapeInfo . m_collisionShapeData [ i ] . m_collisionGeometryType ) ;
PyTuple_SetItem ( collisionShapeObList , 2 , item ) ;
{
PyObject * vec = PyTuple_New ( 3 ) ;
item = PyFloat_FromDouble ( collisionShapeInfo . m_collisionShapeData [ i ] . m_dimensions [ 0 ] ) ;
PyTuple_SetItem ( vec , 0 , item ) ;
item = PyFloat_FromDouble ( collisionShapeInfo . m_collisionShapeData [ i ] . m_dimensions [ 1 ] ) ;
PyTuple_SetItem ( vec , 1 , item ) ;
item = PyFloat_FromDouble ( collisionShapeInfo . m_collisionShapeData [ i ] . m_dimensions [ 2 ] ) ;
PyTuple_SetItem ( vec , 2 , item ) ;
PyTuple_SetItem ( collisionShapeObList , 3 , vec ) ;
}
item = PyString_FromString ( collisionShapeInfo . m_collisionShapeData [ i ] . m_meshAssetFileName ) ;
PyTuple_SetItem ( collisionShapeObList , 4 , item ) ;
{
PyObject * vec = PyTuple_New ( 3 ) ;
item = PyFloat_FromDouble ( collisionShapeInfo . m_collisionShapeData [ i ] . m_localCollisionFrame [ 0 ] ) ;
PyTuple_SetItem ( vec , 0 , item ) ;
item = PyFloat_FromDouble ( collisionShapeInfo . m_collisionShapeData [ i ] . m_localCollisionFrame [ 1 ] ) ;
PyTuple_SetItem ( vec , 1 , item ) ;
item = PyFloat_FromDouble ( collisionShapeInfo . m_collisionShapeData [ i ] . m_localCollisionFrame [ 2 ] ) ;
PyTuple_SetItem ( vec , 2 , item ) ;
PyTuple_SetItem ( collisionShapeObList , 5 , vec ) ;
}
{
PyObject * vec = PyTuple_New ( 4 ) ;
item = PyFloat_FromDouble ( collisionShapeInfo . m_collisionShapeData [ i ] . m_localCollisionFrame [ 3 ] ) ;
PyTuple_SetItem ( vec , 0 , item ) ;
item = PyFloat_FromDouble ( collisionShapeInfo . m_collisionShapeData [ i ] . m_localCollisionFrame [ 4 ] ) ;
PyTuple_SetItem ( vec , 1 , item ) ;
item = PyFloat_FromDouble ( collisionShapeInfo . m_collisionShapeData [ i ] . m_localCollisionFrame [ 5 ] ) ;
PyTuple_SetItem ( vec , 2 , item ) ;
item = PyFloat_FromDouble ( collisionShapeInfo . m_collisionShapeData [ i ] . m_localCollisionFrame [ 6 ] ) ;
PyTuple_SetItem ( vec , 3 , item ) ;
PyTuple_SetItem ( collisionShapeObList , 6 , vec ) ;
}
PyTuple_SetItem ( pyResultList , i , collisionShapeObList ) ;
}
return pyResultList ;
}
else
{
PyErr_SetString ( SpamError , " Error receiving collision shape info " ) ;
return NULL ;
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getVisualShapeData ( PyObject * self , PyObject * args , PyObject * keywds )
2016-10-19 05:05:28 +00:00
{
int objectUniqueId = - 1 ;
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
struct b3VisualShapeInformation visualShapeInfo ;
int statusType ;
2016-10-19 14:42:55 +00:00
int i ;
2016-10-19 05:05:28 +00:00
PyObject * pyResultList = 0 ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
int flags = 0 ;
2018-07-08 09:23:12 +00:00
static char * kwlist [ ] = { " objectUniqueId " , " flags " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|ii " , kwlist , & objectUniqueId , & flags , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
2016-11-10 05:01:04 +00:00
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-12-28 04:25:52 +00:00
2016-10-19 05:05:28 +00:00
{
commandHandle = b3InitRequestVisualShapeInformation ( sm , objectUniqueId ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_VISUAL_SHAPE_INFO_COMPLETED )
{
b3GetVisualShapeInformation ( sm , & visualShapeInfo ) ;
pyResultList = PyTuple_New ( visualShapeInfo . m_numVisualShapes ) ;
2016-10-19 14:42:55 +00:00
for ( i = 0 ; i < visualShapeInfo . m_numVisualShapes ; i + + )
2016-10-19 05:05:28 +00:00
{
2018-09-23 21:17:31 +00:00
int numFields = flags & eVISUAL_SHAPE_DATA_TEXTURE_UNIQUE_IDS ? 9 : 8 ;
2018-07-08 09:23:12 +00:00
PyObject * visualShapeObList = PyTuple_New ( numFields ) ;
2016-10-19 05:05:28 +00:00
PyObject * item ;
item = PyInt_FromLong ( visualShapeInfo . m_visualShapeData [ i ] . m_objectUniqueId ) ;
PyTuple_SetItem ( visualShapeObList , 0 , item ) ;
2017-03-13 23:06:52 +00:00
2016-10-19 05:05:28 +00:00
item = PyInt_FromLong ( visualShapeInfo . m_visualShapeData [ i ] . m_linkIndex ) ;
PyTuple_SetItem ( visualShapeObList , 1 , item ) ;
2017-03-13 23:06:52 +00:00
2016-10-19 05:05:28 +00:00
item = PyInt_FromLong ( visualShapeInfo . m_visualShapeData [ i ] . m_visualGeometryType ) ;
PyTuple_SetItem ( visualShapeObList , 2 , item ) ;
{
PyObject * vec = PyTuple_New ( 3 ) ;
2017-02-03 16:34:22 +00:00
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_dimensions [ 0 ] ) ;
2016-10-19 05:05:28 +00:00
PyTuple_SetItem ( vec , 0 , item ) ;
2017-02-03 16:34:22 +00:00
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_dimensions [ 1 ] ) ;
2016-10-19 05:05:28 +00:00
PyTuple_SetItem ( vec , 1 , item ) ;
2017-02-03 16:34:22 +00:00
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_dimensions [ 2 ] ) ;
2016-10-19 05:05:28 +00:00
PyTuple_SetItem ( vec , 2 , item ) ;
PyTuple_SetItem ( visualShapeObList , 3 , vec ) ;
}
2017-03-13 23:06:52 +00:00
2016-10-19 05:05:28 +00:00
item = PyString_FromString ( visualShapeInfo . m_visualShapeData [ i ] . m_meshAssetFileName ) ;
PyTuple_SetItem ( visualShapeObList , 4 , item ) ;
{
PyObject * vec = PyTuple_New ( 3 ) ;
2017-02-03 16:34:22 +00:00
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_localVisualFrame [ 0 ] ) ;
2016-10-19 05:05:28 +00:00
PyTuple_SetItem ( vec , 0 , item ) ;
2017-02-03 16:34:22 +00:00
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_localVisualFrame [ 1 ] ) ;
2016-10-19 05:05:28 +00:00
PyTuple_SetItem ( vec , 1 , item ) ;
2017-02-03 16:34:22 +00:00
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_localVisualFrame [ 2 ] ) ;
2016-10-19 05:05:28 +00:00
PyTuple_SetItem ( vec , 2 , item ) ;
PyTuple_SetItem ( visualShapeObList , 5 , vec ) ;
}
{
PyObject * vec = PyTuple_New ( 4 ) ;
2017-02-03 16:34:22 +00:00
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_localVisualFrame [ 3 ] ) ;
2016-10-19 05:05:28 +00:00
PyTuple_SetItem ( vec , 0 , item ) ;
2017-02-03 16:34:22 +00:00
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_localVisualFrame [ 4 ] ) ;
2016-10-19 05:05:28 +00:00
PyTuple_SetItem ( vec , 1 , item ) ;
2017-02-03 16:34:22 +00:00
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_localVisualFrame [ 5 ] ) ;
2016-10-19 05:05:28 +00:00
PyTuple_SetItem ( vec , 2 , item ) ;
2017-02-03 16:34:22 +00:00
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_localVisualFrame [ 6 ] ) ;
2016-10-19 05:05:28 +00:00
PyTuple_SetItem ( vec , 3 , item ) ;
PyTuple_SetItem ( visualShapeObList , 6 , vec ) ;
}
2017-03-13 23:06:52 +00:00
{
PyObject * rgba = PyTuple_New ( 4 ) ;
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_rgbaColor [ 0 ] ) ;
PyTuple_SetItem ( rgba , 0 , item ) ;
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_rgbaColor [ 1 ] ) ;
PyTuple_SetItem ( rgba , 1 , item ) ;
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_rgbaColor [ 2 ] ) ;
PyTuple_SetItem ( rgba , 2 , item ) ;
item = PyFloat_FromDouble ( visualShapeInfo . m_visualShapeData [ i ] . m_rgbaColor [ 3 ] ) ;
PyTuple_SetItem ( rgba , 3 , item ) ;
PyTuple_SetItem ( visualShapeObList , 7 , rgba ) ;
}
2018-09-23 21:17:31 +00:00
if ( flags & eVISUAL_SHAPE_DATA_TEXTURE_UNIQUE_IDS )
2018-07-08 09:23:12 +00:00
{
item = PyInt_FromLong ( visualShapeInfo . m_visualShapeData [ i ] . m_textureUniqueId ) ;
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( visualShapeObList , 8 , item ) ;
2018-07-08 09:23:12 +00:00
}
2016-10-19 05:05:28 +00:00
PyTuple_SetItem ( pyResultList , i , visualShapeObList ) ;
}
return pyResultList ;
}
else
{
PyErr_SetString ( SpamError , " Error receiving visual shape info " ) ;
return NULL ;
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-05-13 16:18:36 +00:00
static PyObject * pybullet_changeVisualShape ( PyObject * self , PyObject * args , PyObject * keywds )
2016-10-22 00:48:06 +00:00
{
2017-03-13 23:06:52 +00:00
int objectUniqueId = - 1 ;
int jointIndex = - 1 ;
int shapeIndex = - 1 ;
2018-10-20 22:56:56 +00:00
int textureUniqueId = - 2 ;
2017-03-13 23:06:52 +00:00
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
int physicsClientId = 0 ;
2017-05-13 16:18:36 +00:00
PyObject * rgbaColorObj = 0 ;
2017-06-01 19:32:44 +00:00
PyObject * specularColorObj = 0 ;
2016-12-28 04:25:52 +00:00
b3PhysicsClientHandle sm = 0 ;
2017-06-01 19:32:44 +00:00
static char * kwlist [ ] = { " objectUniqueId " , " linkIndex " , " shapeIndex " , " textureUniqueId " , " rgbaColor " , " specularColor " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|iiOOi " , kwlist , & objectUniqueId , & jointIndex , & shapeIndex , & textureUniqueId , & rgbaColorObj , & specularColorObj , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
2016-11-10 05:01:04 +00:00
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
{
2018-10-21 02:44:39 +00:00
commandHandle = b3InitUpdateVisualShape2 ( sm , objectUniqueId , jointIndex , shapeIndex ) ;
2018-10-20 22:56:56 +00:00
if ( textureUniqueId > = - 1 )
{
b3UpdateVisualShapeTexture ( commandHandle , textureUniqueId ) ;
}
2017-05-13 16:18:36 +00:00
2017-06-01 19:32:44 +00:00
if ( specularColorObj )
{
2018-09-23 21:17:31 +00:00
double specularColor [ 3 ] = { 1 , 1 , 1 } ;
2017-06-01 19:32:44 +00:00
pybullet_internalSetVectord ( specularColorObj , specularColor ) ;
2018-09-23 21:17:31 +00:00
b3UpdateVisualShapeSpecularColor ( commandHandle , specularColor ) ;
2017-06-01 19:32:44 +00:00
}
2017-05-13 16:18:36 +00:00
if ( rgbaColorObj )
{
2018-09-23 21:17:31 +00:00
double rgbaColor [ 4 ] = { 1 , 1 , 1 , 1 } ;
2017-05-13 16:18:36 +00:00
pybullet_internalSetVector4d ( rgbaColorObj , rgbaColor ) ;
2018-09-23 21:17:31 +00:00
b3UpdateVisualShapeRGBAColor ( commandHandle , rgbaColor ) ;
2017-05-13 16:18:36 +00:00
}
2017-03-13 23:06:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_VISUAL_SHAPE_UPDATE_COMPLETED )
{
}
else
{
PyErr_SetString ( SpamError , " Error resetting visual shape info " ) ;
return NULL ;
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-10-22 00:48:06 +00:00
}
2016-10-19 05:05:28 +00:00
2017-07-01 02:11:43 +00:00
static PyObject * pybullet_changeTexture ( PyObject * self , PyObject * args , PyObject * keywds )
{
b3SharedMemoryCommandHandle commandHandle = 0 ;
2018-09-23 21:17:31 +00:00
b3SharedMemoryStatusHandle statusHandle = 0 ;
2017-07-01 02:11:43 +00:00
int statusType = - 1 ;
int textureUniqueId = - 1 ;
int physicsClientId = 0 ;
2018-09-23 21:17:31 +00:00
int width = - 1 ;
int height = - 1 ;
2018-09-11 20:24:35 +00:00
2017-07-01 02:11:43 +00:00
PyObject * pixelsObj = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " textureUniqueId " , " pixels " , " width " , " height " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iOii|i " , kwlist , & textureUniqueId , & pixelsObj , & width , & height , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-09-23 21:17:31 +00:00
if ( textureUniqueId > = 0 & & width > = 0 & & height > = 0 & & pixelsObj )
2017-07-01 02:11:43 +00:00
{
PyObject * seqPixels = PySequence_Fast ( pixelsObj , " expected a sequence " ) ;
PyObject * item ;
int i ;
2018-09-23 21:17:31 +00:00
int numPixels = width * height ;
unsigned char * pixelBuffer = ( unsigned char * ) malloc ( numPixels * 3 ) ;
2017-07-01 02:11:43 +00:00
if ( PyList_Check ( seqPixels ) )
{
2018-09-23 21:17:31 +00:00
for ( i = 0 ; i < numPixels * 3 ; i + + )
2017-07-01 02:11:43 +00:00
{
item = PyList_GET_ITEM ( seqPixels , i ) ;
pixelBuffer [ i ] = PyLong_AsLong ( item ) ;
}
2018-09-23 21:17:31 +00:00
}
else
2017-07-01 02:11:43 +00:00
{
2018-09-23 21:17:31 +00:00
for ( i = 0 ; i < numPixels * 3 ; i + + )
2017-07-01 02:11:43 +00:00
{
item = PyTuple_GET_ITEM ( seqPixels , i ) ;
pixelBuffer [ i ] = PyLong_AsLong ( item ) ;
}
2018-09-11 20:24:35 +00:00
}
2017-07-01 02:11:43 +00:00
2018-09-23 21:17:31 +00:00
commandHandle = b3CreateChangeTextureCommandInit ( sm , textureUniqueId , width , height , ( const char * ) pixelBuffer ) ;
2017-07-01 02:11:43 +00:00
free ( pixelBuffer ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CLIENT_COMMAND_COMPLETED )
{
Py_INCREF ( Py_None ) ;
return Py_None ;
2018-09-23 21:17:31 +00:00
}
else
2017-07-01 02:11:43 +00:00
{
PyErr_SetString ( SpamError , " Error processing changeTexture. " ) ;
return NULL ;
}
}
PyErr_SetString ( SpamError , " Error: invalid arguments in changeTexture. " ) ;
return NULL ;
}
2016-12-28 04:25:52 +00:00
static PyObject * pybullet_loadTexture ( PyObject * self , PyObject * args , PyObject * keywds )
2016-10-22 00:48:06 +00:00
{
2017-03-13 23:06:52 +00:00
const char * filename = 0 ;
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " textureFilename " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|i " , kwlist , & filename , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
2016-11-10 05:01:04 +00:00
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-10-19 05:05:28 +00:00
2017-03-13 23:06:52 +00:00
{
commandHandle = b3InitLoadTexture ( sm , filename ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_LOAD_TEXTURE_COMPLETED )
{
2017-06-30 20:35:07 +00:00
PyObject * item ;
item = PyInt_FromLong ( b3GetStatusTextureUniqueId ( statusHandle ) ) ;
return item ;
2017-03-13 23:06:52 +00:00
}
}
2017-06-30 20:35:07 +00:00
PyErr_SetString ( SpamError , " Error loading texture " ) ;
return NULL ;
2017-03-13 23:06:52 +00:00
}
2016-09-02 01:28:39 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * MyConvertContactPoint ( struct b3ContactInformation * contactPointPtr )
2016-11-10 05:01:04 +00:00
{
2017-03-13 23:06:52 +00:00
/*
2017-09-24 02:58:59 +00:00
0 int m_contactFlags ;
1 int m_bodyUniqueIdA ;
2 int m_bodyUniqueIdB ;
3 int m_linkIndexA ;
4 int m_linkIndexB ;
5 double m_positionOnAInWS [ 3 ] ; //contact point location on object A,
in world space coordinates
6 double m_positionOnBInWS [ 3 ] ; //contact point location on object
A , in world space coordinates
7 double m_contactNormalOnBInWS [ 3 ] ; //the separating contact
normal , pointing from object B towards object A
8 double m_contactDistance ; //negative number is penetration, positive
is distance .
9 double m_normalForce ;
2018-09-24 13:46:56 +00:00
10 double m_linearFrictionForce1 ;
11 double double m_linearFrictionDirection1 [ 3 ] ;
12 double m_linearFrictionForce2 ;
13 double double m_linearFrictionDirection2 [ 3 ] ;
2017-09-24 02:58:59 +00:00
*/
2016-09-08 18:12:58 +00:00
2016-11-10 05:01:04 +00:00
int i ;
PyObject * pyResultList = PyTuple_New ( contactPointPtr - > m_numContactPoints ) ;
2017-03-13 23:06:52 +00:00
for ( i = 0 ; i < contactPointPtr - > m_numContactPoints ; i + + )
{
2018-09-24 13:46:56 +00:00
PyObject * contactObList = PyTuple_New ( 14 ) ; // see above 10 fields
2017-03-13 23:06:52 +00:00
PyObject * item ;
item =
PyInt_FromLong ( contactPointPtr - > m_contactPointData [ i ] . m_contactFlags ) ;
PyTuple_SetItem ( contactObList , 0 , item ) ;
item = PyInt_FromLong (
contactPointPtr - > m_contactPointData [ i ] . m_bodyUniqueIdA ) ;
PyTuple_SetItem ( contactObList , 1 , item ) ;
item = PyInt_FromLong (
contactPointPtr - > m_contactPointData [ i ] . m_bodyUniqueIdB ) ;
PyTuple_SetItem ( contactObList , 2 , item ) ;
item =
PyInt_FromLong ( contactPointPtr - > m_contactPointData [ i ] . m_linkIndexA ) ;
PyTuple_SetItem ( contactObList , 3 , item ) ;
item =
PyInt_FromLong ( contactPointPtr - > m_contactPointData [ i ] . m_linkIndexB ) ;
PyTuple_SetItem ( contactObList , 4 , item ) ;
{
PyObject * posAObj = PyTuple_New ( 3 ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_positionOnAInWS [ 0 ] ) ;
PyTuple_SetItem ( posAObj , 0 , item ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_positionOnAInWS [ 1 ] ) ;
PyTuple_SetItem ( posAObj , 1 , item ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_positionOnAInWS [ 2 ] ) ;
PyTuple_SetItem ( posAObj , 2 , item ) ;
PyTuple_SetItem ( contactObList , 5 , posAObj ) ;
}
{
PyObject * posBObj = PyTuple_New ( 3 ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_positionOnBInWS [ 0 ] ) ;
PyTuple_SetItem ( posBObj , 0 , item ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_positionOnBInWS [ 1 ] ) ;
PyTuple_SetItem ( posBObj , 1 , item ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_positionOnBInWS [ 2 ] ) ;
PyTuple_SetItem ( posBObj , 2 , item ) ;
PyTuple_SetItem ( contactObList , 6 , posBObj ) ;
}
{
PyObject * normalOnB = PyTuple_New ( 3 ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_contactNormalOnBInWS [ 0 ] ) ;
PyTuple_SetItem ( normalOnB , 0 , item ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_contactNormalOnBInWS [ 1 ] ) ;
PyTuple_SetItem ( normalOnB , 1 , item ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_contactNormalOnBInWS [ 2 ] ) ;
PyTuple_SetItem ( normalOnB , 2 , item ) ;
PyTuple_SetItem ( contactObList , 7 , normalOnB ) ;
}
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_contactDistance ) ;
PyTuple_SetItem ( contactObList , 8 , item ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_normalForce ) ;
PyTuple_SetItem ( contactObList , 9 , item ) ;
2018-09-24 13:46:56 +00:00
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_linearFrictionForce1 ) ;
PyTuple_SetItem ( contactObList , 10 , item ) ;
{
PyObject * posAObj = PyTuple_New ( 3 ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_linearFrictionDirection1 [ 0 ] ) ;
PyTuple_SetItem ( posAObj , 0 , item ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_linearFrictionDirection1 [ 1 ] ) ;
PyTuple_SetItem ( posAObj , 1 , item ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_linearFrictionDirection1 [ 2 ] ) ;
PyTuple_SetItem ( posAObj , 2 , item ) ;
PyTuple_SetItem ( contactObList , 11 , posAObj ) ;
}
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_linearFrictionForce2 ) ;
PyTuple_SetItem ( contactObList , 12 , item ) ;
{
PyObject * posAObj = PyTuple_New ( 3 ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_linearFrictionDirection2 [ 0 ] ) ;
PyTuple_SetItem ( posAObj , 0 , item ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_linearFrictionDirection2 [ 1 ] ) ;
PyTuple_SetItem ( posAObj , 1 , item ) ;
item = PyFloat_FromDouble (
contactPointPtr - > m_contactPointData [ i ] . m_linearFrictionDirection2 [ 2 ] ) ;
PyTuple_SetItem ( posAObj , 2 , item ) ;
PyTuple_SetItem ( contactObList , 13 , posAObj ) ;
}
2017-03-13 23:06:52 +00:00
PyTuple_SetItem ( pyResultList , i , contactObList ) ;
}
return pyResultList ;
2016-11-10 05:01:04 +00:00
}
2018-09-13 02:30:49 +00:00
static PyObject * pybullet_setCollisionFilterGroupMask ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
int bodyUniqueIdA = - 1 ;
int linkIndexA = - 2 ;
int collisionFilterGroup = - 1 ;
2018-09-13 02:30:49 +00:00
int collisionFilterMask = - 1 ;
2018-09-23 21:17:31 +00:00
b3SharedMemoryCommandHandle commandHandle ;
2018-09-13 02:30:49 +00:00
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " linkIndexA " , " collisionFilterGroup " , " collisionFilterMask " , " physicsClientId " , NULL } ;
2018-09-13 02:30:49 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iiii|i " , kwlist ,
2018-09-23 21:17:31 +00:00
& bodyUniqueIdA , & linkIndexA , & collisionFilterGroup , & collisionFilterMask , & physicsClientId ) )
2018-09-13 02:30:49 +00:00
return NULL ;
2018-09-23 21:17:31 +00:00
commandHandle = b3CollisionFilterCommandInit ( sm ) ;
b3SetCollisionFilterGroupMask ( commandHandle , bodyUniqueIdA , linkIndexA , collisionFilterGroup , collisionFilterMask ) ;
2018-09-13 02:30:49 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject * pybullet_setCollisionFilterPair ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
int bodyUniqueIdA = - 1 ;
int bodyUniqueIdB = - 1 ;
int linkIndexA = - 2 ;
int linkIndexB = - 2 ;
2018-09-13 02:30:49 +00:00
int enableCollision = - 1 ;
2018-09-23 21:17:31 +00:00
b3SharedMemoryCommandHandle commandHandle ;
2018-09-13 02:30:49 +00:00
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " bodyUniqueIdA " , " bodyUniqueIdB " , " linkIndexA " , " linkIndexB " , " enableCollision " , " physicsClientId " , NULL } ;
2018-09-13 02:30:49 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iiiii|i " , kwlist ,
2018-09-23 21:17:31 +00:00
& bodyUniqueIdA , & bodyUniqueIdB , & linkIndexA , & linkIndexB , & enableCollision , & physicsClientId ) )
2018-09-13 02:30:49 +00:00
return NULL ;
2018-09-23 21:17:31 +00:00
commandHandle = b3CollisionFilterCommandInit ( sm ) ;
b3SetCollisionFilterPair ( commandHandle , bodyUniqueIdA , bodyUniqueIdB , linkIndexA , linkIndexB , enableCollision ) ;
2018-09-13 02:30:49 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getOverlappingObjects ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-10 05:01:04 +00:00
{
2017-03-13 23:06:52 +00:00
PyObject * aabbMinOb = 0 , * aabbMaxOb = 0 ;
2016-11-10 05:01:04 +00:00
double aabbMin [ 3 ] ;
double aabbMax [ 3 ] ;
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
struct b3AABBOverlapData overlapData ;
2016-11-10 19:22:22 +00:00
int i ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " aabbMin " , " aabbMax " , " physicsClientId " , NULL } ;
2016-11-10 19:22:22 +00:00
2016-12-28 04:25:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " OO|i " , kwlist ,
2017-03-13 23:06:52 +00:00
& aabbMinOb , & aabbMaxOb , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
return NULL ;
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
2016-11-10 05:01:04 +00:00
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
pybullet_internalSetVectord ( aabbMinOb , aabbMin ) ;
pybullet_internalSetVectord ( aabbMaxOb , aabbMax ) ;
commandHandle = b3InitAABBOverlapQuery ( sm , aabbMin , aabbMax ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
b3GetAABBOverlapResults ( sm , & overlapData ) ;
2016-11-10 19:22:22 +00:00
if ( overlapData . m_numOverlappingObjects )
{
PyObject * pyResultList = PyTuple_New ( overlapData . m_numOverlappingObjects ) ;
//For huge amount of overlap, we could use numpy instead (see camera pixel data)
//What would Python do with huge amount of data? Pass it onto TensorFlow!
2017-03-13 23:06:52 +00:00
for ( i = 0 ; i < overlapData . m_numOverlappingObjects ; i + + )
{
PyObject * overlap = PyTuple_New ( 2 ) ; //body unique id and link index
2016-11-10 19:22:22 +00:00
PyObject * item ;
item =
PyInt_FromLong ( overlapData . m_overlappingObjects [ i ] . m_objectUniqueId ) ;
PyTuple_SetItem ( overlap , 0 , item ) ;
item =
PyInt_FromLong ( overlapData . m_overlappingObjects [ i ] . m_linkIndex ) ;
PyTuple_SetItem ( overlap , 1 , item ) ;
PyTuple_SetItem ( pyResultList , i , overlap ) ;
}
return pyResultList ;
}
2016-11-10 05:01:04 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getClosestPointData ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-10 05:01:04 +00:00
{
2017-03-13 23:06:52 +00:00
int bodyUniqueIdA = - 1 ;
int bodyUniqueIdB = - 1 ;
int linkIndexA = - 2 ;
int linkIndexB = - 2 ;
2018-09-22 20:17:09 +00:00
int collisionShapeA = - 1 ;
int collisionShapeB = - 1 ;
PyObject * collisionShapePositionAObj = 0 ;
PyObject * collisionShapeOrientationAObj = 0 ;
2018-09-23 21:17:31 +00:00
double collisionShapePositionA [ 3 ] = { 0 , 0 , 0 } ;
double collisionShapeOrientationA [ 4 ] = { 0 , 0 , 0 , 1 } ;
2018-09-22 20:17:09 +00:00
PyObject * collisionShapePositionBObj = 0 ;
PyObject * collisionShapeOrientationBObj = 0 ;
2018-09-23 21:17:31 +00:00
double collisionShapePositionB [ 3 ] = { 0 , 0 , 0 } ;
double collisionShapeOrientationB [ 4 ] = { 0 , 0 , 0 , 1 } ;
2016-11-20 01:13:56 +00:00
2017-03-13 23:06:52 +00:00
double distanceThreshold = 0.f ;
2016-11-10 05:01:04 +00:00
2017-03-13 23:06:52 +00:00
b3SharedMemoryCommandHandle commandHandle ;
struct b3ContactInformation contactPointData ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " bodyA " , " bodyB " , " distance " , " linkIndexA " , " linkIndexB " , " collisionShapeA " , " collisionShapeB " , " collisionShapePositionA " , " collisionShapePositionB " , " collisionShapeOrientationA " , " collisionShapeOrientationB " , " physicsClientId " , NULL } ;
2016-11-10 05:01:04 +00:00
2018-09-22 20:17:09 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iid|iiiiOOOOi " , kwlist ,
2018-09-23 21:17:31 +00:00
& bodyUniqueIdA , & bodyUniqueIdB , & distanceThreshold , & linkIndexA , & linkIndexB ,
2018-09-22 20:17:09 +00:00
& collisionShapeA , & collisionShapeB ,
2018-09-23 21:17:31 +00:00
& collisionShapePositionAObj , & collisionShapePositionBObj ,
& collisionShapeOrientationA , & collisionShapeOrientationBObj ,
2018-09-22 20:17:09 +00:00
& physicsClientId ) )
2017-03-13 23:06:52 +00:00
return NULL ;
2016-11-10 05:01:04 +00:00
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-11-10 05:01:04 +00:00
2017-03-13 23:06:52 +00:00
commandHandle = b3InitClosestDistanceQuery ( sm ) ;
2018-09-23 21:17:31 +00:00
if ( bodyUniqueIdA > = 0 )
2018-09-22 20:17:09 +00:00
{
b3SetClosestDistanceFilterBodyA ( commandHandle , bodyUniqueIdA ) ;
}
2018-09-23 21:17:31 +00:00
if ( bodyUniqueIdB > = 0 )
2018-09-22 20:17:09 +00:00
{
b3SetClosestDistanceFilterBodyB ( commandHandle , bodyUniqueIdB ) ;
}
2017-03-13 23:06:52 +00:00
b3SetClosestDistanceThreshold ( commandHandle , distanceThreshold ) ;
if ( linkIndexA > = - 1 )
{
b3SetClosestDistanceFilterLinkA ( commandHandle , linkIndexA ) ;
}
if ( linkIndexB > = - 1 )
{
b3SetClosestDistanceFilterLinkB ( commandHandle , linkIndexB ) ;
}
2018-09-23 21:17:31 +00:00
if ( collisionShapeA > = 0 )
2018-09-22 20:17:09 +00:00
{
b3SetClosestDistanceFilterCollisionShapeA ( commandHandle , collisionShapeA ) ;
}
2018-09-23 21:17:31 +00:00
if ( collisionShapeB > = 0 )
2018-09-22 20:17:09 +00:00
{
b3SetClosestDistanceFilterCollisionShapeB ( commandHandle , collisionShapeB ) ;
}
if ( collisionShapePositionAObj )
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVectord ( collisionShapePositionAObj , collisionShapePositionA ) ;
2018-09-22 20:17:09 +00:00
b3SetClosestDistanceFilterCollisionShapePositionA ( commandHandle , collisionShapePositionA ) ;
}
if ( collisionShapePositionBObj )
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVectord ( collisionShapePositionBObj , collisionShapePositionB ) ;
2018-09-22 20:17:09 +00:00
b3SetClosestDistanceFilterCollisionShapePositionB ( commandHandle , collisionShapePositionB ) ;
}
if ( collisionShapeOrientationAObj )
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVector4d ( collisionShapeOrientationAObj , collisionShapeOrientationA ) ;
2018-09-22 20:17:09 +00:00
b3SetClosestDistanceFilterCollisionShapeOrientationA ( commandHandle , collisionShapeOrientationA ) ;
}
if ( collisionShapeOrientationBObj )
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVector4d ( collisionShapeOrientationBObj , collisionShapeOrientationB ) ;
2018-09-22 20:17:09 +00:00
b3SetClosestDistanceFilterCollisionShapeOrientationB ( commandHandle , collisionShapeOrientationB ) ;
}
2016-11-10 05:01:04 +00:00
2017-03-13 23:06:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CONTACT_POINT_INFORMATION_COMPLETED )
{
b3GetContactPointInformation ( sm , & contactPointData ) ;
2016-11-10 05:01:04 +00:00
2017-03-13 23:06:52 +00:00
return MyConvertContactPoint ( & contactPointData ) ;
}
2016-11-10 05:01:04 +00:00
2017-03-13 23:06:52 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-11-10 05:01:04 +00:00
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_changeUserConstraint ( PyObject * self , PyObject * args , PyObject * keywds )
2017-01-12 18:30:46 +00:00
{
2017-09-27 02:54:36 +00:00
static char * kwlist [ ] = { " userConstraintUniqueId " , " jointChildPivot " , " jointChildFrameOrientation " , " maxForce " , " gearRatio " , " gearAuxLink " , " relativePositionTarget " , " erp " , " physicsClientId " , NULL } ;
2017-03-13 23:06:52 +00:00
int userConstraintUniqueId = - 1 ;
2017-01-12 18:30:46 +00:00
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2017-06-24 03:24:04 +00:00
int gearAuxLink = - 1 ;
2017-01-12 18:30:46 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
PyObject * jointChildPivotObj = 0 ;
PyObject * jointChildFrameOrnObj = 0 ;
2017-01-12 18:30:46 +00:00
double jointChildPivot [ 3 ] ;
double jointChildFrameOrn [ 4 ] ;
2017-01-17 02:17:18 +00:00
double maxForce = - 1 ;
2017-06-07 20:44:34 +00:00
double gearRatio = 0 ;
2018-09-23 21:17:31 +00:00
double relativePositionTarget = 1e32 ;
double erp = - 1 ;
2017-09-27 02:54:36 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|OOddiddi " , kwlist , & userConstraintUniqueId , & jointChildPivotObj , & jointChildFrameOrnObj , & maxForce , & gearRatio , & gearAuxLink , & relativePositionTarget , & erp , & physicsClientId ) )
2017-01-12 18:30:46 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2017-01-12 18:30:46 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
commandHandle = b3InitChangeUserConstraintCommand ( sm , userConstraintUniqueId ) ;
2017-01-12 18:30:46 +00:00
2017-03-13 23:06:52 +00:00
if ( pybullet_internalSetVectord ( jointChildPivotObj , jointChildPivot ) )
2017-01-12 18:30:46 +00:00
{
b3InitChangeUserConstraintSetPivotInB ( commandHandle , jointChildPivot ) ;
}
2017-11-13 05:53:14 +00:00
2017-03-13 23:06:52 +00:00
if ( pybullet_internalSetVector4d ( jointChildFrameOrnObj , jointChildFrameOrn ) )
2017-01-12 18:30:46 +00:00
{
b3InitChangeUserConstraintSetFrameInB ( commandHandle , jointChildFrameOrn ) ;
}
2017-09-27 02:54:36 +00:00
2018-09-23 21:17:31 +00:00
if ( relativePositionTarget < 1e10 )
2017-09-27 02:54:36 +00:00
{
b3InitChangeUserConstraintSetRelativePositionTarget ( commandHandle , relativePositionTarget ) ;
}
2018-09-23 21:17:31 +00:00
if ( erp > = 0 )
2017-09-27 02:54:36 +00:00
{
b3InitChangeUserConstraintSetERP ( commandHandle , erp ) ;
}
2017-03-13 23:06:52 +00:00
if ( maxForce > = 0 )
2017-01-17 02:17:18 +00:00
{
2017-03-13 23:06:52 +00:00
b3InitChangeUserConstraintSetMaxForce ( commandHandle , maxForce ) ;
2017-01-17 02:17:18 +00:00
}
2018-09-23 21:17:31 +00:00
if ( gearRatio ! = 0 )
2017-06-07 20:44:34 +00:00
{
2018-09-23 21:17:31 +00:00
b3InitChangeUserConstraintSetGearRatio ( commandHandle , gearRatio ) ;
2017-06-07 20:44:34 +00:00
}
2018-09-23 21:17:31 +00:00
if ( gearAuxLink > = 0 )
2017-06-24 03:24:04 +00:00
{
2018-09-23 21:17:31 +00:00
b3InitChangeUserConstraintSetGearAuxLink ( commandHandle , gearAuxLink ) ;
2017-06-24 03:24:04 +00:00
}
2017-01-12 18:30:46 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
} ;
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_removeUserConstraint ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-14 22:08:05 +00:00
{
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " userConstraintUniqueId " , " physicsClientId " , NULL } ;
int userConstraintUniqueId = - 1 ;
2016-11-14 22:08:05 +00:00
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & userConstraintUniqueId , & physicsClientId ) )
2016-11-14 22:08:05 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-11-14 22:08:05 +00:00
{
2016-12-28 04:25:52 +00:00
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
2016-11-14 22:08:05 +00:00
return NULL ;
}
2017-03-13 23:06:52 +00:00
commandHandle = b3InitRemoveUserConstraintCommand ( sm , userConstraintUniqueId ) ;
2016-11-14 22:08:05 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
Py_INCREF ( Py_None ) ;
return Py_None ;
} ;
/*
2018-09-11 20:24:35 +00:00
static PyObject * pybullet_updateUserConstraint ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-14 22:08:05 +00:00
{
return NULL ;
}
*/
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_enableJointForceTorqueSensor ( PyObject * self , PyObject * args , PyObject * keywds )
2017-01-31 18:14:00 +00:00
{
int bodyUniqueId = - 1 ;
int jointIndex = - 1 ;
int enableSensor = 1 ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
int numJoints = - 1 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " jointIndex " , " enableSensor " , " physicsClientId " , NULL } ;
2017-01-31 18:14:00 +00:00
2017-03-13 23:06:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|ii " , kwlist , & bodyUniqueId , & jointIndex , & enableSensor , & physicsClientId ) )
2017-01-31 18:14:00 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
if ( bodyUniqueId < 0 )
{
PyErr_SetString ( SpamError , " Error: invalid bodyUniqueId " ) ;
return NULL ;
}
numJoints = b3GetNumJoints ( sm , bodyUniqueId ) ;
if ( ( jointIndex < 0 ) | | ( jointIndex > = numJoints ) )
{
PyErr_SetString ( SpamError , " Error: invalid jointIndex. " ) ;
return NULL ;
}
{
b3SharedMemoryCommandHandle commandHandle ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
commandHandle = b3CreateSensorCommandInit ( sm , bodyUniqueId ) ;
b3CreateSensorEnable6DofJointForceTorqueSensor ( commandHandle , jointIndex , enableSensor ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CLIENT_COMMAND_COMPLETED )
{
Py_INCREF ( Py_None ) ;
return Py_None ;
}
}
PyErr_SetString ( SpamError , " Error creating sensor. " ) ;
return NULL ;
}
2018-10-26 17:18:51 +00:00
static int extractVertices ( PyObject * verticesObj , double * vertices , int maxNumVertices )
{
int numVerticesOut = 0 ;
if ( verticesObj )
{
PyObject * seqVerticesObj = PySequence_Fast ( verticesObj , " expected a sequence of vertex positions " ) ;
if ( seqVerticesObj )
{
int numVerticesSrc = PySequence_Size ( seqVerticesObj ) ;
{
int i ;
if ( numVerticesSrc > B3_MAX_NUM_VERTICES )
{
PyErr_SetString ( SpamError , " Number of vertices exceeds the maximum. " ) ;
Py_DECREF ( seqVerticesObj ) ;
return 0 ;
}
for ( i = 0 ; i < numVerticesSrc ; i + + )
{
PyObject * vertexObj = PySequence_GetItem ( seqVerticesObj , i ) ;
double vertex [ 3 ] ;
if ( pybullet_internalSetVectord ( vertexObj , vertex ) )
{
vertices [ numVerticesOut * 3 + 0 ] = vertex [ 0 ] ;
vertices [ numVerticesOut * 3 + 1 ] = vertex [ 1 ] ;
vertices [ numVerticesOut * 3 + 2 ] = vertex [ 2 ] ;
numVerticesOut + + ;
}
}
}
}
}
return numVerticesOut ;
}
static int extractIndices ( PyObject * indicesObj , int * indices , int maxNumIndices )
{
int numIndicesOut = 0 ;
if ( indicesObj )
{
PyObject * seqIndicesObj = PySequence_Fast ( indicesObj , " expected a sequence of indices " ) ;
if ( seqIndicesObj )
{
int numIndicesSrc = PySequence_Size ( seqIndicesObj ) ;
{
int i ;
if ( numIndicesSrc > B3_MAX_NUM_INDICES )
{
PyErr_SetString ( SpamError , " Number of indices exceeds the maximum. " ) ;
Py_DECREF ( seqIndicesObj ) ;
return 0 ;
}
for ( i = 0 ; i < numIndicesSrc ; i + + )
{
int index = pybullet_internalGetIntFromSequence ( seqIndicesObj , i ) ;
indices [ numIndicesOut ] = index ;
numIndicesOut + + ;
}
}
}
}
return numIndicesOut ;
}
2017-06-03 17:57:56 +00:00
static PyObject * pybullet_createCollisionShape ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
int shapeType = - 1 ;
double radius = 0.5 ;
2017-06-19 17:14:26 +00:00
double height = 1 ;
2018-09-23 21:17:31 +00:00
PyObject * meshScaleObj = 0 ;
double meshScale [ 3 ] = { 1 , 1 , 1 } ;
PyObject * planeNormalObj = 0 ;
double planeNormal [ 3 ] = { 0 , 0 , 1 } ;
PyObject * collisionFramePositionObj = 0 ;
double collisionFramePosition [ 3 ] = { 0 , 0 , 0 } ;
PyObject * collisionFrameOrientationObj = 0 ;
double collisionFrameOrientation [ 4 ] = { 0 , 0 , 0 , 1 } ;
char * fileName = 0 ;
2017-06-19 17:14:26 +00:00
int flags = 0 ;
2018-09-23 21:17:31 +00:00
PyObject * halfExtentsObj = 0 ;
2018-10-26 17:18:51 +00:00
PyObject * verticesObj = 0 ;
PyObject * indicesObj = 0 ;
2017-06-03 17:57:56 +00:00
2018-10-26 17:18:51 +00:00
static char * kwlist [ ] = { " shapeType " , " radius " , " halfExtents " , " height " , " fileName " , " meshScale " , " planeNormal " , " flags " , " collisionFramePosition " , " collisionFrameOrientation " , " vertices " , " indices " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|dOdsOOiOOOOi " , kwlist ,
& shapeType , & radius , & halfExtentsObj , & height , & fileName , & meshScaleObj , & planeNormalObj , & flags , & collisionFramePositionObj , & collisionFrameOrientationObj , & verticesObj , & indicesObj , & physicsClientId ) )
2017-06-03 17:57:56 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-10-26 17:18:51 +00:00
2018-09-23 21:17:31 +00:00
if ( shapeType > = GEOM_SPHERE )
2017-06-03 17:57:56 +00:00
{
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2017-06-19 17:14:26 +00:00
int shapeIndex = - 1 ;
2017-06-03 17:57:56 +00:00
b3SharedMemoryCommandHandle commandHandle = b3CreateCollisionShapeCommandInit ( sm ) ;
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_SPHERE & & radius > 0 )
2017-06-03 17:57:56 +00:00
{
2018-09-23 21:17:31 +00:00
shapeIndex = b3CreateCollisionShapeAddSphere ( commandHandle , radius ) ;
2017-06-03 17:57:56 +00:00
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_BOX & & halfExtentsObj )
2017-06-03 17:57:56 +00:00
{
2018-09-23 21:17:31 +00:00
double halfExtents [ 3 ] = { 1 , 1 , 1 } ;
pybullet_internalSetVectord ( halfExtentsObj , halfExtents ) ;
shapeIndex = b3CreateCollisionShapeAddBox ( commandHandle , halfExtents ) ;
2017-06-19 17:14:26 +00:00
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_CAPSULE & & radius > 0 & & height > = 0 )
2017-06-19 17:14:26 +00:00
{
2018-09-23 21:17:31 +00:00
shapeIndex = b3CreateCollisionShapeAddCapsule ( commandHandle , radius , height ) ;
2017-06-19 17:14:26 +00:00
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_CYLINDER & & radius > 0 & & height > = 0 )
2017-06-19 17:14:26 +00:00
{
2018-09-23 21:17:31 +00:00
shapeIndex = b3CreateCollisionShapeAddCylinder ( commandHandle , radius , height ) ;
2017-06-19 17:14:26 +00:00
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_MESH & & fileName )
2017-06-19 17:14:26 +00:00
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVectord ( meshScaleObj , meshScale ) ;
shapeIndex = b3CreateCollisionShapeAddMesh ( commandHandle , fileName , meshScale ) ;
2017-06-19 17:14:26 +00:00
}
2018-10-26 17:18:51 +00:00
if ( shapeType = = GEOM_MESH & & verticesObj )
{
int numVertices = 0 ;
int numIndices = 0 ;
double vertices [ B3_MAX_NUM_VERTICES * 3 ] ;
int indices [ B3_MAX_NUM_INDICES ] ;
numVertices = extractVertices ( verticesObj , vertices , B3_MAX_NUM_VERTICES ) ;
pybullet_internalSetVectord ( meshScaleObj , meshScale ) ;
if ( indicesObj )
{
numIndices = extractIndices ( indicesObj , indices , B3_MAX_NUM_INDICES ) ;
}
if ( numIndices )
{
shapeIndex = b3CreateCollisionShapeAddConcaveMesh ( commandHandle , meshScale , vertices , numVertices , indices , numIndices ) ;
} else
{
shapeIndex = b3CreateCollisionShapeAddConvexMesh ( commandHandle , meshScale , vertices , numVertices ) ;
}
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_PLANE )
2017-06-19 17:14:26 +00:00
{
2018-09-23 21:17:31 +00:00
double planeConstant = 0 ;
pybullet_internalSetVectord ( planeNormalObj , planeNormal ) ;
2017-06-19 17:14:26 +00:00
shapeIndex = b3CreateCollisionShapeAddPlane ( commandHandle , planeNormal , planeConstant ) ;
}
2018-09-23 21:17:31 +00:00
if ( shapeIndex > = 0 & & flags )
2017-06-19 17:14:26 +00:00
{
2018-09-23 21:17:31 +00:00
b3CreateCollisionSetFlag ( commandHandle , shapeIndex , flags ) ;
2017-06-03 17:57:56 +00:00
}
2018-09-23 21:17:31 +00:00
if ( shapeIndex > = 0 )
2017-10-08 01:50:23 +00:00
{
if ( collisionFramePositionObj )
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVectord ( collisionFramePositionObj , collisionFramePosition ) ;
2017-10-08 01:50:23 +00:00
}
if ( collisionFrameOrientationObj )
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVector4d ( collisionFrameOrientationObj , collisionFrameOrientation ) ;
2017-10-08 01:50:23 +00:00
}
2018-10-31 05:16:13 +00:00
b3CreateCollisionShapeSetChildTransform ( commandHandle , shapeIndex , collisionFramePosition , collisionFrameOrientation ) ;
2017-10-08 01:50:23 +00:00
}
2017-06-03 17:57:56 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CREATE_COLLISION_SHAPE_COMPLETED )
{
int uid = b3GetStatusCollisionShapeUniqueId ( statusHandle ) ;
PyObject * ob = PyLong_FromLong ( uid ) ;
return ob ;
}
}
PyErr_SetString ( SpamError , " createCollisionShape failed. " ) ;
return NULL ;
}
2018-01-08 20:25:56 +00:00
static PyObject * pybullet_createCollisionShapeArray ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
PyObject * shapeTypeArray = 0 ;
PyObject * radiusArray = 0 ;
PyObject * halfExtentsObjArray = 0 ;
PyObject * lengthArray = 0 ;
PyObject * fileNameArray = 0 ;
PyObject * meshScaleObjArray = 0 ;
PyObject * planeNormalObjArray = 0 ;
PyObject * flagsArray = 0 ;
PyObject * collisionFramePositionObjArray = 0 ;
PyObject * collisionFrameOrientationObjArray = 0 ;
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " shapeTypes " , " radii " , " halfExtents " , " lengths " , " fileNames " , " meshScales " , " planeNormals " ,
" flags " , " collisionFramePositions " , " collisionFrameOrientations " , " physicsClientId " , NULL } ;
2018-01-08 20:25:56 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " O|OOOOOOOOOi " , kwlist ,
2018-09-23 21:17:31 +00:00
& shapeTypeArray , & radiusArray , & halfExtentsObjArray , & lengthArray , & fileNameArray , & meshScaleObjArray , & planeNormalObjArray , & flagsArray , & collisionFramePositionObjArray , & collisionFrameOrientationObjArray , & physicsClientId ) )
2018-01-08 20:25:56 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
2018-01-09 16:43:00 +00:00
b3SharedMemoryCommandHandle commandHandle = b3CreateCollisionShapeCommandInit ( sm ) ;
2018-01-08 20:25:56 +00:00
int numShapeTypes = 0 ;
int numRadius = 0 ;
int numHalfExtents = 0 ;
int numLengths = 0 ;
int numFileNames = 0 ;
int numMeshScales = 0 ;
int numPlaneNormals = 0 ;
int numFlags = 0 ;
int numPositions = 0 ;
int numOrientations = 0 ;
int s ;
2018-09-23 21:17:31 +00:00
PyObject * shapeTypeArraySeq = shapeTypeArray ? PySequence_Fast ( shapeTypeArray , " expected a sequence of shape types " ) : 0 ;
PyObject * radiusArraySeq = radiusArray ? PySequence_Fast ( radiusArray , " expected a sequence of radii " ) : 0 ;
PyObject * halfExtentsArraySeq = halfExtentsObjArray ? PySequence_Fast ( halfExtentsObjArray , " expected a sequence of half extents " ) : 0 ;
PyObject * lengthArraySeq = lengthArray ? PySequence_Fast ( lengthArray , " expected a sequence of lengths " ) : 0 ;
PyObject * fileNameArraySeq = fileNameArray ? PySequence_Fast ( fileNameArray , " expected a sequence of filename " ) : 0 ;
PyObject * meshScaleArraySeq = meshScaleObjArray ? PySequence_Fast ( meshScaleObjArray , " expected a sequence of mesh scale " ) : 0 ;
PyObject * planeNormalArraySeq = planeNormalObjArray ? PySequence_Fast ( planeNormalObjArray , " expected a sequence of plane normal " ) : 0 ;
PyObject * flagsArraySeq = flagsArray ? PySequence_Fast ( flagsArray , " expected a sequence of flags " ) : 0 ;
PyObject * positionArraySeq = collisionFramePositionObjArray ? PySequence_Fast ( collisionFramePositionObjArray , " expected a sequence of collision frame positions " ) : 0 ;
PyObject * orientationArraySeq = collisionFrameOrientationObjArray ? PySequence_Fast ( collisionFrameOrientationObjArray , " expected a sequence of collision frame orientations " ) : 0 ;
2018-01-08 20:25:56 +00:00
if ( shapeTypeArraySeq = = 0 )
{
PyErr_SetString ( SpamError , " expected a sequence of shape types " ) ;
return NULL ;
}
2018-09-23 21:17:31 +00:00
numShapeTypes = shapeTypeArray ? PySequence_Size ( shapeTypeArray ) : 0 ;
numRadius = radiusArraySeq ? PySequence_Size ( radiusArraySeq ) : 0 ;
numHalfExtents = halfExtentsArraySeq ? PySequence_Size ( halfExtentsArraySeq ) : 0 ;
numLengths = lengthArraySeq ? PySequence_Size ( lengthArraySeq ) : 0 ;
numFileNames = fileNameArraySeq ? PySequence_Size ( fileNameArraySeq ) : 0 ;
numMeshScales = meshScaleArraySeq ? PySequence_Size ( meshScaleArraySeq ) : 0 ;
numPlaneNormals = planeNormalArraySeq ? PySequence_Size ( planeNormalArraySeq ) : 0 ;
2018-01-08 20:25:56 +00:00
2018-09-23 21:17:31 +00:00
for ( s = 0 ; s < numShapeTypes ; s + + )
2018-01-08 20:25:56 +00:00
{
int shapeType = pybullet_internalGetIntFromSequence ( shapeTypeArraySeq , s ) ;
if ( shapeType > = GEOM_SPHERE )
{
int shapeIndex = - 1 ;
if ( shapeType = = GEOM_SPHERE & & s < = numRadius )
{
double radius = pybullet_internalGetFloatFromSequence ( radiusArraySeq , s ) ;
if ( radius > 0 )
{
shapeIndex = b3CreateCollisionShapeAddSphere ( commandHandle , radius ) ;
}
}
if ( shapeType = = GEOM_BOX )
{
PyObject * halfExtentsObj = 0 ;
2018-09-23 21:17:31 +00:00
double halfExtents [ 3 ] = { 1 , 1 , 1 } ;
2018-01-08 20:25:56 +00:00
2018-09-23 21:17:31 +00:00
if ( halfExtentsArraySeq & & s < = numHalfExtents )
2018-01-08 20:25:56 +00:00
{
if ( PyList_Check ( halfExtentsArraySeq ) )
{
halfExtentsObj = PyList_GET_ITEM ( halfExtentsArraySeq , s ) ;
}
else
{
halfExtentsObj = PyTuple_GET_ITEM ( halfExtentsArraySeq , s ) ;
}
}
pybullet_internalSetVectord ( halfExtentsObj , halfExtents ) ;
shapeIndex = b3CreateCollisionShapeAddBox ( commandHandle , halfExtents ) ;
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_CAPSULE & & s < = numRadius )
2018-01-08 20:25:56 +00:00
{
double radius = pybullet_internalGetFloatFromSequence ( radiusArraySeq , s ) ;
double height = pybullet_internalGetFloatFromSequence ( lengthArraySeq , s ) ;
if ( radius > 0 & & height > = 0 )
{
shapeIndex = b3CreateCollisionShapeAddCapsule ( commandHandle , radius , height ) ;
}
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_CYLINDER & & s < = numRadius & & s < numLengths )
2018-01-08 20:25:56 +00:00
{
double radius = pybullet_internalGetFloatFromSequence ( radiusArraySeq , s ) ;
double height = pybullet_internalGetFloatFromSequence ( lengthArraySeq , s ) ;
if ( radius > 0 & & height > = 0 )
{
shapeIndex = b3CreateCollisionShapeAddCylinder ( commandHandle , radius , height ) ;
}
}
if ( shapeType = = GEOM_MESH )
{
2018-09-23 21:17:31 +00:00
double meshScale [ 3 ] = { 1 , 1 , 1 } ;
2018-01-08 20:25:56 +00:00
2018-09-23 21:17:31 +00:00
PyObject * meshScaleObj = meshScaleArraySeq ? PyList_GET_ITEM ( meshScaleArraySeq , s ) : 0 ;
PyObject * fileNameObj = fileNameArraySeq ? PyList_GET_ITEM ( fileNameArraySeq , s ) : 0 ;
2018-01-08 20:25:56 +00:00
const char * fileName = 0 ;
if ( fileNameObj )
{
# if PY_MAJOR_VERSION >= 3
PyObject * ob = PyUnicode_AsASCIIString ( fileNameObj ) ;
fileName = PyBytes_AS_STRING ( ob ) ;
# else
2018-01-09 00:15:54 +00:00
fileName = PyString_AsString ( fileNameObj ) ;
2018-01-08 20:25:56 +00:00
# endif
}
if ( meshScaleObj )
{
pybullet_internalSetVectord ( meshScaleObj , meshScale ) ;
}
if ( fileName )
{
shapeIndex = b3CreateCollisionShapeAddMesh ( commandHandle , fileName , meshScale ) ;
}
}
if ( shapeType = = GEOM_PLANE )
{
2018-09-23 21:17:31 +00:00
PyObject * planeNormalObj = planeNormalArraySeq ? PyList_GET_ITEM ( planeNormalArraySeq , s ) : 0 ;
2018-01-08 20:25:56 +00:00
double planeNormal [ 3 ] ;
double planeConstant = 0 ;
pybullet_internalSetVectord ( planeNormalObj , planeNormal ) ;
shapeIndex = b3CreateCollisionShapeAddPlane ( commandHandle , planeNormal , planeConstant ) ;
}
if ( flagsArraySeq )
{
int flags = pybullet_internalGetIntFromSequence ( flagsArraySeq , s ) ;
b3CreateCollisionSetFlag ( commandHandle , shapeIndex , flags ) ;
}
if ( positionArraySeq | | orientationArraySeq )
{
2018-09-23 21:17:31 +00:00
PyObject * collisionFramePositionObj = positionArraySeq ? PyList_GET_ITEM ( positionArraySeq , s ) : 0 ;
PyObject * collisionFrameOrientationObj = orientationArraySeq ? PyList_GET_ITEM ( orientationArraySeq , s ) : 0 ;
double collisionFramePosition [ 3 ] = { 0 , 0 , 0 } ;
double collisionFrameOrientation [ 4 ] = { 0 , 0 , 0 , 1 } ;
2018-01-08 20:25:56 +00:00
if ( collisionFramePositionObj )
{
pybullet_internalSetVectord ( collisionFramePositionObj , collisionFramePosition ) ;
}
if ( collisionFrameOrientationObj )
{
pybullet_internalSetVector4d ( collisionFrameOrientationObj , collisionFrameOrientation ) ;
}
if ( shapeIndex > = 0 )
{
b3CreateCollisionShapeSetChildTransform ( commandHandle , shapeIndex , collisionFramePosition , collisionFrameOrientation ) ;
}
}
}
}
if ( shapeTypeArraySeq )
Py_DECREF ( shapeTypeArraySeq ) ;
if ( radiusArraySeq )
Py_DECREF ( radiusArraySeq ) ;
if ( halfExtentsArraySeq )
Py_DECREF ( halfExtentsArraySeq ) ;
if ( lengthArraySeq )
Py_DECREF ( lengthArraySeq ) ;
if ( fileNameArraySeq )
Py_DECREF ( fileNameArraySeq ) ;
if ( meshScaleArraySeq )
Py_DECREF ( meshScaleArraySeq ) ;
if ( planeNormalArraySeq )
Py_DECREF ( planeNormalArraySeq ) ;
if ( flagsArraySeq )
Py_DECREF ( flagsArraySeq ) ;
if ( positionArraySeq )
Py_DECREF ( positionArraySeq ) ;
if ( orientationArraySeq )
Py_DECREF ( orientationArraySeq ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CREATE_COLLISION_SHAPE_COMPLETED )
{
int uid = b3GetStatusCollisionShapeUniqueId ( statusHandle ) ;
PyObject * ob = PyLong_FromLong ( uid ) ;
return ob ;
}
}
PyErr_SetString ( SpamError , " createCollisionShapeArray failed. " ) ;
return NULL ;
}
2017-06-03 17:57:56 +00:00
static PyObject * pybullet_createVisualShape ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
int shapeType = - 1 ;
double radius = 0.5 ;
2018-01-08 20:25:56 +00:00
double length = 1 ;
2018-09-23 21:17:31 +00:00
PyObject * meshScaleObj = 0 ;
double meshScale [ 3 ] = { 1 , 1 , 1 } ;
PyObject * planeNormalObj = 0 ;
double planeNormal [ 3 ] = { 0 , 0 , 1 } ;
2017-10-08 01:50:23 +00:00
2018-09-23 21:17:31 +00:00
PyObject * rgbaColorObj = 0 ;
double rgbaColor [ 4 ] = { 1 , 1 , 1 , 1 } ;
2017-10-08 01:50:23 +00:00
2018-09-23 21:17:31 +00:00
PyObject * specularColorObj = 0 ;
double specularColor [ 3 ] = { 1 , 1 , 1 } ;
2017-10-08 01:50:23 +00:00
2018-09-23 21:17:31 +00:00
char * fileName = 0 ;
2017-10-08 01:50:23 +00:00
int flags = 0 ;
2018-09-23 21:17:31 +00:00
PyObject * visualFramePositionObj = 0 ;
double visualFramePosition [ 3 ] = { 0 , 0 , 0 } ;
PyObject * visualFrameOrientationObj = 0 ;
double visualFrameOrientation [ 4 ] = { 0 , 0 , 0 , 1 } ;
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
PyObject * halfExtentsObj = 0 ;
2017-10-08 01:50:23 +00:00
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " shapeType " , " radius " , " halfExtents " , " length " , " fileName " , " meshScale " , " planeNormal " , " flags " , " rgbaColor " , " specularColor " , " visualFramePosition " , " visualFrameOrientation " , " physicsClientId " , NULL } ;
2018-09-11 20:24:35 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|dOdsOOiOOOOi " , kwlist ,
2018-09-23 21:17:31 +00:00
& shapeType , & radius , & halfExtentsObj , & length , & fileName , & meshScaleObj , & planeNormalObj , & flags , & rgbaColorObj , & specularColorObj , & visualFramePositionObj , & visualFrameOrientationObj , & physicsClientId ) )
2017-06-03 17:57:56 +00:00
{
return NULL ;
}
2017-10-08 01:50:23 +00:00
2017-06-03 17:57:56 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
if ( shapeType > = GEOM_SPHERE )
2017-06-03 17:57:56 +00:00
{
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
b3SharedMemoryCommandHandle commandHandle = b3CreateVisualShapeCommandInit ( sm ) ;
2017-10-08 01:50:23 +00:00
int shapeIndex = - 1 ;
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_SPHERE & & radius > 0 )
2017-10-08 01:50:23 +00:00
{
2018-09-23 21:17:31 +00:00
shapeIndex = b3CreateVisualShapeAddSphere ( commandHandle , radius ) ;
2017-10-08 01:50:23 +00:00
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_BOX & & halfExtentsObj )
2017-10-08 01:50:23 +00:00
{
2018-09-23 21:17:31 +00:00
double halfExtents [ 3 ] = { 1 , 1 , 1 } ;
pybullet_internalSetVectord ( halfExtentsObj , halfExtents ) ;
shapeIndex = b3CreateVisualShapeAddBox ( commandHandle , halfExtents ) ;
2017-10-08 01:50:23 +00:00
}
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_CAPSULE & & radius > 0 & & length > = 0 )
2017-10-08 01:50:23 +00:00
{
2018-09-23 21:17:31 +00:00
shapeIndex = b3CreateVisualShapeAddCapsule ( commandHandle , radius , length ) ;
2017-10-08 01:50:23 +00:00
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_CYLINDER & & radius > 0 & & length > = 0 )
2017-10-08 01:50:23 +00:00
{
2018-09-23 21:17:31 +00:00
shapeIndex = b3CreateVisualShapeAddCylinder ( commandHandle , radius , length ) ;
2017-10-08 01:50:23 +00:00
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_MESH & & fileName )
2017-10-08 01:50:23 +00:00
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVectord ( meshScaleObj , meshScale ) ;
shapeIndex = b3CreateVisualShapeAddMesh ( commandHandle , fileName , meshScale ) ;
2017-10-08 01:50:23 +00:00
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_PLANE )
2017-10-08 01:50:23 +00:00
{
2018-09-23 21:17:31 +00:00
double planeConstant = 0 ;
pybullet_internalSetVectord ( planeNormalObj , planeNormal ) ;
2017-10-08 01:50:23 +00:00
shapeIndex = b3CreateVisualShapeAddPlane ( commandHandle , planeNormal , planeConstant ) ;
}
2018-09-23 21:17:31 +00:00
if ( shapeIndex > = 0 & & flags )
2017-10-08 01:50:23 +00:00
{
2018-09-23 21:17:31 +00:00
b3CreateVisualSetFlag ( commandHandle , shapeIndex , flags ) ;
2017-10-08 01:50:23 +00:00
}
2018-09-23 21:17:31 +00:00
if ( shapeIndex > = 0 )
2017-10-08 01:50:23 +00:00
{
2018-09-23 21:17:31 +00:00
double rgbaColor [ 4 ] = { 1 , 1 , 1 , 1 } ;
double specularColor [ 3 ] = { 1 , 1 , 1 } ;
2018-03-15 03:47:56 +00:00
if ( rgbaColorObj )
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVector4d ( rgbaColorObj , rgbaColor ) ;
2018-03-15 03:47:56 +00:00
}
2018-09-23 21:17:31 +00:00
b3CreateVisualShapeSetRGBAColor ( commandHandle , shapeIndex , rgbaColor ) ;
2017-10-08 01:50:23 +00:00
2018-03-15 03:47:56 +00:00
if ( specularColorObj )
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVectord ( specularColorObj , specularColor ) ;
2018-03-15 03:47:56 +00:00
}
2018-09-23 21:17:31 +00:00
b3CreateVisualShapeSetSpecularColor ( commandHandle , shapeIndex , specularColor ) ;
2017-10-08 01:50:23 +00:00
if ( visualFramePositionObj )
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVectord ( visualFramePositionObj , visualFramePosition ) ;
2017-10-08 01:50:23 +00:00
}
2018-03-15 03:47:56 +00:00
2017-10-08 01:50:23 +00:00
if ( visualFrameOrientationObj )
{
2018-09-23 21:17:31 +00:00
pybullet_internalSetVector4d ( visualFrameOrientationObj , visualFrameOrientation ) ;
2017-10-08 01:50:23 +00:00
}
2018-09-23 21:17:31 +00:00
b3CreateVisualShapeSetChildTransform ( commandHandle , shapeIndex , visualFramePosition , visualFrameOrientation ) ;
2018-03-15 03:47:56 +00:00
}
2018-09-11 20:24:35 +00:00
2017-06-03 17:57:56 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CREATE_VISUAL_SHAPE_COMPLETED )
{
int uid = b3GetStatusVisualShapeUniqueId ( statusHandle ) ;
PyObject * ob = PyLong_FromLong ( uid ) ;
return ob ;
}
}
PyErr_SetString ( SpamError , " createVisualShape failed. " ) ;
return NULL ;
}
2018-03-10 02:02:06 +00:00
static PyObject * pybullet_createVisualShapeArray ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
PyObject * shapeTypeArray = 0 ;
PyObject * radiusArray = 0 ;
PyObject * halfExtentsObjArray = 0 ;
PyObject * lengthArray = 0 ;
PyObject * fileNameArray = 0 ;
PyObject * meshScaleObjArray = 0 ;
PyObject * planeNormalObjArray = 0 ;
2018-09-23 21:17:31 +00:00
PyObject * rgbaColorArray = 0 ;
2018-03-10 02:02:06 +00:00
PyObject * flagsArray = 0 ;
PyObject * visualFramePositionObjArray = 0 ;
PyObject * visualFrameOrientationObjArray = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " shapeTypes " , " radii " , " halfExtents " , " lengths " , " fileNames " , " meshScales " , " planeNormals " ,
" flags " , " rgbaColors " , " visualFramePositions " , " visualFrameOrientations " , " physicsClientId " , NULL } ;
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " O|OOOOOOOOOOi " , kwlist ,
& shapeTypeArray , & radiusArray , & halfExtentsObjArray , & lengthArray , & fileNameArray , & meshScaleObjArray , & planeNormalObjArray , & flagsArray , & rgbaColorArray , & visualFramePositionObjArray , & visualFrameOrientationObjArray , & physicsClientId ) )
2018-03-10 02:02:06 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2018-03-15 03:47:56 +00:00
2018-03-10 02:02:06 +00:00
{
b3SharedMemoryCommandHandle commandHandle = b3CreateVisualShapeCommandInit ( sm ) ;
int numShapeTypes = 0 ;
int numRadius = 0 ;
int numHalfExtents = 0 ;
int numLengths = 0 ;
int numFileNames = 0 ;
int numMeshScales = 0 ;
int numPlaneNormals = 0 ;
2018-09-23 21:17:31 +00:00
int numRGBAColors = 0 ;
2018-03-10 02:02:06 +00:00
int numFlags = 0 ;
int numPositions = 0 ;
int numOrientations = 0 ;
int s ;
PyObject * shapeTypeArraySeq = shapeTypeArray ? PySequence_Fast ( shapeTypeArray , " expected a sequence of shape types " ) : 0 ;
PyObject * radiusArraySeq = radiusArray ? PySequence_Fast ( radiusArray , " expected a sequence of radii " ) : 0 ;
PyObject * halfExtentsArraySeq = halfExtentsObjArray ? PySequence_Fast ( halfExtentsObjArray , " expected a sequence of half extents " ) : 0 ;
PyObject * lengthArraySeq = lengthArray ? PySequence_Fast ( lengthArray , " expected a sequence of lengths " ) : 0 ;
PyObject * fileNameArraySeq = fileNameArray ? PySequence_Fast ( fileNameArray , " expected a sequence of filename " ) : 0 ;
PyObject * meshScaleArraySeq = meshScaleObjArray ? PySequence_Fast ( meshScaleObjArray , " expected a sequence of mesh scale " ) : 0 ;
PyObject * planeNormalArraySeq = planeNormalObjArray ? PySequence_Fast ( planeNormalObjArray , " expected a sequence of plane normal " ) : 0 ;
2018-09-23 21:17:31 +00:00
PyObject * rgbaColorArraySeq = rgbaColorArray ? PySequence_Fast ( rgbaColorArray , " expected a sequence of rgba color " ) : 0 ;
2018-03-10 02:02:06 +00:00
PyObject * flagsArraySeq = flagsArray ? PySequence_Fast ( flagsArray , " expected a sequence of flags " ) : 0 ;
PyObject * positionArraySeq = visualFramePositionObjArray ? PySequence_Fast ( visualFramePositionObjArray , " expected a sequence of visual frame positions " ) : 0 ;
PyObject * orientationArraySeq = visualFrameOrientationObjArray ? PySequence_Fast ( visualFrameOrientationObjArray , " expected a sequence of visual frame orientations " ) : 0 ;
if ( shapeTypeArraySeq = = 0 )
{
PyErr_SetString ( SpamError , " expected a sequence of shape types " ) ;
return NULL ;
}
numShapeTypes = shapeTypeArray ? PySequence_Size ( shapeTypeArray ) : 0 ;
numRadius = radiusArraySeq ? PySequence_Size ( radiusArraySeq ) : 0 ;
numHalfExtents = halfExtentsArraySeq ? PySequence_Size ( halfExtentsArraySeq ) : 0 ;
numLengths = lengthArraySeq ? PySequence_Size ( lengthArraySeq ) : 0 ;
numFileNames = fileNameArraySeq ? PySequence_Size ( fileNameArraySeq ) : 0 ;
numMeshScales = meshScaleArraySeq ? PySequence_Size ( meshScaleArraySeq ) : 0 ;
numPlaneNormals = planeNormalArraySeq ? PySequence_Size ( planeNormalArraySeq ) : 0 ;
2018-09-23 21:17:31 +00:00
numRGBAColors = rgbaColorArraySeq ? PySequence_Size ( rgbaColorArraySeq ) : 0 ;
2018-03-10 02:02:06 +00:00
2018-09-23 21:17:31 +00:00
for ( s = 0 ; s < numShapeTypes ; s + + )
2018-03-10 02:02:06 +00:00
{
int shapeType = pybullet_internalGetIntFromSequence ( shapeTypeArraySeq , s ) ;
if ( shapeType > = GEOM_SPHERE )
{
int shapeIndex = - 1 ;
if ( shapeType = = GEOM_SPHERE & & s < = numRadius )
{
double radius = pybullet_internalGetFloatFromSequence ( radiusArraySeq , s ) ;
if ( radius > 0 )
{
shapeIndex = b3CreateVisualShapeAddSphere ( commandHandle , radius ) ;
}
}
if ( shapeType = = GEOM_BOX )
{
PyObject * halfExtentsObj = 0 ;
2018-09-23 21:17:31 +00:00
double halfExtents [ 3 ] = { 1 , 1 , 1 } ;
2018-03-10 02:02:06 +00:00
if ( halfExtentsArraySeq & & s < = numHalfExtents )
{
if ( PyList_Check ( halfExtentsArraySeq ) )
{
halfExtentsObj = PyList_GET_ITEM ( halfExtentsArraySeq , s ) ;
}
else
{
halfExtentsObj = PyTuple_GET_ITEM ( halfExtentsArraySeq , s ) ;
}
}
pybullet_internalSetVectord ( halfExtentsObj , halfExtents ) ;
shapeIndex = b3CreateVisualShapeAddBox ( commandHandle , halfExtents ) ;
}
if ( shapeType = = GEOM_CAPSULE & & s < = numRadius )
{
double radius = pybullet_internalGetFloatFromSequence ( radiusArraySeq , s ) ;
double height = pybullet_internalGetFloatFromSequence ( lengthArraySeq , s ) ;
if ( radius > 0 & & height > = 0 )
{
shapeIndex = b3CreateVisualShapeAddCapsule ( commandHandle , radius , height ) ;
}
}
2018-09-23 21:17:31 +00:00
if ( shapeType = = GEOM_CYLINDER & & s < = numRadius & & s < numLengths )
2018-03-10 02:02:06 +00:00
{
double radius = pybullet_internalGetFloatFromSequence ( radiusArraySeq , s ) ;
double height = pybullet_internalGetFloatFromSequence ( lengthArraySeq , s ) ;
if ( radius > 0 & & height > = 0 )
{
shapeIndex = b3CreateVisualShapeAddCylinder ( commandHandle , radius , height ) ;
}
}
if ( shapeType = = GEOM_MESH )
{
2018-09-23 21:17:31 +00:00
double meshScale [ 3 ] = { 1 , 1 , 1 } ;
2018-03-10 02:02:06 +00:00
PyObject * meshScaleObj = meshScaleArraySeq ? PyList_GET_ITEM ( meshScaleArraySeq , s ) : 0 ;
PyObject * fileNameObj = fileNameArraySeq ? PyList_GET_ITEM ( fileNameArraySeq , s ) : 0 ;
const char * fileName = 0 ;
if ( fileNameObj )
{
# if PY_MAJOR_VERSION >= 3
PyObject * ob = PyUnicode_AsASCIIString ( fileNameObj ) ;
fileName = PyBytes_AS_STRING ( ob ) ;
# else
fileName = PyString_AsString ( fileNameObj ) ;
# endif
}
if ( meshScaleObj )
{
pybullet_internalSetVectord ( meshScaleObj , meshScale ) ;
}
if ( fileName )
{
shapeIndex = b3CreateVisualShapeAddMesh ( commandHandle , fileName , meshScale ) ;
}
}
if ( shapeType = = GEOM_PLANE )
{
PyObject * planeNormalObj = planeNormalArraySeq ? PyList_GET_ITEM ( planeNormalArraySeq , s ) : 0 ;
double planeNormal [ 3 ] ;
double planeConstant = 0 ;
pybullet_internalSetVectord ( planeNormalObj , planeNormal ) ;
shapeIndex = b3CreateVisualShapeAddPlane ( commandHandle , planeNormal , planeConstant ) ;
}
if ( flagsArraySeq )
{
int flags = pybullet_internalGetIntFromSequence ( flagsArraySeq , s ) ;
b3CreateVisualSetFlag ( commandHandle , shapeIndex , flags ) ;
}
2018-09-23 21:17:31 +00:00
if ( rgbaColorArraySeq )
{
PyObject * rgbaColorObj = rgbaColorArraySeq ? PyList_GET_ITEM ( rgbaColorArraySeq , s ) : 0 ;
double rgbaColor [ 4 ] = { 1 , 1 , 1 , 1 } ;
if ( rgbaColorObj )
{
pybullet_internalSetVector4d ( rgbaColorObj , rgbaColor ) ;
}
b3CreateVisualShapeSetRGBAColor ( commandHandle , shapeIndex , rgbaColor ) ;
}
2018-03-10 02:02:06 +00:00
if ( positionArraySeq | | orientationArraySeq )
{
PyObject * visualFramePositionObj = positionArraySeq ? PyList_GET_ITEM ( positionArraySeq , s ) : 0 ;
PyObject * visualFrameOrientationObj = orientationArraySeq ? PyList_GET_ITEM ( orientationArraySeq , s ) : 0 ;
2018-09-23 21:17:31 +00:00
double visualFramePosition [ 3 ] = { 0 , 0 , 0 } ;
double visualFrameOrientation [ 4 ] = { 0 , 0 , 0 , 1 } ;
2018-03-10 02:02:06 +00:00
if ( visualFramePositionObj )
{
pybullet_internalSetVectord ( visualFramePositionObj , visualFramePosition ) ;
}
if ( visualFrameOrientationObj )
{
pybullet_internalSetVector4d ( visualFrameOrientationObj , visualFrameOrientation ) ;
}
if ( shapeIndex > = 0 )
{
b3CreateVisualShapeSetChildTransform ( commandHandle , shapeIndex , visualFramePosition , visualFrameOrientation ) ;
}
}
}
}
if ( shapeTypeArraySeq )
Py_DECREF ( shapeTypeArraySeq ) ;
if ( radiusArraySeq )
Py_DECREF ( radiusArraySeq ) ;
if ( halfExtentsArraySeq )
Py_DECREF ( halfExtentsArraySeq ) ;
if ( lengthArraySeq )
Py_DECREF ( lengthArraySeq ) ;
if ( fileNameArraySeq )
Py_DECREF ( fileNameArraySeq ) ;
if ( meshScaleArraySeq )
Py_DECREF ( meshScaleArraySeq ) ;
if ( planeNormalArraySeq )
Py_DECREF ( planeNormalArraySeq ) ;
2018-09-23 21:17:31 +00:00
if ( rgbaColorArraySeq )
Py_DECREF ( rgbaColorArraySeq ) ;
2018-03-10 02:02:06 +00:00
if ( flagsArraySeq )
Py_DECREF ( flagsArraySeq ) ;
if ( positionArraySeq )
Py_DECREF ( positionArraySeq ) ;
if ( orientationArraySeq )
Py_DECREF ( orientationArraySeq ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CREATE_VISUAL_SHAPE_COMPLETED )
{
int uid = b3GetStatusVisualShapeUniqueId ( statusHandle ) ;
PyObject * ob = PyLong_FromLong ( uid ) ;
return ob ;
}
}
PyErr_SetString ( SpamError , " createVisualShapeArray failed. " ) ;
return NULL ;
}
2017-06-03 17:57:56 +00:00
static PyObject * pybullet_createMultiBody ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
double baseMass = 0 ;
2018-09-23 21:17:31 +00:00
int baseCollisionShapeIndex = - 1 ;
int baseVisualShapeIndex = - 1 ;
2017-06-05 05:04:16 +00:00
int useMaximalCoordinates = 0 ;
2018-06-02 18:37:14 +00:00
int flags = - 1 ;
2018-09-23 21:17:31 +00:00
PyObject * basePosObj = 0 ;
PyObject * baseOrnObj = 0 ;
PyObject * baseInertialFramePositionObj = 0 ;
PyObject * baseInertialFrameOrientationObj = 0 ;
PyObject * linkMassesObj = 0 ;
PyObject * linkCollisionShapeIndicesObj = 0 ;
PyObject * linkVisualShapeIndicesObj = 0 ;
PyObject * linkPositionsObj = 0 ;
PyObject * linkOrientationsObj = 0 ;
PyObject * linkParentIndicesObj = 0 ;
PyObject * linkJointTypesObj = 0 ;
PyObject * linkJointAxisObj = 0 ;
PyObject * linkInertialFramePositionObj = 0 ;
PyObject * linkInertialFrameOrientationObj = 0 ;
2018-09-11 20:24:35 +00:00
2018-06-02 18:37:14 +00:00
static char * kwlist [ ] = {
2018-09-23 21:17:31 +00:00
" baseMass " , " baseCollisionShapeIndex " , " baseVisualShapeIndex " , " basePosition " , " baseOrientation " ,
" baseInertialFramePosition " , " baseInertialFrameOrientation " , " linkMasses " , " linkCollisionShapeIndices " ,
" linkVisualShapeIndices " , " linkPositions " , " linkOrientations " , " linkInertialFramePositions " , " linkInertialFrameOrientations " , " linkParentIndices " ,
" linkJointTypes " , " linkJointAxis " , " useMaximalCoordinates " , " flags " , " physicsClientId " , NULL } ;
2017-06-03 17:57:56 +00:00
2018-09-11 20:24:35 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |diiOOOOOOOOOOOOOOiii " , kwlist ,
2018-09-23 21:17:31 +00:00
& baseMass , & baseCollisionShapeIndex , & baseVisualShapeIndex , & basePosObj , & baseOrnObj ,
& baseInertialFramePositionObj , & baseInertialFrameOrientationObj , & linkMassesObj , & linkCollisionShapeIndicesObj ,
& linkVisualShapeIndicesObj , & linkPositionsObj , & linkOrientationsObj , & linkInertialFramePositionObj , & linkInertialFrameOrientationObj , & linkParentIndicesObj ,
& linkJointTypesObj , & linkJointAxisObj , & useMaximalCoordinates , & flags , & physicsClientId ) )
2017-06-03 17:57:56 +00:00
{
return NULL ;
}
2018-06-02 18:37:14 +00:00
2017-06-03 17:57:56 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
2018-09-23 21:17:31 +00:00
int numLinkMasses = linkMassesObj ? PySequence_Size ( linkMassesObj ) : 0 ;
int numLinkCollisionShapes = linkCollisionShapeIndicesObj ? PySequence_Size ( linkCollisionShapeIndicesObj ) : 0 ;
int numLinkVisualShapes = linkVisualShapeIndicesObj ? PySequence_Size ( linkVisualShapeIndicesObj ) : 0 ;
int numLinkPositions = linkPositionsObj ? PySequence_Size ( linkPositionsObj ) : 0 ;
int numLinkOrientations = linkOrientationsObj ? PySequence_Size ( linkOrientationsObj ) : 0 ;
int numLinkParentIndices = linkParentIndicesObj ? PySequence_Size ( linkParentIndicesObj ) : 0 ;
int numLinkJointTypes = linkJointTypesObj ? PySequence_Size ( linkJointTypesObj ) : 0 ;
int numLinkJoinAxis = linkJointAxisObj ? PySequence_Size ( linkJointAxisObj ) : 0 ;
int numLinkInertialFramePositions = linkInertialFramePositionObj ? PySequence_Size ( linkInertialFramePositionObj ) : 0 ;
int numLinkInertialFrameOrientations = linkInertialFrameOrientationObj ? PySequence_Size ( linkInertialFrameOrientationObj ) : 0 ;
PyObject * seqLinkMasses = linkMassesObj ? PySequence_Fast ( linkMassesObj , " expected a sequence " ) : 0 ;
PyObject * seqLinkCollisionShapes = linkCollisionShapeIndicesObj ? PySequence_Fast ( linkCollisionShapeIndicesObj , " expected a sequence " ) : 0 ;
PyObject * seqLinkVisualShapes = linkVisualShapeIndicesObj ? PySequence_Fast ( linkVisualShapeIndicesObj , " expected a sequence " ) : 0 ;
PyObject * seqLinkPositions = linkPositionsObj ? PySequence_Fast ( linkPositionsObj , " expected a sequence " ) : 0 ;
PyObject * seqLinkOrientations = linkOrientationsObj ? PySequence_Fast ( linkOrientationsObj , " expected a sequence " ) : 0 ;
PyObject * seqLinkParentIndices = linkParentIndicesObj ? PySequence_Fast ( linkParentIndicesObj , " expected a sequence " ) : 0 ;
PyObject * seqLinkJointTypes = linkJointTypesObj ? PySequence_Fast ( linkJointTypesObj , " expected a sequence " ) : 0 ;
PyObject * seqLinkJoinAxis = linkJointAxisObj ? PySequence_Fast ( linkJointAxisObj , " expected a sequence " ) : 0 ;
PyObject * seqLinkInertialFramePositions = linkInertialFramePositionObj ? PySequence_Fast ( linkInertialFramePositionObj , " expected a sequence " ) : 0 ;
PyObject * seqLinkInertialFrameOrientations = linkInertialFrameOrientationObj ? PySequence_Fast ( linkInertialFrameOrientationObj , " expected a sequence " ) : 0 ;
if ( ( numLinkMasses = = numLinkCollisionShapes ) & &
( numLinkMasses = = numLinkVisualShapes ) & &
( numLinkMasses = = numLinkPositions ) & &
( numLinkMasses = = numLinkOrientations ) & &
( numLinkMasses = = numLinkParentIndices ) & &
( numLinkMasses = = numLinkJointTypes ) & &
( numLinkMasses = = numLinkJoinAxis ) & &
( numLinkMasses = = numLinkInertialFramePositions ) & &
( numLinkMasses = = numLinkInertialFrameOrientations ) )
2017-06-05 05:04:16 +00:00
{
2017-06-19 17:14:26 +00:00
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
int i ;
b3SharedMemoryCommandHandle commandHandle = b3CreateMultiBodyCommandInit ( sm ) ;
2018-09-23 21:17:31 +00:00
double basePosition [ 3 ] = { 0 , 0 , 0 } ;
double baseOrientation [ 4 ] = { 0 , 0 , 0 , 1 } ;
double baseInertialFramePosition [ 3 ] = { 0 , 0 , 0 } ;
double baseInertialFrameOrientation [ 4 ] = { 0 , 0 , 0 , 1 } ;
2017-06-19 17:14:26 +00:00
int baseIndex ;
2018-09-23 21:17:31 +00:00
pybullet_internalSetVectord ( basePosObj , basePosition ) ;
pybullet_internalSetVector4d ( baseOrnObj , baseOrientation ) ;
pybullet_internalSetVectord ( baseInertialFramePositionObj , baseInertialFramePosition ) ;
pybullet_internalSetVector4d ( baseInertialFrameOrientationObj , baseInertialFrameOrientation ) ;
2017-06-20 00:13:20 +00:00
2018-09-23 21:17:31 +00:00
baseIndex = b3CreateMultiBodyBase ( commandHandle , baseMass , baseCollisionShapeIndex , baseVisualShapeIndex , basePosition , baseOrientation , baseInertialFramePosition , baseInertialFrameOrientation ) ;
2017-06-19 17:14:26 +00:00
2018-09-23 21:17:31 +00:00
for ( i = 0 ; i < numLinkMasses ; i + + )
2017-06-19 17:14:26 +00:00
{
2018-09-23 21:17:31 +00:00
double linkMass = pybullet_internalGetFloatFromSequence ( seqLinkMasses , i ) ;
int linkCollisionShapeIndex = pybullet_internalGetIntFromSequence ( seqLinkCollisionShapes , i ) ;
int linkVisualShapeIndex = pybullet_internalGetIntFromSequence ( seqLinkVisualShapes , i ) ;
2017-06-19 17:14:26 +00:00
double linkPosition [ 3 ] ;
double linkOrientation [ 4 ] ;
double linkJointAxis [ 3 ] ;
2017-06-19 20:15:05 +00:00
double linkInertialFramePosition [ 3 ] ;
double linkInertialFrameOrientation [ 4 ] ;
2017-06-24 03:36:19 +00:00
int linkParentIndex ;
int linkJointType ;
2018-09-23 21:17:31 +00:00
pybullet_internalGetVector3FromSequence ( seqLinkInertialFramePositions , i , linkInertialFramePosition ) ;
pybullet_internalGetVector4FromSequence ( linkInertialFrameOrientationObj , i , linkInertialFrameOrientation ) ;
pybullet_internalGetVector3FromSequence ( seqLinkPositions , i , linkPosition ) ;
pybullet_internalGetVector4FromSequence ( seqLinkOrientations , i , linkOrientation ) ;
pybullet_internalGetVector3FromSequence ( seqLinkJoinAxis , i , linkJointAxis ) ;
linkParentIndex = pybullet_internalGetIntFromSequence ( seqLinkParentIndices , i ) ;
linkJointType = pybullet_internalGetIntFromSequence ( seqLinkJointTypes , i ) ;
2017-06-19 17:14:26 +00:00
2018-09-11 20:24:35 +00:00
b3CreateMultiBodyLink ( commandHandle ,
2018-09-23 21:17:31 +00:00
linkMass ,
linkCollisionShapeIndex ,
linkVisualShapeIndex ,
linkPosition ,
linkOrientation ,
linkInertialFramePosition ,
linkInertialFrameOrientation ,
linkParentIndex ,
linkJointType ,
linkJointAxis ) ;
2017-06-19 17:14:26 +00:00
}
if ( seqLinkMasses )
Py_DECREF ( seqLinkMasses ) ;
if ( seqLinkCollisionShapes )
Py_DECREF ( seqLinkCollisionShapes ) ;
if ( seqLinkVisualShapes )
Py_DECREF ( seqLinkVisualShapes ) ;
if ( seqLinkPositions )
Py_DECREF ( seqLinkPositions ) ;
if ( seqLinkOrientations )
Py_DECREF ( seqLinkOrientations ) ;
if ( seqLinkParentIndices )
Py_DECREF ( seqLinkParentIndices ) ;
if ( seqLinkJointTypes )
Py_DECREF ( seqLinkJointTypes ) ;
if ( seqLinkJoinAxis )
Py_DECREF ( seqLinkJoinAxis ) ;
2017-06-19 20:15:05 +00:00
if ( seqLinkInertialFramePositions )
Py_DECREF ( seqLinkInertialFramePositions ) ;
if ( seqLinkInertialFrameOrientations )
Py_DECREF ( seqLinkInertialFrameOrientations ) ;
2017-06-19 17:14:26 +00:00
2018-09-23 21:17:31 +00:00
if ( useMaximalCoordinates > 0 )
2017-06-19 17:14:26 +00:00
{
b3CreateMultiBodyUseMaximalCoordinates ( commandHandle ) ;
}
2018-09-23 21:17:31 +00:00
if ( flags > 0 )
2018-06-02 18:37:14 +00:00
{
b3CreateMultiBodySetFlags ( commandHandle , flags ) ;
}
2017-06-19 17:14:26 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CREATE_MULTI_BODY_COMPLETED )
{
int uid = b3GetStatusBodyIndex ( statusHandle ) ;
PyObject * ob = PyLong_FromLong ( uid ) ;
return ob ;
}
2018-09-23 21:17:31 +00:00
}
else
2017-06-19 17:14:26 +00:00
{
if ( seqLinkMasses )
Py_DECREF ( seqLinkMasses ) ;
if ( seqLinkCollisionShapes )
Py_DECREF ( seqLinkCollisionShapes ) ;
if ( seqLinkVisualShapes )
Py_DECREF ( seqLinkVisualShapes ) ;
if ( seqLinkPositions )
Py_DECREF ( seqLinkPositions ) ;
if ( seqLinkOrientations )
Py_DECREF ( seqLinkOrientations ) ;
if ( seqLinkParentIndices )
Py_DECREF ( seqLinkParentIndices ) ;
if ( seqLinkJointTypes )
Py_DECREF ( seqLinkJointTypes ) ;
if ( seqLinkJoinAxis )
Py_DECREF ( seqLinkJoinAxis ) ;
2017-06-19 20:15:05 +00:00
if ( seqLinkInertialFramePositions )
Py_DECREF ( seqLinkInertialFramePositions ) ;
if ( seqLinkInertialFrameOrientations )
Py_DECREF ( seqLinkInertialFrameOrientations ) ;
2017-06-19 17:14:26 +00:00
PyErr_SetString ( SpamError , " All link arrays need to be same size. " ) ;
return NULL ;
2017-06-05 05:04:16 +00:00
}
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
#if 0
2017-06-19 17:14:26 +00:00
PyObject * seq ;
seq = PySequence_Fast ( objMat , " expected a sequence " ) ;
if ( seq )
2017-06-03 17:57:56 +00:00
{
2017-06-19 17:14:26 +00:00
len = PySequence_Size ( objMat ) ;
if ( len = = 16 )
{
for ( i = 0 ; i < len ; i + + )
{
matrix [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
Py_DECREF ( seq ) ;
return 1 ;
}
Py_DECREF ( seq ) ;
2017-06-03 17:57:56 +00:00
}
2018-09-23 21:17:31 +00:00
# endif
2017-06-03 17:57:56 +00:00
}
PyErr_SetString ( SpamError , " createMultiBody failed. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_createUserConstraint ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-14 22:08:05 +00:00
{
b3SharedMemoryCommandHandle commandHandle ;
2017-03-13 23:06:52 +00:00
int parentBodyUniqueId = - 1 ;
int parentLinkIndex = - 1 ;
int childBodyUniqueId = - 1 ;
int childLinkIndex = - 1 ;
int jointType = ePoint2PointType ;
PyObject * jointAxisObj = 0 ;
double jointAxis [ 3 ] = { 0 , 0 , 0 } ;
2016-11-14 22:08:05 +00:00
PyObject * parentFramePositionObj = 0 ;
2017-03-13 23:06:52 +00:00
double parentFramePosition [ 3 ] = { 0 , 0 , 0 } ;
2016-11-14 22:08:05 +00:00
PyObject * childFramePositionObj = 0 ;
2017-03-13 23:06:52 +00:00
double childFramePosition [ 3 ] = { 0 , 0 , 0 } ;
2016-11-14 22:08:05 +00:00
PyObject * parentFrameOrientationObj = 0 ;
2017-03-13 23:06:52 +00:00
double parentFrameOrientation [ 4 ] = { 0 , 0 , 0 , 1 } ;
2016-11-14 22:08:05 +00:00
PyObject * childFrameOrientationObj = 0 ;
2017-03-13 23:06:52 +00:00
double childFrameOrientation [ 4 ] = { 0 , 0 , 0 , 1 } ;
2016-11-14 22:08:05 +00:00
struct b3JointInfo jointInfo ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-03-13 23:06:52 +00:00
static char * kwlist [ ] = { " parentBodyUniqueId " , " parentLinkIndex " ,
" childBodyUniqueId " , " childLinkIndex " ,
" jointType " ,
" jointAxis " ,
" parentFramePosition " ,
" childFramePosition " ,
" parentFrameOrientation " ,
" childFrameOrientation " ,
" physicsClientId " ,
NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iiiiiOOO|OOi " , kwlist , & parentBodyUniqueId , & parentLinkIndex ,
& childBodyUniqueId , & childLinkIndex ,
& jointType , & jointAxisObj ,
& parentFramePositionObj ,
& childFramePositionObj ,
& parentFrameOrientationObj ,
& childFrameOrientationObj ,
& physicsClientId ) )
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
pybullet_internalSetVectord ( jointAxisObj , jointAxis ) ;
pybullet_internalSetVectord ( parentFramePositionObj , parentFramePosition ) ;
pybullet_internalSetVectord ( childFramePositionObj , childFramePosition ) ;
pybullet_internalSetVector4d ( parentFrameOrientationObj , parentFrameOrientation ) ;
pybullet_internalSetVector4d ( childFrameOrientationObj , childFrameOrientation ) ;
2016-11-14 22:08:05 +00:00
jointInfo . m_jointType = jointType ;
jointInfo . m_parentFrame [ 0 ] = parentFramePosition [ 0 ] ;
jointInfo . m_parentFrame [ 1 ] = parentFramePosition [ 1 ] ;
jointInfo . m_parentFrame [ 2 ] = parentFramePosition [ 2 ] ;
jointInfo . m_parentFrame [ 3 ] = parentFrameOrientation [ 0 ] ;
jointInfo . m_parentFrame [ 4 ] = parentFrameOrientation [ 1 ] ;
jointInfo . m_parentFrame [ 5 ] = parentFrameOrientation [ 2 ] ;
jointInfo . m_parentFrame [ 6 ] = parentFrameOrientation [ 3 ] ;
jointInfo . m_childFrame [ 0 ] = childFramePosition [ 0 ] ;
jointInfo . m_childFrame [ 1 ] = childFramePosition [ 1 ] ;
jointInfo . m_childFrame [ 2 ] = childFramePosition [ 2 ] ;
jointInfo . m_childFrame [ 3 ] = childFrameOrientation [ 0 ] ;
jointInfo . m_childFrame [ 4 ] = childFrameOrientation [ 1 ] ;
jointInfo . m_childFrame [ 5 ] = childFrameOrientation [ 2 ] ;
jointInfo . m_childFrame [ 6 ] = childFrameOrientation [ 3 ] ;
2017-03-13 23:06:52 +00:00
2016-11-14 22:08:05 +00:00
jointInfo . m_jointAxis [ 0 ] = jointAxis [ 0 ] ;
jointInfo . m_jointAxis [ 1 ] = jointAxis [ 1 ] ;
jointInfo . m_jointAxis [ 2 ] = jointAxis [ 2 ] ;
2017-03-13 23:06:52 +00:00
commandHandle = b3InitCreateUserConstraintCommand ( sm , parentBodyUniqueId , parentLinkIndex , childBodyUniqueId , childLinkIndex , & jointInfo ) ;
2016-11-14 22:08:05 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2017-03-13 23:06:52 +00:00
if ( statusType = = CMD_USER_CONSTRAINT_COMPLETED )
2016-11-14 22:08:05 +00:00
{
int userConstraintUid = b3GetStatusUserConstraintUniqueId ( statusHandle ) ;
PyObject * ob = PyLong_FromLong ( userConstraintUid ) ;
return ob ;
}
2017-01-31 18:14:00 +00:00
PyErr_SetString ( SpamError , " createConstraint failed. " ) ;
return NULL ;
2016-11-14 22:08:05 +00:00
}
2016-11-10 05:01:04 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getContactPointData ( PyObject * self , PyObject * args , PyObject * keywds )
{
int bodyUniqueIdA = - 1 ;
int bodyUniqueIdB = - 1 ;
2017-09-24 02:58:59 +00:00
int linkIndexA = - 2 ;
int linkIndexB = - 2 ;
2018-09-11 20:24:35 +00:00
2017-03-13 23:06:52 +00:00
b3SharedMemoryCommandHandle commandHandle ;
struct b3ContactInformation contactPointData ;
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
2016-11-10 05:01:04 +00:00
2017-03-29 19:04:23 +00:00
static char * kwlist [ ] = { " bodyA " , " bodyB " , " linkIndexA " , " linkIndexB " , " physicsClientId " , NULL } ;
2016-11-10 05:01:04 +00:00
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-03-29 19:04:23 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |iiiii " , kwlist ,
& bodyUniqueIdA , & bodyUniqueIdB , & linkIndexA , & linkIndexB , & physicsClientId ) )
2017-03-13 23:06:52 +00:00
return NULL ;
2016-11-10 05:01:04 +00:00
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-11-10 05:01:04 +00:00
2017-03-13 23:06:52 +00:00
commandHandle = b3InitRequestContactPointInformation ( sm ) ;
2018-09-23 21:17:31 +00:00
if ( bodyUniqueIdA > = 0 )
2017-09-24 02:58:59 +00:00
{
b3SetContactFilterBodyA ( commandHandle , bodyUniqueIdA ) ;
}
2018-09-23 21:17:31 +00:00
if ( bodyUniqueIdB > = 0 )
2017-09-24 02:58:59 +00:00
{
b3SetContactFilterBodyB ( commandHandle , bodyUniqueIdB ) ;
}
2018-09-23 21:17:31 +00:00
if ( linkIndexA > = - 1 )
2017-09-24 02:58:59 +00:00
{
2018-09-23 21:17:31 +00:00
b3SetContactFilterLinkA ( commandHandle , linkIndexA ) ;
2017-09-24 02:58:59 +00:00
}
2018-09-23 21:17:31 +00:00
if ( linkIndexB > = - 1 )
2017-09-24 02:58:59 +00:00
{
2018-09-23 21:17:31 +00:00
b3SetContactFilterLinkB ( commandHandle , linkIndexB ) ;
2017-09-24 02:58:59 +00:00
}
2018-09-11 20:24:35 +00:00
2017-03-13 23:06:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CONTACT_POINT_INFORMATION_COMPLETED )
{
b3GetContactPointInformation ( sm , & contactPointData ) ;
2016-11-10 05:01:04 +00:00
2017-03-13 23:06:52 +00:00
return MyConvertContactPoint ( & contactPointData ) ;
}
2016-09-02 01:28:39 +00:00
2017-03-13 23:06:52 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-09-08 18:12:58 +00:00
}
2016-09-02 01:28:39 +00:00
2018-05-23 03:26:00 +00:00
static PyObject * pybullet_isNumpyEnabled ( PyObject * self , PyObject * args , PyObject * keywds )
{
int physicsClientId = 0 ;
int isNumpyEnabled = 0 ;
int method = 0 ;
PyObject * pylist = 0 ;
PyObject * val = 0 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " physicsClientId " , NULL } ;
2018-05-23 03:26:00 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " |i " , kwlist , & physicsClientId ) )
{
return NULL ;
}
# ifdef PYBULLET_USE_NUMPY
isNumpyEnabled = 1 ;
# endif
return PyLong_FromLong ( isNumpyEnabled ) ;
}
2016-11-17 23:15:52 +00:00
/// Render an image from the current timestep of the simulation, width, height are required, other args are optional
2017-03-04 21:31:30 +00:00
// getCameraImage(w, h, view[16], projection[16], lightDir[3], lightColor[3], lightDist, hasShadow, lightAmbientCoeff, lightDiffuseCoeff, lightSpecularCoeff, renderer)
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getCameraImage ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-17 23:15:52 +00:00
{
2017-03-04 21:31:30 +00:00
/// request an image from a simulated camera, using software or hardware renderer.
2016-11-17 23:15:52 +00:00
struct b3CameraImageData imageData ;
2018-03-19 01:45:54 +00:00
PyObject * objViewMat = 0 , * objProjMat = 0 , * lightDirObj = 0 , * lightColorObj = 0 , * objProjectiveTextureView = 0 , * objProjectiveTextureProj = 0 ;
2016-11-17 23:15:52 +00:00
int width , height ;
float viewMatrix [ 16 ] ;
float projectionMatrix [ 16 ] ;
2018-03-19 01:45:54 +00:00
float projectiveTextureView [ 16 ] ;
float projectiveTextureProj [ 16 ] ;
2016-11-17 23:15:52 +00:00
float lightDir [ 3 ] ;
2017-03-13 23:06:52 +00:00
float lightColor [ 3 ] ;
2017-05-18 00:25:34 +00:00
float lightDist = - 1 ;
int hasShadow = - 1 ;
float lightAmbientCoeff = - 1 ;
float lightDiffuseCoeff = - 1 ;
float lightSpecularCoeff = - 1 ;
2017-12-28 20:37:07 +00:00
int flags = - 1 ;
2017-05-18 00:25:34 +00:00
int renderer = - 1 ;
2016-11-17 23:15:52 +00:00
// inialize cmd
b3SharedMemoryCommandHandle command ;
2016-12-28 04:25:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
// set camera resolution, optionally view, projection matrix, light direction, light color, light distance, shadow
2018-03-19 01:45:54 +00:00
static char * kwlist [ ] = { " width " , " height " , " viewMatrix " , " projectionMatrix " , " lightDirection " , " lightColor " , " lightDistance " , " shadow " , " lightAmbientCoeff " , " lightDiffuseCoeff " , " lightSpecularCoeff " , " renderer " , " flags " , " projectiveTextureView " , " projectiveTextureProj " , " physicsClientId " , NULL } ;
2016-11-17 23:15:52 +00:00
2018-03-19 01:45:54 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ii|OOOOfifffiiOOi " , kwlist , & width , & height , & objViewMat , & objProjMat , & lightDirObj , & lightColorObj , & lightDist , & hasShadow , & lightAmbientCoeff , & lightDiffuseCoeff , & lightSpecularCoeff , & renderer , & flags , & objProjectiveTextureView , & objProjectiveTextureProj , & physicsClientId ) )
2016-11-17 23:15:52 +00:00
{
return NULL ;
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-11-17 23:15:52 +00:00
{
2016-12-28 04:25:52 +00:00
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
2016-11-17 23:15:52 +00:00
return NULL ;
}
2016-12-28 04:25:52 +00:00
command = b3InitRequestCameraImage ( sm ) ;
2016-11-17 23:15:52 +00:00
b3RequestCameraImageSetPixelResolution ( command , width , height ) ;
// set camera matrices only if set matrix function succeeds
2017-05-18 00:25:34 +00:00
if ( objViewMat & & objProjMat & & pybullet_internalSetMatrix ( objViewMat , viewMatrix ) & & ( pybullet_internalSetMatrix ( objProjMat , projectionMatrix ) ) )
2016-11-17 23:15:52 +00:00
{
b3RequestCameraImageSetCameraMatrices ( command , viewMatrix , projectionMatrix ) ;
}
2016-11-20 21:14:18 +00:00
//set light direction only if function succeeds
2017-05-18 00:25:34 +00:00
if ( lightDirObj & & pybullet_internalSetVector ( lightDirObj , lightDir ) )
2016-11-17 23:15:52 +00:00
{
b3RequestCameraImageSetLightDirection ( command , lightDir ) ;
}
2017-03-13 23:06:52 +00:00
//set light color only if function succeeds
if ( pybullet_internalSetVector ( lightColorObj , lightColor ) )
{
b3RequestCameraImageSetLightColor ( command , lightColor ) ;
}
2018-09-23 21:17:31 +00:00
if ( lightDist > = 0 )
2017-05-18 00:25:34 +00:00
{
b3RequestCameraImageSetLightDistance ( command , lightDist ) ;
}
2017-03-13 23:06:52 +00:00
2018-09-23 21:17:31 +00:00
if ( hasShadow > = 0 )
2017-05-18 00:25:34 +00:00
{
b3RequestCameraImageSetShadow ( command , hasShadow ) ;
}
2018-09-23 21:17:31 +00:00
if ( lightAmbientCoeff > = 0 )
2017-05-18 00:25:34 +00:00
{
b3RequestCameraImageSetLightAmbientCoeff ( command , lightAmbientCoeff ) ;
}
2018-09-23 21:17:31 +00:00
if ( lightDiffuseCoeff > = 0 )
2017-05-18 00:25:34 +00:00
{
b3RequestCameraImageSetLightDiffuseCoeff ( command , lightDiffuseCoeff ) ;
}
2017-03-13 23:06:52 +00:00
2018-09-23 21:17:31 +00:00
if ( lightSpecularCoeff > = 0 )
2017-05-18 00:25:34 +00:00
{
b3RequestCameraImageSetLightSpecularCoeff ( command , lightSpecularCoeff ) ;
}
2017-03-13 23:06:52 +00:00
2017-12-28 20:37:07 +00:00
if ( flags > = 0 )
{
b3RequestCameraImageSetFlags ( command , flags ) ;
}
2018-03-19 01:45:54 +00:00
if ( objProjectiveTextureView & & objProjectiveTextureProj & & pybullet_internalSetMatrix ( objProjectiveTextureView , projectiveTextureView ) & & ( pybullet_internalSetMatrix ( objProjectiveTextureProj , projectiveTextureProj ) ) )
{
b3RequestCameraImageSetProjectiveTextureMatrices ( command , projectiveTextureView , projectiveTextureProj ) ;
}
2018-09-23 21:17:31 +00:00
if ( renderer > = 0 )
2017-05-18 00:25:34 +00:00
{
2018-09-23 21:17:31 +00:00
b3RequestCameraImageSelectRenderer ( command , renderer ) ; //renderer could be ER_BULLET_HARDWARE_OPENGL
2017-05-18 00:25:34 +00:00
}
2018-09-23 21:17:31 +00:00
//PyErr_Clear();
2016-11-17 23:15:52 +00:00
if ( b3CanSubmitCommand ( sm ) )
{
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
2017-03-13 23:06:52 +00:00
if ( statusType = = CMD_CAMERA_IMAGE_COMPLETED )
{
2016-11-17 23:15:52 +00:00
PyObject * pyResultList ; // store 4 elements in this result: width,
// height, rgbData, depth
# ifdef PYBULLET_USE_NUMPY
PyObject * pyRGB ;
PyObject * pyDep ;
PyObject * pySeg ;
2017-11-24 22:33:24 +00:00
int bytesPerPixel = 4 ; // Red, Green, Blue, and Alpha each 8 bit values
2016-11-17 23:15:52 +00:00
b3GetCameraImageData ( sm , & imageData ) ;
// TODO(hellojas): error handling if image size is 0
2017-11-25 00:50:36 +00:00
{
2018-09-23 21:17:31 +00:00
npy_intp rgb_dims [ 3 ] = { imageData . m_pixelHeight , imageData . m_pixelWidth ,
bytesPerPixel } ;
npy_intp dep_dims [ 2 ] = { imageData . m_pixelHeight , imageData . m_pixelWidth } ;
npy_intp seg_dims [ 2 ] = { imageData . m_pixelHeight , imageData . m_pixelWidth } ;
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
pyResultList = PyTuple_New ( 5 ) ;
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( pyResultList , 0 , PyInt_FromLong ( imageData . m_pixelWidth ) ) ;
PyTuple_SetItem ( pyResultList , 1 , PyInt_FromLong ( imageData . m_pixelHeight ) ) ;
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
pyRGB = PyArray_SimpleNew ( 3 , rgb_dims , NPY_UINT8 ) ;
pyDep = PyArray_SimpleNew ( 2 , dep_dims , NPY_FLOAT32 ) ;
pySeg = PyArray_SimpleNew ( 2 , seg_dims , NPY_INT32 ) ;
2016-11-17 23:15:52 +00:00
2018-09-23 21:17:31 +00:00
memcpy ( PyArray_DATA ( pyRGB ) , imageData . m_rgbColorData ,
imageData . m_pixelHeight * imageData . m_pixelWidth * bytesPerPixel ) ;
memcpy ( PyArray_DATA ( pyDep ) , imageData . m_depthValues ,
imageData . m_pixelHeight * imageData . m_pixelWidth * sizeof ( float ) ) ;
memcpy ( PyArray_DATA ( pySeg ) , imageData . m_segmentationMaskValues ,
imageData . m_pixelHeight * imageData . m_pixelWidth * sizeof ( int ) ) ;
2016-11-17 23:15:52 +00:00
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( pyResultList , 2 , pyRGB ) ;
PyTuple_SetItem ( pyResultList , 3 , pyDep ) ;
PyTuple_SetItem ( pyResultList , 4 , pySeg ) ;
2017-11-25 00:50:36 +00:00
}
2017-03-13 23:06:52 +00:00
# else //PYBULLET_USE_NUMPY
2017-11-25 00:50:36 +00:00
PyObject * item2 ;
2016-11-17 23:15:52 +00:00
PyObject * pylistRGB ;
PyObject * pylistDep ;
PyObject * pylistSeg ;
int i , j , p ;
b3GetCameraImageData ( sm , & imageData ) ;
// TODO(hellojas): error handling if image size is 0
pyResultList = PyTuple_New ( 5 ) ;
PyTuple_SetItem ( pyResultList , 0 , PyInt_FromLong ( imageData . m_pixelWidth ) ) ;
PyTuple_SetItem ( pyResultList , 1 , PyInt_FromLong ( imageData . m_pixelHeight ) ) ;
{
PyObject * item ;
int bytesPerPixel = 4 ; // Red, Green, Blue, and Alpha each 8 bit values
int num =
bytesPerPixel * imageData . m_pixelWidth * imageData . m_pixelHeight ;
pylistRGB = PyTuple_New ( num ) ;
pylistDep =
PyTuple_New ( imageData . m_pixelWidth * imageData . m_pixelHeight ) ;
pylistSeg =
PyTuple_New ( imageData . m_pixelWidth * imageData . m_pixelHeight ) ;
2017-03-13 23:06:52 +00:00
for ( i = 0 ; i < imageData . m_pixelWidth ; i + + )
{
for ( j = 0 ; j < imageData . m_pixelHeight ; j + + )
{
2016-11-17 23:15:52 +00:00
// TODO(hellojas): validate depth values make sense
int depIndex = i + j * imageData . m_pixelWidth ;
{
item = PyFloat_FromDouble ( imageData . m_depthValues [ depIndex ] ) ;
PyTuple_SetItem ( pylistDep , depIndex , item ) ;
}
{
item2 =
PyLong_FromLong ( imageData . m_segmentationMaskValues [ depIndex ] ) ;
PyTuple_SetItem ( pylistSeg , depIndex , item2 ) ;
}
2017-03-13 23:06:52 +00:00
for ( p = 0 ; p < bytesPerPixel ; p + + )
{
2016-11-17 23:15:52 +00:00
int pixelIndex =
bytesPerPixel * ( i + j * imageData . m_pixelWidth ) + p ;
item = PyInt_FromLong ( imageData . m_rgbColorData [ pixelIndex ] ) ;
PyTuple_SetItem ( pylistRGB , pixelIndex , item ) ;
}
}
}
}
PyTuple_SetItem ( pyResultList , 2 , pylistRGB ) ;
PyTuple_SetItem ( pyResultList , 3 , pylistDep ) ;
PyTuple_SetItem ( pyResultList , 4 , pylistSeg ) ;
return pyResultList ;
2017-03-13 23:06:52 +00:00
# endif //PYBULLET_USE_NUMPY
2016-11-17 23:15:52 +00:00
return pyResultList ;
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_computeViewMatrix ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-17 23:15:52 +00:00
{
PyObject * camEyeObj = 0 ;
PyObject * camTargetPositionObj = 0 ;
PyObject * camUpVectorObj = 0 ;
float camEye [ 3 ] ;
float camTargetPosition [ 3 ] ;
float camUpVector [ 3 ] ;
2018-09-23 21:17:31 +00:00
int physicsClientId = 0 ;
2016-11-17 23:15:52 +00:00
// set camera resolution, optionally view, projection matrix, light position
2017-08-25 21:04:45 +00:00
static char * kwlist [ ] = { " cameraEyePosition " , " cameraTargetPosition " , " cameraUpVector " , " physicsClientId " , NULL } ;
2016-11-17 23:15:52 +00:00
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " OOO|i " , kwlist , & camEyeObj , & camTargetPositionObj , & camUpVectorObj , & physicsClientId ) )
2016-11-17 23:15:52 +00:00
{
return NULL ;
}
if ( pybullet_internalSetVector ( camEyeObj , camEye ) & &
pybullet_internalSetVector ( camTargetPositionObj , camTargetPosition ) & &
pybullet_internalSetVector ( camUpVectorObj , camUpVector ) )
{
float viewMatrix [ 16 ] ;
2017-03-13 23:06:52 +00:00
PyObject * pyResultList = 0 ;
2016-11-17 23:15:52 +00:00
int i ;
b3ComputeViewMatrixFromPositions ( camEye , camTargetPosition , camUpVector , viewMatrix ) ;
pyResultList = PyTuple_New ( 16 ) ;
for ( i = 0 ; i < 16 ; i + + )
{
PyObject * item = PyFloat_FromDouble ( viewMatrix [ i ] ) ;
PyTuple_SetItem ( pyResultList , i , item ) ;
}
return pyResultList ;
}
PyErr_SetString ( SpamError , " Error in computeViewMatrix. " ) ;
return NULL ;
}
///compute a view matrix, helper function for b3RequestCameraImageSetCameraMatrices
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_computeViewMatrixFromYawPitchRoll ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-17 23:15:52 +00:00
{
PyObject * cameraTargetPositionObj = 0 ;
float cameraTargetPosition [ 3 ] ;
float distance , yaw , pitch , roll ;
int upAxisIndex ;
float viewMatrix [ 16 ] ;
PyObject * pyResultList = 0 ;
int i ;
2017-08-25 21:04:45 +00:00
int physicsClientId = 0 ;
2016-11-17 23:15:52 +00:00
// set camera resolution, optionally view, projection matrix, light position
2017-08-25 21:04:45 +00:00
static char * kwlist [ ] = { " cameraTargetPosition " , " distance " , " yaw " , " pitch " , " roll " , " upAxisIndex " , " physicsClientId " , NULL } ;
2017-03-13 23:06:52 +00:00
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " Offffi|i " , kwlist , & cameraTargetPositionObj , & distance , & yaw , & pitch , & roll , & upAxisIndex , & physicsClientId ) )
2016-11-17 23:15:52 +00:00
{
return NULL ;
}
if ( ! pybullet_internalSetVector ( cameraTargetPositionObj , cameraTargetPosition ) )
{
PyErr_SetString ( SpamError , " Cannot convert cameraTargetPosition. " ) ;
return NULL ;
}
b3ComputeViewMatrixFromYawPitchRoll ( cameraTargetPosition , distance , yaw , pitch , roll , upAxisIndex , viewMatrix ) ;
pyResultList = PyTuple_New ( 16 ) ;
for ( i = 0 ; i < 16 ; i + + )
{
PyObject * item = PyFloat_FromDouble ( viewMatrix [ i ] ) ;
PyTuple_SetItem ( pyResultList , i , item ) ;
}
return pyResultList ;
}
///compute a projection matrix, helper function for b3RequestCameraImageSetCameraMatrices
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_computeProjectionMatrix ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-17 23:15:52 +00:00
{
PyObject * pyResultList = 0 ;
float left ;
float right ;
float bottom ;
float top ;
float nearVal ;
float farVal ;
float projectionMatrix [ 16 ] ;
int i ;
2017-08-25 21:04:45 +00:00
int physicsClientId ;
2016-11-17 23:15:52 +00:00
// set camera resolution, optionally view, projection matrix, light position
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " left " , " right " , " bottom " , " top " , " nearVal " , " farVal " , " physicsClientId " , NULL } ;
2016-11-17 23:15:52 +00:00
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ffffff|i " , kwlist , & left , & right , & bottom , & top , & nearVal , & farVal , & physicsClientId ) )
2016-11-17 23:15:52 +00:00
{
return NULL ;
}
b3ComputeProjectionMatrix ( left , right , bottom , top , nearVal , farVal , projectionMatrix ) ;
pyResultList = PyTuple_New ( 16 ) ;
for ( i = 0 ; i < 16 ; i + + )
{
PyObject * item = PyFloat_FromDouble ( projectionMatrix [ i ] ) ;
PyTuple_SetItem ( pyResultList , i , item ) ;
}
return pyResultList ;
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_computeProjectionMatrixFOV ( PyObject * self , PyObject * args , PyObject * keywds )
2016-11-17 23:15:52 +00:00
{
2017-03-13 23:06:52 +00:00
float fov , aspect , nearVal , farVal ;
2016-11-17 23:15:52 +00:00
PyObject * pyResultList = 0 ;
float projectionMatrix [ 16 ] ;
int i ;
2018-09-23 21:17:31 +00:00
int physicsClientId = 0 ;
2016-11-17 23:15:52 +00:00
2017-08-25 21:04:45 +00:00
static char * kwlist [ ] = { " fov " , " aspect " , " nearVal " , " farVal " , " physicsClientId " , NULL } ;
2016-11-17 23:15:52 +00:00
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " ffff|i " , kwlist , & fov , & aspect , & nearVal , & farVal , & physicsClientId ) )
2016-11-17 23:15:52 +00:00
{
return NULL ;
}
2017-03-13 23:06:52 +00:00
2016-11-17 23:15:52 +00:00
b3ComputeProjectionMatrixFOV ( fov , aspect , nearVal , farVal , projectionMatrix ) ;
pyResultList = PyTuple_New ( 16 ) ;
for ( i = 0 ; i < 16 ; i + + )
{
PyObject * item = PyFloat_FromDouble ( projectionMatrix [ i ] ) ;
PyTuple_SetItem ( pyResultList , i , item ) ;
}
2017-03-13 23:06:52 +00:00
return pyResultList ;
}
// Render an image from the current timestep of the simulation
//
// Examples:
// renderImage() - default image resolution and camera position
// renderImage(w, h) - image resolution of (w,h), default camera
// renderImage(w, h, view[16], projection[16]) - set both resolution
// and initialize camera to the view and projection values
// renderImage(w, h, cameraPos, targetPos, cameraUp, nearVal, farVal) - set
// resolution and initialize camera based on camera position, target
// position, camera up and fulstrum near/far values.
// renderImage(w, h, cameraPos, targetPos, cameraUp, nearVal, farVal, fov) -
// set resolution and initialize camera based on camera position, target
// position, camera up, fulstrum near/far values and camera field of view.
// renderImage(w, h, targetPos, distance, yaw, pitch, upAxisIndex, nearVal,
// farVal, fov)
//
// Note if the (w,h) is too small, the objects may not appear based on
// where the camera has been set
//
// TODO(hellojas): fix image is cut off at head
// TODO(hellojas): should we add check to give minimum image resolution
// to see object based on camera position?
static PyObject * pybullet_renderImageObsolete ( PyObject * self , PyObject * args )
{
/// request an image from a simulated camera, using a software renderer.
struct b3CameraImageData imageData ;
PyObject * objViewMat , * objProjMat ;
PyObject * objCameraPos , * objTargetPos , * objCameraUp ;
int width , height ;
int size = PySequence_Size ( args ) ;
float viewMatrix [ 16 ] ;
float projectionMatrix [ 16 ] ;
float cameraPos [ 3 ] ;
float targetPos [ 3 ] ;
float cameraUp [ 3 ] ;
float left , right , bottom , top , aspect ;
float nearVal , farVal ;
float fov ;
// inialize cmd
b3SharedMemoryCommandHandle command ;
b3PhysicsClientHandle sm ;
int physicsClientId = 0 ;
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
command = b3InitRequestCameraImage ( sm ) ;
if ( size = = 2 ) // only set camera resolution
{
if ( PyArg_ParseTuple ( args , " ii " , & width , & height ) )
{
b3RequestCameraImageSetPixelResolution ( command , width , height ) ;
}
}
else if ( size = = 4 ) // set camera resolution and view and projection matrix
{
if ( PyArg_ParseTuple ( args , " iiOO " , & width , & height , & objViewMat ,
& objProjMat ) )
{
b3RequestCameraImageSetPixelResolution ( command , width , height ) ;
// set camera matrices only if set matrix function succeeds
if ( pybullet_internalSetMatrix ( objViewMat , viewMatrix ) & &
( pybullet_internalSetMatrix ( objProjMat , projectionMatrix ) ) )
{
b3RequestCameraImageSetCameraMatrices ( command , viewMatrix ,
projectionMatrix ) ;
}
else
{
PyErr_SetString ( SpamError , " Error parsing view or projection matrix. " ) ;
return NULL ;
}
}
}
else if ( size = = 7 ) // set camera resolution, camera positions and
// calculate projection using near/far values.
{
if ( PyArg_ParseTuple ( args , " iiOOOff " , & width , & height , & objCameraPos ,
& objTargetPos , & objCameraUp , & nearVal , & farVal ) )
{
b3RequestCameraImageSetPixelResolution ( command , width , height ) ;
if ( pybullet_internalSetVector ( objCameraPos , cameraPos ) & &
pybullet_internalSetVector ( objTargetPos , targetPos ) & &
pybullet_internalSetVector ( objCameraUp , cameraUp ) )
{
b3RequestCameraImageSetViewMatrix ( command , cameraPos , targetPos ,
cameraUp ) ;
}
else
{
PyErr_SetString ( SpamError ,
" Error parsing camera position, target or up. " ) ;
return NULL ;
}
aspect = width / height ;
left = - aspect * nearVal ;
right = aspect * nearVal ;
bottom = - nearVal ;
top = nearVal ;
b3RequestCameraImageSetProjectionMatrix ( command , left , right , bottom , top ,
nearVal , farVal ) ;
}
}
else if ( size = = 8 ) // set camera resolution, camera positions and
// calculate projection using near/far values & field
// of view
{
if ( PyArg_ParseTuple ( args , " iiOOOfff " , & width , & height , & objCameraPos ,
& objTargetPos , & objCameraUp , & nearVal , & farVal ,
& fov ) )
{
b3RequestCameraImageSetPixelResolution ( command , width , height ) ;
if ( pybullet_internalSetVector ( objCameraPos , cameraPos ) & &
pybullet_internalSetVector ( objTargetPos , targetPos ) & &
pybullet_internalSetVector ( objCameraUp , cameraUp ) )
{
b3RequestCameraImageSetViewMatrix ( command , cameraPos , targetPos ,
cameraUp ) ;
}
else
{
PyErr_SetString ( SpamError ,
" Error parsing camera position, target or up. " ) ;
return NULL ;
}
aspect = width / height ;
b3RequestCameraImageSetFOVProjectionMatrix ( command , fov , aspect , nearVal ,
farVal ) ;
}
}
else if ( size = = 11 )
{
int upAxisIndex = 1 ;
float camDistance , yaw , pitch , roll ;
// sometimes more arguments are better :-)
if ( PyArg_ParseTuple ( args , " iiOffffifff " , & width , & height , & objTargetPos ,
& camDistance , & yaw , & pitch , & roll , & upAxisIndex ,
& nearVal , & farVal , & fov ) )
{
b3RequestCameraImageSetPixelResolution ( command , width , height ) ;
if ( pybullet_internalSetVector ( objTargetPos , targetPos ) )
{
// printf("width = %d, height = %d, targetPos = %f,%f,%f, distance = %f,
// yaw = %f, pitch = %f, upAxisIndex = %d, near=%f, far=%f,
// fov=%f\n",width,height,targetPos[0],targetPos[1],targetPos[2],camDistance,yaw,pitch,upAxisIndex,nearVal,farVal,fov);
b3RequestCameraImageSetViewMatrix2 ( command , targetPos , camDistance , yaw ,
pitch , roll , upAxisIndex ) ;
aspect = width / height ;
b3RequestCameraImageSetFOVProjectionMatrix ( command , fov , aspect ,
nearVal , farVal ) ;
}
else
{
PyErr_SetString ( SpamError , " Error parsing camera target pos " ) ;
}
}
else
{
PyErr_SetString ( SpamError , " Error parsing arguments " ) ;
}
}
else
{
PyErr_SetString ( SpamError , " Invalid number of args passed to renderImage. " ) ;
return NULL ;
}
if ( b3CanSubmitCommand ( sm ) )
{
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CAMERA_IMAGE_COMPLETED )
{
PyObject * pyResultList ; // store 4 elements in this result: width,
// height, rgbData, depth
# ifdef PYBULLET_USE_NUMPY
PyObject * pyRGB ;
PyObject * pyDep ;
PyObject * pySeg ;
2017-11-24 22:33:24 +00:00
int bytesPerPixel = 4 ; // Red, Green, Blue, and Alpha each 8 bit values
2017-03-13 23:06:52 +00:00
b3GetCameraImageData ( sm , & imageData ) ;
// TODO(hellojas): error handling if image size is 0
pyResultList = PyTuple_New ( 5 ) ;
PyTuple_SetItem ( pyResultList , 0 , PyInt_FromLong ( imageData . m_pixelWidth ) ) ;
PyTuple_SetItem ( pyResultList , 1 , PyInt_FromLong ( imageData . m_pixelHeight ) ) ;
2017-11-25 00:50:36 +00:00
{
2018-09-23 21:17:31 +00:00
npy_intp rgb_dims [ 3 ] = { imageData . m_pixelHeight , imageData . m_pixelWidth ,
bytesPerPixel } ;
npy_intp dep_dims [ 2 ] = { imageData . m_pixelHeight , imageData . m_pixelWidth } ;
npy_intp seg_dims [ 2 ] = { imageData . m_pixelHeight , imageData . m_pixelWidth } ;
2017-03-13 23:06:52 +00:00
2018-09-23 21:17:31 +00:00
pyRGB = PyArray_SimpleNew ( 3 , rgb_dims , NPY_UINT8 ) ;
pyDep = PyArray_SimpleNew ( 2 , dep_dims , NPY_FLOAT32 ) ;
pySeg = PyArray_SimpleNew ( 2 , seg_dims , NPY_INT32 ) ;
2017-03-13 23:06:52 +00:00
2018-09-23 21:17:31 +00:00
memcpy ( PyArray_DATA ( pyRGB ) , imageData . m_rgbColorData ,
imageData . m_pixelHeight * imageData . m_pixelWidth * bytesPerPixel ) ;
memcpy ( PyArray_DATA ( pyDep ) , imageData . m_depthValues ,
imageData . m_pixelHeight * imageData . m_pixelWidth ) ;
memcpy ( PyArray_DATA ( pySeg ) , imageData . m_segmentationMaskValues ,
imageData . m_pixelHeight * imageData . m_pixelWidth ) ;
2017-03-13 23:06:52 +00:00
2018-09-23 21:17:31 +00:00
PyTuple_SetItem ( pyResultList , 2 , pyRGB ) ;
PyTuple_SetItem ( pyResultList , 3 , pyDep ) ;
PyTuple_SetItem ( pyResultList , 4 , pySeg ) ;
2017-11-25 00:50:36 +00:00
}
2017-03-13 23:06:52 +00:00
# else //PYBULLET_USE_NUMPY
2017-11-25 00:50:36 +00:00
PyObject * item2 ;
2017-03-13 23:06:52 +00:00
PyObject * pylistRGB ;
PyObject * pylistDep ;
PyObject * pylistSeg ;
int i , j , p ;
b3GetCameraImageData ( sm , & imageData ) ;
// TODO(hellojas): error handling if image size is 0
pyResultList = PyTuple_New ( 5 ) ;
PyTuple_SetItem ( pyResultList , 0 , PyInt_FromLong ( imageData . m_pixelWidth ) ) ;
PyTuple_SetItem ( pyResultList , 1 , PyInt_FromLong ( imageData . m_pixelHeight ) ) ;
{
PyObject * item ;
int bytesPerPixel = 4 ; // Red, Green, Blue, and Alpha each 8 bit values
int num =
bytesPerPixel * imageData . m_pixelWidth * imageData . m_pixelHeight ;
pylistRGB = PyTuple_New ( num ) ;
pylistDep =
PyTuple_New ( imageData . m_pixelWidth * imageData . m_pixelHeight ) ;
pylistSeg =
PyTuple_New ( imageData . m_pixelWidth * imageData . m_pixelHeight ) ;
for ( i = 0 ; i < imageData . m_pixelWidth ; i + + )
{
for ( j = 0 ; j < imageData . m_pixelHeight ; j + + )
{
// TODO(hellojas): validate depth values make sense
int depIndex = i + j * imageData . m_pixelWidth ;
{
item = PyFloat_FromDouble ( imageData . m_depthValues [ depIndex ] ) ;
PyTuple_SetItem ( pylistDep , depIndex , item ) ;
}
{
item2 =
PyLong_FromLong ( imageData . m_segmentationMaskValues [ depIndex ] ) ;
PyTuple_SetItem ( pylistSeg , depIndex , item2 ) ;
}
for ( p = 0 ; p < bytesPerPixel ; p + + )
{
int pixelIndex =
bytesPerPixel * ( i + j * imageData . m_pixelWidth ) + p ;
item = PyInt_FromLong ( imageData . m_rgbColorData [ pixelIndex ] ) ;
PyTuple_SetItem ( pylistRGB , pixelIndex , item ) ;
}
}
}
}
PyTuple_SetItem ( pyResultList , 2 , pylistRGB ) ;
PyTuple_SetItem ( pyResultList , 3 , pylistDep ) ;
PyTuple_SetItem ( pyResultList , 4 , pylistSeg ) ;
return pyResultList ;
# endif //PYBULLET_USE_NUMPY
return pyResultList ;
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
static PyObject * pybullet_applyExternalForce ( PyObject * self , PyObject * args , PyObject * keywds )
{
{
int objectUniqueId = - 1 , linkIndex = - 1 , flags ;
double force [ 3 ] ;
double position [ 3 ] = { 0.0 , 0.0 , 0.0 } ;
PyObject * forceObj = 0 , * posObj = 0 ;
b3SharedMemoryCommandHandle command ;
b3SharedMemoryStatusHandle statusHandle ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " objectUniqueId " , " linkIndex " ,
" forceObj " , " posObj " , " flags " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iiOOi|i " , kwlist , & objectUniqueId , & linkIndex ,
& forceObj , & posObj , & flags , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
PyObject * seq ;
int len , i ;
seq = PySequence_Fast ( forceObj , " expected a sequence " ) ;
len = PySequence_Size ( forceObj ) ;
if ( len = = 3 )
{
for ( i = 0 ; i < 3 ; i + + )
{
force [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
}
else
{
PyErr_SetString ( SpamError , " force needs a 3 coordinates [x,y,z]. " ) ;
Py_DECREF ( seq ) ;
return NULL ;
}
Py_DECREF ( seq ) ;
}
{
PyObject * seq ;
int len , i ;
seq = PySequence_Fast ( posObj , " expected a sequence " ) ;
len = PySequence_Size ( posObj ) ;
if ( len = = 3 )
{
for ( i = 0 ; i < 3 ; i + + )
{
position [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
}
else
{
PyErr_SetString ( SpamError , " position needs a 3 coordinates [x,y,z]. " ) ;
Py_DECREF ( seq ) ;
return NULL ;
}
Py_DECREF ( seq ) ;
}
if ( ( flags ! = EF_WORLD_FRAME ) & & ( flags ! = EF_LINK_FRAME ) )
{
PyErr_SetString ( SpamError ,
" flag has to be either WORLD_FRAME or LINK_FRAME " ) ;
return NULL ;
}
command = b3ApplyExternalForceCommandInit ( sm ) ;
b3ApplyExternalForce ( command , objectUniqueId , linkIndex , force , position ,
flags ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-11-17 23:15:52 +00:00
}
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_applyExternalTorque ( PyObject * self , PyObject * args , PyObject * keywds )
{
{
int objectUniqueId , linkIndex , flags ;
double torque [ 3 ] ;
PyObject * torqueObj ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " objectUniqueId " , " linkIndex " , " torqueObj " ,
" flags " , " physicsClientId " , NULL } ;
2016-11-17 23:15:52 +00:00
2017-03-13 23:06:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iiOi|i " , kwlist , & objectUniqueId , & linkIndex , & torqueObj ,
& flags , & physicsClientId ) )
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
2016-08-02 18:12:23 +00:00
2017-03-13 23:06:52 +00:00
{
PyObject * seq ;
int len , i ;
seq = PySequence_Fast ( torqueObj , " expected a sequence " ) ;
len = PySequence_Size ( torqueObj ) ;
if ( len = = 3 )
{
for ( i = 0 ; i < 3 ; i + + )
{
torque [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
}
else
{
PyErr_SetString ( SpamError , " torque needs a 3 coordinates [x,y,z]. " ) ;
Py_DECREF ( seq ) ;
return NULL ;
}
Py_DECREF ( seq ) ;
2016-06-24 22:30:43 +00:00
2017-03-13 23:06:52 +00:00
if ( linkIndex < - 1 )
{
PyErr_SetString ( SpamError ,
" Invalid link index, has to be -1 or larger " ) ;
return NULL ;
}
if ( ( flags ! = EF_WORLD_FRAME ) & & ( flags ! = EF_LINK_FRAME ) )
{
PyErr_SetString ( SpamError ,
" flag has to be either WORLD_FRAME or LINK_FRAME " ) ;
return NULL ;
}
{
b3SharedMemoryStatusHandle statusHandle ;
b3SharedMemoryCommandHandle command =
b3ApplyExternalForceCommandInit ( sm ) ;
2018-05-12 02:35:27 +00:00
b3ApplyExternalTorque ( command , objectUniqueId , linkIndex , torque , flags ) ;
2017-03-13 23:06:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
}
}
}
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2016-06-24 22:30:43 +00:00
2017-03-13 23:06:52 +00:00
static PyObject * pybullet_getQuaternionFromEuler ( PyObject * self ,
2017-08-25 21:04:45 +00:00
PyObject * args , PyObject * keywds )
2017-03-13 23:06:52 +00:00
{
double rpy [ 3 ] ;
2016-06-10 22:07:41 +00:00
2017-03-13 23:06:52 +00:00
PyObject * eulerObj ;
2018-09-23 21:17:31 +00:00
int physicsClientId = 0 ;
2017-08-25 21:04:45 +00:00
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " eulerAngles " , " physicsClientId " , NULL } ;
2016-12-29 05:51:54 +00:00
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " O|i " , kwlist , & eulerObj , & physicsClientId ) )
2017-08-25 21:04:45 +00:00
{
return NULL ;
}
if ( eulerObj )
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
PyObject * seq ;
int len , i ;
seq = PySequence_Fast ( eulerObj , " expected a sequence " ) ;
len = PySequence_Size ( eulerObj ) ;
if ( len = = 3 )
{
for ( i = 0 ; i < 3 ; i + + )
{
rpy [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
}
else
{
PyErr_SetString ( SpamError ,
" Euler angles need a 3 coordinates [roll, pitch, yaw]. " ) ;
Py_DECREF ( seq ) ;
return NULL ;
}
Py_DECREF ( seq ) ;
2016-12-28 04:25:52 +00:00
}
2017-03-13 23:06:52 +00:00
else
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
PyErr_SetString ( SpamError ,
" Euler angles need a 3 coordinates [roll, pitch, yaw]. " ) ;
2016-12-28 04:25:52 +00:00
return NULL ;
}
2017-03-13 23:06:52 +00:00
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
double phi , the , psi ;
double roll = rpy [ 0 ] ;
double pitch = rpy [ 1 ] ;
double yaw = rpy [ 2 ] ;
phi = roll / 2.0 ;
the = pitch / 2.0 ;
psi = yaw / 2.0 ;
{
double quat [ 4 ] = {
sin ( phi ) * cos ( the ) * cos ( psi ) - cos ( phi ) * sin ( the ) * sin ( psi ) ,
cos ( phi ) * sin ( the ) * cos ( psi ) + sin ( phi ) * cos ( the ) * sin ( psi ) ,
cos ( phi ) * cos ( the ) * sin ( psi ) - sin ( phi ) * sin ( the ) * cos ( psi ) ,
cos ( phi ) * cos ( the ) * cos ( psi ) + sin ( phi ) * sin ( the ) * sin ( psi ) } ;
// normalize the quaternion
double len = sqrt ( quat [ 0 ] * quat [ 0 ] + quat [ 1 ] * quat [ 1 ] +
quat [ 2 ] * quat [ 2 ] + quat [ 3 ] * quat [ 3 ] ) ;
quat [ 0 ] / = len ;
quat [ 1 ] / = len ;
quat [ 2 ] / = len ;
quat [ 3 ] / = len ;
{
PyObject * pylist ;
int i ;
pylist = PyTuple_New ( 4 ) ;
for ( i = 0 ; i < 4 ; i + + )
PyTuple_SetItem ( pylist , i , PyFloat_FromDouble ( quat [ i ] ) ) ;
return pylist ;
}
}
2016-12-28 04:25:52 +00:00
}
2017-03-13 23:06:52 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-06-27 01:18:30 +00:00
}
2017-05-30 04:55:58 +00:00
static PyObject * pybullet_multiplyTransforms ( PyObject * self ,
2018-09-23 21:17:31 +00:00
PyObject * args , PyObject * keywds )
2017-05-30 04:55:58 +00:00
{
PyObject * posAObj = 0 ;
PyObject * ornAObj = 0 ;
PyObject * posBObj = 0 ;
PyObject * ornBObj = 0 ;
2018-09-23 21:17:31 +00:00
int hasPosA = 0 ;
int hasOrnA = 0 ;
int hasPosB = 0 ;
int hasOrnB = 0 ;
2017-05-30 04:55:58 +00:00
double posA [ 3 ] ;
double ornA [ 4 ] = { 0 , 0 , 0 , 1 } ;
double posB [ 3 ] ;
double ornB [ 4 ] = { 0 , 0 , 0 , 1 } ;
2018-09-23 21:17:31 +00:00
int physicsClientId = 0 ;
2017-05-30 04:55:58 +00:00
2017-08-25 21:04:45 +00:00
static char * kwlist [ ] = { " positionA " , " orientationA " , " positionB " , " orientationB " , " physicsClientId " , NULL } ;
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " OOOO|i " , kwlist , & posAObj , & ornAObj , & posBObj , & ornBObj , & physicsClientId ) )
2017-05-30 04:55:58 +00:00
{
return NULL ;
}
2018-09-11 20:24:35 +00:00
2017-05-30 04:55:58 +00:00
hasPosA = pybullet_internalSetVectord ( posAObj , posA ) ;
hasOrnA = pybullet_internalSetVector4d ( ornAObj , ornA ) ;
hasPosB = pybullet_internalSetVectord ( posBObj , posB ) ;
2018-09-23 21:17:31 +00:00
hasOrnB = pybullet_internalSetVector4d ( ornBObj , ornB ) ;
2017-05-30 04:55:58 +00:00
2018-09-23 21:17:31 +00:00
if ( hasPosA & & hasOrnA & & hasPosB & & hasOrnB )
2017-05-30 04:55:58 +00:00
{
double outPos [ 3 ] ;
double outOrn [ 4 ] ;
int i ;
2018-09-23 21:17:31 +00:00
PyObject * pyListOutObj = 0 ;
PyObject * pyPosOutObj = 0 ;
PyObject * pyOrnOutObj = 0 ;
2017-05-30 04:55:58 +00:00
2018-09-23 21:17:31 +00:00
b3MultiplyTransforms ( posA , ornA , posB , ornB , outPos , outOrn ) ;
2017-05-30 04:55:58 +00:00
pyListOutObj = PyTuple_New ( 2 ) ;
pyPosOutObj = PyTuple_New ( 3 ) ;
pyOrnOutObj = PyTuple_New ( 4 ) ;
for ( i = 0 ; i < 3 ; i + + )
PyTuple_SetItem ( pyPosOutObj , i , PyFloat_FromDouble ( outPos [ i ] ) ) ;
for ( i = 0 ; i < 4 ; i + + )
PyTuple_SetItem ( pyOrnOutObj , i , PyFloat_FromDouble ( outOrn [ i ] ) ) ;
2018-09-11 20:24:35 +00:00
2017-05-30 04:55:58 +00:00
PyTuple_SetItem ( pyListOutObj , 0 , pyPosOutObj ) ;
PyTuple_SetItem ( pyListOutObj , 1 , pyOrnOutObj ) ;
return pyListOutObj ;
}
PyErr_SetString ( SpamError , " Invalid input: expected positionA [x,y,z], orientationA [x,y,z,w], positionB, orientationB. " ) ;
return NULL ;
}
static PyObject * pybullet_invertTransform ( PyObject * self ,
2018-09-23 21:17:31 +00:00
PyObject * args , PyObject * keywds )
2017-05-30 04:55:58 +00:00
{
PyObject * posObj = 0 ;
PyObject * ornObj = 0 ;
double pos [ 3 ] ;
double orn [ 4 ] = { 0 , 0 , 0 , 1 } ;
2018-09-23 21:17:31 +00:00
int hasPos = 0 ;
int hasOrn = 0 ;
2017-08-25 21:04:45 +00:00
int physicsClientId = 0 ;
2017-05-30 04:55:58 +00:00
2017-08-25 21:04:45 +00:00
static char * kwlist [ ] = { " position " , " orientation " , " physicsClientId " , NULL } ;
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " OO|i " , kwlist , & posObj , & ornObj , & physicsClientId ) )
2017-05-30 04:55:58 +00:00
{
return NULL ;
}
hasPos = pybullet_internalSetVectord ( posObj , pos ) ;
hasOrn = pybullet_internalSetVector4d ( ornObj , orn ) ;
2018-09-11 20:24:35 +00:00
2017-05-30 04:55:58 +00:00
if ( hasPos & & hasOrn )
{
double outPos [ 3 ] ;
double outOrn [ 4 ] ;
int i ;
2018-09-23 21:17:31 +00:00
PyObject * pyListOutObj = 0 ;
PyObject * pyPosOutObj = 0 ;
PyObject * pyOrnOutObj = 0 ;
2017-05-30 04:55:58 +00:00
b3InvertTransform ( pos , orn , outPos , outOrn ) ;
pyListOutObj = PyTuple_New ( 2 ) ;
pyPosOutObj = PyTuple_New ( 3 ) ;
pyOrnOutObj = PyTuple_New ( 4 ) ;
for ( i = 0 ; i < 3 ; i + + )
PyTuple_SetItem ( pyPosOutObj , i , PyFloat_FromDouble ( outPos [ i ] ) ) ;
for ( i = 0 ; i < 4 ; i + + )
PyTuple_SetItem ( pyOrnOutObj , i , PyFloat_FromDouble ( outOrn [ i ] ) ) ;
2018-09-11 20:24:35 +00:00
2017-05-30 04:55:58 +00:00
PyTuple_SetItem ( pyListOutObj , 0 , pyPosOutObj ) ;
PyTuple_SetItem ( pyListOutObj , 1 , pyOrnOutObj ) ;
return pyListOutObj ;
}
2018-09-11 20:24:35 +00:00
2017-05-30 04:55:58 +00:00
PyErr_SetString ( SpamError , " Invalid input: expected position [x,y,z] and orientation [x,y,z,w]. " ) ;
return NULL ;
}
2018-09-11 20:24:35 +00:00
2017-03-13 23:06:52 +00:00
/// quaternion <-> euler yaw/pitch/roll convention from URDF/SDF, see Gazebo
/// https://github.com/arpg/Gazebo/blob/master/gazebo/math/Quaternion.cc
static PyObject * pybullet_getEulerFromQuaternion ( PyObject * self ,
2017-08-25 21:04:45 +00:00
PyObject * args , PyObject * keywds )
2017-03-13 23:06:52 +00:00
{
double squ ;
double sqx ;
double sqy ;
double sqz ;
2016-06-27 01:18:30 +00:00
2017-03-13 23:06:52 +00:00
double quat [ 4 ] ;
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
PyObject * quatObj ;
2018-09-23 21:17:31 +00:00
int physicsClientId = 0 ;
2017-08-25 21:04:45 +00:00
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " quaternion " , " physicsClientId " , NULL } ;
2017-08-25 21:04:45 +00:00
2018-09-23 21:17:31 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " O|i " , kwlist , & quatObj , & physicsClientId ) )
2017-08-25 21:04:45 +00:00
{
return NULL ;
}
if ( quatObj )
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
PyObject * seq ;
int len , i ;
seq = PySequence_Fast ( quatObj , " expected a sequence " ) ;
len = PySequence_Size ( quatObj ) ;
if ( len = = 4 )
{
for ( i = 0 ; i < 4 ; i + + )
{
quat [ i ] = pybullet_internalGetFloatFromSequence ( seq , i ) ;
}
}
else
{
PyErr_SetString ( SpamError , " Quaternion need a 4 components [x,y,z,w]. " ) ;
Py_DECREF ( seq ) ;
return NULL ;
}
Py_DECREF ( seq ) ;
2016-12-28 04:25:52 +00:00
}
2017-03-13 23:06:52 +00:00
else
2016-12-28 04:25:52 +00:00
{
2017-03-13 23:06:52 +00:00
PyErr_SetString ( SpamError , " Quaternion need a 4 components [x,y,z,w]. " ) ;
2016-12-28 04:25:52 +00:00
return NULL ;
}
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
{
double rpy [ 3 ] ;
double sarg ;
sqx = quat [ 0 ] * quat [ 0 ] ;
sqy = quat [ 1 ] * quat [ 1 ] ;
sqz = quat [ 2 ] * quat [ 2 ] ;
squ = quat [ 3 ] * quat [ 3 ] ;
sarg = - 2 * ( quat [ 0 ] * quat [ 2 ] - quat [ 3 ] * quat [ 1 ] ) ;
2018-09-11 20:24:35 +00:00
2018-07-30 15:53:37 +00:00
// If the pitch angle is PI/2 or -PI/2, we can only compute
// the sum roll + yaw. However, any combination that gives
// the right sum will produce the correct orientation, so we
// set rollX = 0 and compute yawZ.
if ( sarg < = - 0.99999 )
{
2018-09-23 21:17:31 +00:00
rpy [ 0 ] = 0 ;
rpy [ 1 ] = - 0.5 * PYBULLET_PI ;
rpy [ 2 ] = 2 * atan2 ( quat [ 0 ] , - quat [ 1 ] ) ;
}
else if ( sarg > = 0.99999 )
2018-07-30 15:53:37 +00:00
{
2018-09-23 21:17:31 +00:00
rpy [ 0 ] = 0 ;
rpy [ 1 ] = 0.5 * PYBULLET_PI ;
rpy [ 2 ] = 2 * atan2 ( - quat [ 0 ] , quat [ 1 ] ) ;
}
else
2018-07-30 15:53:37 +00:00
{
rpy [ 0 ] = atan2 ( 2 * ( quat [ 1 ] * quat [ 2 ] + quat [ 3 ] * quat [ 0 ] ) , squ - sqx - sqy + sqz ) ;
rpy [ 1 ] = asin ( sarg ) ;
rpy [ 2 ] = atan2 ( 2 * ( quat [ 0 ] * quat [ 1 ] + quat [ 3 ] * quat [ 2 ] ) , squ + sqx - sqy - sqz ) ;
}
2017-03-13 23:06:52 +00:00
{
PyObject * pylist ;
int i ;
pylist = PyTuple_New ( 3 ) ;
for ( i = 0 ; i < 3 ; i + + )
PyTuple_SetItem ( pylist , i , PyFloat_FromDouble ( rpy [ i ] ) ) ;
return pylist ;
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-08-10 01:40:12 +00:00
}
2017-09-23 02:17:57 +00:00
static PyObject * pybullet_loadPlugin ( PyObject * self ,
2018-09-23 21:17:31 +00:00
PyObject * args , PyObject * keywds )
2017-09-23 02:17:57 +00:00
{
int physicsClientId = 0 ;
2018-09-11 20:24:35 +00:00
2017-09-23 02:17:57 +00:00
char * pluginPath = 0 ;
2017-10-03 22:00:52 +00:00
char * postFix = 0 ;
2017-09-23 02:17:57 +00:00
b3SharedMemoryCommandHandle command = 0 ;
2018-09-23 21:17:31 +00:00
b3SharedMemoryStatusHandle statusHandle = 0 ;
2017-09-23 02:17:57 +00:00
int statusType = - 1 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " pluginPath " , " postFix " , " physicsClientId " , NULL } ;
2017-10-03 22:00:52 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " s|si " , kwlist , & pluginPath , & postFix , & physicsClientId ) )
2017-09-23 02:17:57 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
command = b3CreateCustomCommand ( sm ) ;
2017-09-24 01:05:23 +00:00
b3CustomCommandLoadPlugin ( command , pluginPath ) ;
2017-10-03 22:00:52 +00:00
if ( postFix )
{
b3CustomCommandLoadPluginSetPostFix ( command , postFix ) ;
}
2017-09-23 02:17:57 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusPluginUniqueId ( statusHandle ) ;
return PyInt_FromLong ( statusType ) ;
}
static PyObject * pybullet_unloadPlugin ( PyObject * self ,
2018-09-23 21:17:31 +00:00
PyObject * args , PyObject * keywds )
2017-09-23 02:17:57 +00:00
{
int physicsClientId = 0 ;
int pluginUniqueId = - 1 ;
b3SharedMemoryCommandHandle command = 0 ;
2018-09-23 21:17:31 +00:00
b3SharedMemoryStatusHandle statusHandle = 0 ;
2017-09-23 02:17:57 +00:00
int statusType = - 1 ;
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " pluginUniqueId " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|i " , kwlist , & pluginUniqueId , & physicsClientId ) )
2017-09-23 02:17:57 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
command = b3CreateCustomCommand ( sm ) ;
b3CustomCommandUnloadPlugin ( command , pluginUniqueId ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
Py_INCREF ( Py_None ) ;
2018-09-23 21:17:31 +00:00
return Py_None ;
;
2017-09-23 02:17:57 +00:00
}
//createCustomCommand for executing commands implemented in a plugin system
static PyObject * pybullet_executePluginCommand ( PyObject * self ,
2018-09-23 21:17:31 +00:00
PyObject * args , PyObject * keywds )
2017-09-23 02:17:57 +00:00
{
int physicsClientId = 0 ;
int pluginUniqueId = - 1 ;
2017-09-24 01:05:23 +00:00
char * textArgument = 0 ;
2018-09-23 21:17:31 +00:00
b3SharedMemoryCommandHandle command = 0 ;
b3SharedMemoryStatusHandle statusHandle = 0 ;
2017-09-23 14:52:10 +00:00
int statusType = - 1 ;
2018-09-23 21:17:31 +00:00
PyObject * intArgs = 0 ;
PyObject * floatArgs = 0 ;
2017-09-23 02:17:57 +00:00
b3PhysicsClientHandle sm = 0 ;
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " pluginUniqueId " , " textArgument " , " intArgs " , " floatArgs " , " physicsClientId " , NULL } ;
2017-09-24 01:05:23 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " i|sOOi " , kwlist , & pluginUniqueId , & textArgument , & intArgs , & floatArgs , & physicsClientId ) )
2017-09-23 02:17:57 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
command = b3CreateCustomCommand ( sm ) ;
2017-09-24 01:05:23 +00:00
b3CustomCommandExecutePluginCommand ( command , pluginUniqueId , textArgument ) ;
{
2018-09-23 21:17:31 +00:00
PyObject * seqIntArgs = intArgs ? PySequence_Fast ( intArgs , " expected a sequence " ) : 0 ;
PyObject * seqFloatArgs = floatArgs ? PySequence_Fast ( floatArgs , " expected a sequence " ) : 0 ;
int numIntArgs = seqIntArgs ? PySequence_Size ( intArgs ) : 0 ;
int numFloatArgs = seqFloatArgs ? PySequence_Size ( floatArgs ) : 0 ;
2017-09-24 01:05:23 +00:00
int i ;
2018-09-23 21:17:31 +00:00
for ( i = 0 ; i < numIntArgs ; i + + )
2017-09-24 01:05:23 +00:00
{
2018-09-23 21:17:31 +00:00
int val = pybullet_internalGetIntFromSequence ( seqIntArgs , i ) ;
2017-09-24 01:05:23 +00:00
b3CustomCommandExecuteAddIntArgument ( command , val ) ;
}
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
for ( i = 0 ; i < numFloatArgs ; i + + )
2017-09-24 01:05:23 +00:00
{
2018-09-23 21:17:31 +00:00
float val = pybullet_internalGetFloatFromSequence ( seqFloatArgs , i ) ;
2017-09-24 01:05:23 +00:00
b3CustomCommandExecuteAddFloatArgument ( command , val ) ;
}
2018-06-05 22:59:01 +00:00
if ( seqFloatArgs )
{
Py_DECREF ( seqFloatArgs ) ;
}
if ( seqIntArgs )
{
Py_DECREF ( seqIntArgs ) ;
}
2017-09-24 01:05:23 +00:00
}
2018-09-11 20:24:35 +00:00
2017-09-23 02:17:57 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
statusType = b3GetStatusPluginCommandResult ( statusHandle ) ;
return PyInt_FromLong ( statusType ) ;
}
2016-12-15 05:11:53 +00:00
///Inverse Kinematics binding
static PyObject * pybullet_calculateInverseKinematics ( PyObject * self ,
2017-03-13 23:06:52 +00:00
PyObject * args , PyObject * keywds )
2016-12-28 04:25:52 +00:00
2017-03-13 23:06:52 +00:00
{
2017-05-28 20:30:20 +00:00
int bodyUniqueId ;
2017-03-13 23:06:52 +00:00
int endEffectorLinkIndex ;
2016-09-22 20:27:09 +00:00
2017-03-13 23:06:52 +00:00
PyObject * targetPosObj = 0 ;
PyObject * targetOrnObj = 0 ;
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
int solver = 0 ; // the default IK solver is DLS
2017-03-13 23:06:52 +00:00
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
PyObject * lowerLimitsObj = 0 ;
PyObject * upperLimitsObj = 0 ;
PyObject * jointRangesObj = 0 ;
PyObject * restPosesObj = 0 ;
PyObject * jointDampingObj = 0 ;
2018-05-31 23:06:15 +00:00
PyObject * currentPositionsObj = 0 ;
int maxNumIterations = - 1 ;
2018-09-23 21:17:31 +00:00
double residualThreshold = - 1 ;
2017-01-12 05:39:22 +00:00
2018-09-23 21:17:31 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " endEffectorLinkIndex " , " targetPosition " , " targetOrientation " , " lowerLimits " , " upperLimits " , " jointRanges " , " restPoses " , " jointDamping " , " solver " , " currentPositions " , " maxNumIterations " , " residualThreshold " , " physicsClientId " , NULL } ;
2018-05-31 23:06:15 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iiO|OOOOOOiOidi " , kwlist , & bodyUniqueId , & endEffectorLinkIndex , & targetPosObj , & targetOrnObj , & lowerLimitsObj , & upperLimitsObj , & jointRangesObj , & restPosesObj , & jointDampingObj , & solver , & currentPositionsObj , & maxNumIterations , & residualThreshold , & physicsClientId ) )
2016-12-28 04:25:52 +00:00
{
2017-05-28 20:30:20 +00:00
//backward compatibility bodyIndex -> bodyUniqueId. don't update keywords, people need to migrate to bodyUniqueId version
2018-09-23 21:17:31 +00:00
static char * kwlist2 [ ] = { " bodyIndex " , " endEffectorLinkIndex " , " targetPosition " , " targetOrientation " , " lowerLimits " , " upperLimits " , " jointRanges " , " restPoses " , " jointDamping " , " physicsClientId " , NULL } ;
2017-05-28 20:30:20 +00:00
PyErr_Clear ( ) ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iiO|OOOOOOi " , kwlist2 , & bodyUniqueId , & endEffectorLinkIndex , & targetPosObj , & targetOrnObj , & lowerLimitsObj , & upperLimitsObj , & jointRangesObj , & restPosesObj , & jointDampingObj , & physicsClientId ) )
{
return NULL ;
}
2016-12-28 04:25:52 +00:00
}
2016-12-29 05:51:54 +00:00
sm = getPhysicsClient ( physicsClientId ) ;
2017-03-13 23:06:52 +00:00
if ( sm = = 0 )
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
double pos [ 3 ] ;
2017-05-30 04:55:58 +00:00
double ori [ 4 ] = { 0 , 0 , 0 , 1 } ;
2017-03-13 23:06:52 +00:00
int hasPos = pybullet_internalSetVectord ( targetPosObj , pos ) ;
int hasOrn = pybullet_internalSetVector4d ( targetOrnObj , ori ) ;
2017-01-12 05:39:22 +00:00
int szLowerLimits = lowerLimitsObj ? PySequence_Size ( lowerLimitsObj ) : 0 ;
2017-03-13 23:06:52 +00:00
int szUpperLimits = upperLimitsObj ? PySequence_Size ( upperLimitsObj ) : 0 ;
int szJointRanges = jointRangesObj ? PySequence_Size ( jointRangesObj ) : 0 ;
int szRestPoses = restPosesObj ? PySequence_Size ( restPosesObj ) : 0 ;
int szJointDamping = jointDampingObj ? PySequence_Size ( jointDampingObj ) : 0 ;
2017-01-12 05:39:22 +00:00
2018-05-31 23:06:15 +00:00
int szCurrentPositions = currentPositionsObj ? PySequence_Size ( currentPositionsObj ) : 0 ;
2017-05-28 20:30:20 +00:00
int numJoints = b3GetNumJoints ( sm , bodyUniqueId ) ;
2018-05-31 23:06:15 +00:00
int dofCount = b3ComputeDofCount ( sm , bodyUniqueId ) ;
2017-01-12 05:39:22 +00:00
int hasNullSpace = 0 ;
2017-03-13 23:06:52 +00:00
int hasJointDamping = 0 ;
2018-05-31 23:06:15 +00:00
int hasCurrentPositions = 0 ;
2017-01-12 05:39:22 +00:00
double * lowerLimits = 0 ;
double * upperLimits = 0 ;
double * jointRanges = 0 ;
double * restPoses = 0 ;
2017-03-13 23:06:52 +00:00
double * jointDamping = 0 ;
2018-05-31 23:06:15 +00:00
double * currentPositions = 0 ;
2018-09-11 20:24:35 +00:00
2018-06-01 04:07:04 +00:00
if ( dofCount & & ( szLowerLimits = = dofCount ) & & ( szUpperLimits = = dofCount ) & &
( szJointRanges = = dofCount ) & & ( szRestPoses = = dofCount ) )
2017-01-12 05:39:22 +00:00
{
2018-06-01 04:07:04 +00:00
int szInBytes = sizeof ( double ) * dofCount ;
2017-01-12 05:39:22 +00:00
int i ;
lowerLimits = ( double * ) malloc ( szInBytes ) ;
upperLimits = ( double * ) malloc ( szInBytes ) ;
jointRanges = ( double * ) malloc ( szInBytes ) ;
restPoses = ( double * ) malloc ( szInBytes ) ;
2018-06-01 04:07:04 +00:00
for ( i = 0 ; i < dofCount ; i + + )
2017-01-12 05:39:22 +00:00
{
2018-06-01 04:07:04 +00:00
lowerLimits [ i ] = pybullet_internalGetFloatFromSequence ( lowerLimitsObj , i ) ;
upperLimits [ i ] = pybullet_internalGetFloatFromSequence ( upperLimitsObj , i ) ;
jointRanges [ i ] = pybullet_internalGetFloatFromSequence ( jointRangesObj , i ) ;
2018-09-23 21:17:31 +00:00
restPoses [ i ] = pybullet_internalGetFloatFromSequence ( restPosesObj , i ) ;
2017-01-12 05:39:22 +00:00
}
hasNullSpace = 1 ;
}
2017-03-13 23:06:52 +00:00
2018-05-31 23:06:15 +00:00
if ( szCurrentPositions > 0 )
{
2018-06-01 04:07:04 +00:00
if ( szCurrentPositions ! = dofCount )
2018-05-31 23:06:15 +00:00
{
PyErr_SetString ( SpamError ,
2018-06-01 04:07:04 +00:00
" calculateInverseKinematics the size of input current positions needs to be equal to the number of degrees of freedom. " ) ;
2018-05-31 23:06:15 +00:00
return NULL ;
}
else
{
int szInBytes = sizeof ( double ) * szCurrentPositions ;
int i ;
currentPositions = ( double * ) malloc ( szInBytes ) ;
for ( i = 0 ; i < szCurrentPositions ; i + + )
{
currentPositions [ i ] = pybullet_internalGetFloatFromSequence ( currentPositionsObj , i ) ;
}
hasCurrentPositions = 1 ;
}
}
2017-09-27 22:18:08 +00:00
if ( szJointDamping > 0 )
2017-03-13 23:06:52 +00:00
{
2018-06-02 06:25:47 +00:00
if ( szJointDamping < dofCount )
2017-03-13 23:06:52 +00:00
{
2018-06-02 06:25:47 +00:00
printf ( " calculateInverseKinematics: the size of input joint damping values should be equal to the number of degrees of freedom, not using joint damping. " ) ;
2017-09-27 22:18:08 +00:00
}
else
{
2018-06-02 18:37:14 +00:00
int szInBytes = sizeof ( double ) * szJointDamping ;
int i ;
2018-08-09 23:53:11 +00:00
//if (szJointDamping != dofCount)
//{
// printf("calculateInverseKinematics: the size of input joint damping values should be equal to the number of degrees of freedom, ignoring the additonal values.");
//}
2017-09-27 22:18:08 +00:00
jointDamping = ( double * ) malloc ( szInBytes ) ;
for ( i = 0 ; i < szJointDamping ; i + + )
{
jointDamping [ i ] = pybullet_internalGetFloatFromSequence ( jointDampingObj , i ) ;
}
hasJointDamping = 1 ;
2017-03-13 23:06:52 +00:00
}
}
2017-01-12 05:39:22 +00:00
if ( hasPos )
2016-12-28 04:25:52 +00:00
{
b3SharedMemoryStatusHandle statusHandle ;
2017-03-13 23:06:52 +00:00
int numPos = 0 ;
2016-12-28 04:25:52 +00:00
int resultBodyIndex ;
int result ;
2017-05-28 20:30:20 +00:00
b3SharedMemoryCommandHandle command = b3CalculateInverseKinematicsCommandInit ( sm , bodyUniqueId ) ;
2017-10-19 21:00:53 +00:00
b3CalculateInverseKinematicsSelectSolver ( command , solver ) ;
2017-01-12 05:39:22 +00:00
2018-05-31 23:06:15 +00:00
if ( hasCurrentPositions )
{
2018-06-01 04:07:04 +00:00
b3CalculateInverseKinematicsSetCurrentPositions ( command , dofCount , currentPositions ) ;
2018-05-31 23:06:15 +00:00
}
2018-09-23 21:17:31 +00:00
if ( maxNumIterations > 0 )
2018-05-31 23:06:15 +00:00
{
2018-09-23 21:17:31 +00:00
b3CalculateInverseKinematicsSetMaxNumIterations ( command , maxNumIterations ) ;
2018-05-31 23:06:15 +00:00
}
2018-09-23 21:17:31 +00:00
if ( residualThreshold > = 0 )
2018-05-31 23:06:15 +00:00
{
2018-09-23 21:17:31 +00:00
b3CalculateInverseKinematicsSetResidualThreshold ( command , residualThreshold ) ;
2018-05-31 23:06:15 +00:00
}
2017-01-12 05:39:22 +00:00
if ( hasNullSpace )
{
if ( hasOrn )
{
2018-06-01 04:07:04 +00:00
b3CalculateInverseKinematicsPosOrnWithNullSpaceVel ( command , dofCount , endEffectorLinkIndex , pos , ori , lowerLimits , upperLimits , jointRanges , restPoses ) ;
2017-03-13 23:06:52 +00:00
}
else
2017-01-12 05:39:22 +00:00
{
2018-06-01 04:07:04 +00:00
b3CalculateInverseKinematicsPosWithNullSpaceVel ( command , dofCount , endEffectorLinkIndex , pos , lowerLimits , upperLimits , jointRanges , restPoses ) ;
2017-01-12 05:39:22 +00:00
}
2017-03-13 23:06:52 +00:00
}
else
2017-01-12 05:39:22 +00:00
{
if ( hasOrn )
{
2017-03-13 23:06:52 +00:00
b3CalculateInverseKinematicsAddTargetPositionWithOrientation ( command , endEffectorLinkIndex , pos , ori ) ;
}
else
2017-01-12 05:39:22 +00:00
{
2017-03-13 23:06:52 +00:00
b3CalculateInverseKinematicsAddTargetPurePosition ( command , endEffectorLinkIndex , pos ) ;
2017-01-12 05:39:22 +00:00
}
}
2017-03-13 23:06:52 +00:00
if ( hasJointDamping )
{
2018-06-01 04:07:04 +00:00
b3CalculateInverseKinematicsSetJointDamping ( command , dofCount , jointDamping ) ;
2017-03-13 23:06:52 +00:00
}
2018-05-31 23:06:15 +00:00
free ( currentPositions ) ;
2017-09-27 23:42:29 +00:00
free ( jointDamping ) ;
2017-01-12 05:39:22 +00:00
2016-12-28 04:25:52 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , command ) ;
2017-03-13 23:06:52 +00:00
2016-12-28 04:25:52 +00:00
result = b3GetStatusInverseKinematicsJointPositions ( statusHandle ,
2017-03-13 23:06:52 +00:00
& resultBodyIndex ,
& numPos ,
0 ) ;
2016-12-28 04:25:52 +00:00
if ( result & & numPos )
{
int i ;
PyObject * pylist ;
2017-03-13 23:06:52 +00:00
double * ikOutPutJointPos = ( double * ) malloc ( numPos * sizeof ( double ) ) ;
2016-12-28 04:25:52 +00:00
result = b3GetStatusInverseKinematicsJointPositions ( statusHandle ,
& resultBodyIndex ,
& numPos ,
ikOutPutJointPos ) ;
pylist = PyTuple_New ( numPos ) ;
for ( i = 0 ; i < numPos ; i + + )
{
PyTuple_SetItem ( pylist , i ,
PyFloat_FromDouble ( ikOutPutJointPos [ i ] ) ) ;
}
2017-03-13 23:06:52 +00:00
2016-12-28 04:25:52 +00:00
free ( ikOutPutJointPos ) ;
return pylist ;
}
else
{
PyErr_SetString ( SpamError ,
" Error in calculateInverseKinematics " ) ;
return NULL ;
}
2017-03-13 23:06:52 +00:00
}
else
2016-12-28 04:25:52 +00:00
{
PyErr_SetString ( SpamError ,
2017-03-13 23:06:52 +00:00
" calculateInverseKinematics couldn't extract position vector3 " ) ;
2016-12-28 04:25:52 +00:00
return NULL ;
}
}
2016-09-13 22:37:46 +00:00
2017-03-13 23:06:52 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2016-09-13 22:37:46 +00:00
2016-09-08 18:12:58 +00:00
/// Given an object id, joint positions, joint velocities and joint
/// accelerations,
/// compute the joint forces using Inverse Dynamics
2017-09-24 02:58:59 +00:00
static PyObject * pybullet_calculateInverseDynamics ( PyObject * self , PyObject * args , PyObject * keywds )
2016-12-28 04:25:52 +00:00
{
{
2017-05-28 20:30:20 +00:00
int bodyUniqueId ;
2017-03-13 23:06:52 +00:00
PyObject * objPositionsQ ;
PyObject * objVelocitiesQdot ;
PyObject * objAccelerations ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
2017-09-24 02:58:59 +00:00
static char * kwlist [ ] = { " bodyUniqueId " , " objPositions " ,
" objVelocities " , " objAccelerations " ,
" physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iOOO|i " , kwlist ,
& bodyUniqueId , & objPositionsQ ,
& objVelocitiesQdot , & objAccelerations ,
& physicsClientId ) )
{
static char * kwlist2 [ ] = { " bodyIndex " , " objPositions " ,
" objVelocities " , " objAccelerations " ,
" physicsClientId " , NULL } ;
2017-05-28 20:30:20 +00:00
PyErr_Clear ( ) ;
2017-09-24 02:58:59 +00:00
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iOOO|i " , kwlist2 ,
2018-09-23 21:17:31 +00:00
& bodyUniqueId , & objPositionsQ , & objVelocitiesQdot ,
& objAccelerations , & physicsClientId ) )
2017-05-28 20:30:20 +00:00
{
2018-09-23 21:17:31 +00:00
return NULL ;
2017-05-28 20:30:20 +00:00
}
2017-03-13 23:06:52 +00:00
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
int szObPos = PySequence_Size ( objPositionsQ ) ;
int szObVel = PySequence_Size ( objVelocitiesQdot ) ;
int szObAcc = PySequence_Size ( objAccelerations ) ;
2018-09-11 20:24:35 +00:00
2018-05-31 23:06:15 +00:00
int dofCountOrg = b3ComputeDofCount ( sm , bodyUniqueId ) ;
2017-10-13 21:19:25 +00:00
if ( dofCountOrg & & ( szObPos = = dofCountOrg ) & & ( szObVel = = dofCountOrg ) & &
( szObAcc = = dofCountOrg ) )
2017-03-13 23:06:52 +00:00
{
2017-10-13 21:19:25 +00:00
int szInBytes = sizeof ( double ) * dofCountOrg ;
2017-03-13 23:06:52 +00:00
int i ;
PyObject * pylist = 0 ;
double * jointPositionsQ = ( double * ) malloc ( szInBytes ) ;
double * jointVelocitiesQdot = ( double * ) malloc ( szInBytes ) ;
double * jointAccelerations = ( double * ) malloc ( szInBytes ) ;
double * jointForcesOutput = ( double * ) malloc ( szInBytes ) ;
2017-10-13 21:19:25 +00:00
for ( i = 0 ; i < dofCountOrg ; i + + )
2017-03-13 23:06:52 +00:00
{
jointPositionsQ [ i ] =
pybullet_internalGetFloatFromSequence ( objPositionsQ , i ) ;
jointVelocitiesQdot [ i ] =
pybullet_internalGetFloatFromSequence ( objVelocitiesQdot , i ) ;
jointAccelerations [ i ] =
pybullet_internalGetFloatFromSequence ( objAccelerations , i ) ;
}
{
b3SharedMemoryStatusHandle statusHandle ;
int statusType ;
b3SharedMemoryCommandHandle commandHandle =
b3CalculateInverseDynamicsCommandInit (
2017-05-28 20:30:20 +00:00
sm , bodyUniqueId , jointPositionsQ , jointVelocitiesQdot ,
2017-03-13 23:06:52 +00:00
jointAccelerations ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CALCULATED_INVERSE_DYNAMICS_COMPLETED )
{
int bodyUniqueId ;
int dofCount ;
b3GetStatusInverseDynamicsJointForces ( statusHandle , & bodyUniqueId ,
& dofCount , 0 ) ;
if ( dofCount )
{
b3GetStatusInverseDynamicsJointForces ( statusHandle , 0 , 0 ,
jointForcesOutput ) ;
{
{
int i ;
pylist = PyTuple_New ( dofCount ) ;
for ( i = 0 ; i < dofCount ; i + + )
PyTuple_SetItem ( pylist , i ,
PyFloat_FromDouble ( jointForcesOutput [ i ] ) ) ;
}
}
}
}
else
{
PyErr_SetString ( SpamError ,
" Internal error in calculateInverseDynamics " ) ;
}
}
free ( jointPositionsQ ) ;
free ( jointVelocitiesQdot ) ;
free ( jointAccelerations ) ;
free ( jointForcesOutput ) ;
if ( pylist ) return pylist ;
}
else
{
PyErr_SetString ( SpamError ,
2017-10-13 21:19:25 +00:00
" calculateInverseDynamics numDofs needs to be "
2017-03-13 23:06:52 +00:00
" positive and [joint positions], [joint velocities], "
" [joint accelerations] need to match the number of "
2017-10-13 21:19:25 +00:00
" degrees of freedom. " ) ;
2017-03-13 23:06:52 +00:00
return NULL ;
}
}
2016-12-28 04:25:52 +00:00
}
2017-03-13 23:06:52 +00:00
Py_INCREF ( Py_None ) ;
return Py_None ;
2016-09-08 18:12:58 +00:00
}
2016-06-10 22:07:41 +00:00
2017-09-24 02:58:59 +00:00
/// Given an object id, joint positions, joint velocities and joint
2017-09-24 16:49:53 +00:00
/// accelerations, compute the Jacobian
2017-09-24 02:58:59 +00:00
static PyObject * pybullet_calculateJacobian ( PyObject * self , PyObject * args , PyObject * keywds )
{
{
int bodyUniqueId ;
int linkIndex ;
PyObject * localPosition ;
PyObject * objPositions ;
PyObject * objVelocities ;
PyObject * objAccelerations ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " bodyUniqueId " , " linkIndex " , " localPosition " ,
" objPositions " , " objVelocities " ,
" objAccelerations " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iiOOOO|i " , kwlist ,
2018-09-23 21:17:31 +00:00
& bodyUniqueId , & linkIndex , & localPosition , & objPositions ,
& objVelocities , & objAccelerations , & physicsClientId ) )
2017-09-24 02:58:59 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
int szLoPos = PySequence_Size ( localPosition ) ;
int szObPos = PySequence_Size ( objPositions ) ;
int szObVel = PySequence_Size ( objVelocities ) ;
int szObAcc = PySequence_Size ( objAccelerations ) ;
int numJoints = b3GetNumJoints ( sm , bodyUniqueId ) ;
2018-03-26 09:40:42 +00:00
2018-09-23 21:17:31 +00:00
int j = 0 ;
2018-03-26 09:40:42 +00:00
int dofCountOrg = 0 ;
2018-09-23 21:17:31 +00:00
for ( j = 0 ; j < numJoints ; j + + )
2018-03-26 09:40:42 +00:00
{
struct b3JointInfo info ;
b3GetJointInfo ( sm , bodyUniqueId , j , & info ) ;
switch ( info . m_jointType )
{
2018-09-23 21:17:31 +00:00
case eRevoluteType :
2018-03-26 09:40:42 +00:00
{
2018-09-23 21:17:31 +00:00
dofCountOrg + = 1 ;
2018-03-26 09:40:42 +00:00
break ;
}
2018-09-23 21:17:31 +00:00
case ePrismaticType :
2018-03-26 09:40:42 +00:00
{
2018-09-23 21:17:31 +00:00
dofCountOrg + = 1 ;
2018-03-26 09:40:42 +00:00
break ;
}
2018-09-23 21:17:31 +00:00
case eSphericalType :
2018-03-26 09:40:42 +00:00
{
PyErr_SetString ( SpamError ,
2018-09-23 21:17:31 +00:00
" Spherirical joints are not supported in the pybullet binding " ) ;
2018-03-26 09:40:42 +00:00
return NULL ;
}
2018-09-23 21:17:31 +00:00
case ePlanarType :
2018-03-26 09:40:42 +00:00
{
PyErr_SetString ( SpamError ,
2018-09-23 21:17:31 +00:00
" Planar joints are not supported in the pybullet binding " ) ;
2018-03-26 09:40:42 +00:00
return NULL ;
}
default :
{
//fixed joint has 0-dof and at the moment, we don't deal with planar, spherical etc
}
}
}
if ( dofCountOrg & & ( szLoPos = = 3 ) & & ( szObPos = = dofCountOrg ) & &
( szObVel = = dofCountOrg ) & & ( szObAcc = = dofCountOrg ) )
2017-09-24 02:58:59 +00:00
{
2018-03-26 09:40:42 +00:00
int byteSizeJoints = sizeof ( double ) * dofCountOrg ;
2018-09-23 21:17:31 +00:00
int byteSizeVec3 = sizeof ( double ) * 3 ;
2017-09-24 02:58:59 +00:00
int i ;
PyObject * pyResultList = PyTuple_New ( 2 ) ;
double * localPoint = ( double * ) malloc ( byteSizeVec3 ) ;
double * jointPositions = ( double * ) malloc ( byteSizeJoints ) ;
double * jointVelocities = ( double * ) malloc ( byteSizeJoints ) ;
double * jointAccelerations = ( double * ) malloc ( byteSizeJoints ) ;
2017-10-01 03:39:56 +00:00
double * linearJacobian = NULL ;
double * angularJacobian = NULL ;
2017-09-24 02:58:59 +00:00
pybullet_internalSetVectord ( localPosition , localPoint ) ;
2018-03-26 09:40:42 +00:00
for ( i = 0 ; i < dofCountOrg ; i + + )
2017-09-24 02:58:59 +00:00
{
jointPositions [ i ] =
pybullet_internalGetFloatFromSequence ( objPositions , i ) ;
jointVelocities [ i ] =
pybullet_internalGetFloatFromSequence ( objVelocities , i ) ;
jointAccelerations [ i ] =
pybullet_internalGetFloatFromSequence ( objAccelerations , i ) ;
}
{
2018-09-11 20:24:35 +00:00
b3SharedMemoryStatusHandle statusHandle ;
2017-09-25 14:38:00 +00:00
int statusType ;
2017-09-24 02:58:59 +00:00
b3SharedMemoryCommandHandle commandHandle =
b3CalculateJacobianCommandInit ( sm , bodyUniqueId ,
2018-09-23 21:17:31 +00:00
linkIndex , localPoint , jointPositions ,
jointVelocities , jointAccelerations ) ;
2017-09-24 02:58:59 +00:00
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
2017-09-25 14:38:00 +00:00
statusType = b3GetStatusType ( statusHandle ) ;
2017-09-24 02:58:59 +00:00
if ( statusType = = CMD_CALCULATED_JACOBIAN_COMPLETED )
{
int dofCount ;
b3GetStatusJacobian ( statusHandle , & dofCount , NULL , NULL ) ;
if ( dofCount )
{
int byteSizeDofCount = sizeof ( double ) * dofCount ;
double * linearJacobian = ( double * ) malloc ( 3 * byteSizeDofCount ) ;
double * angularJacobian = ( double * ) malloc ( 3 * byteSizeDofCount ) ;
b3GetStatusJacobian ( statusHandle ,
NULL ,
linearJacobian ,
angularJacobian ) ;
if ( linearJacobian )
{
2017-09-24 16:16:54 +00:00
int r ;
2017-09-24 02:58:59 +00:00
PyObject * pymat = PyTuple_New ( 3 ) ;
2018-09-23 21:17:31 +00:00
for ( r = 0 ; r < 3 ; + + r )
{
2017-09-24 16:16:54 +00:00
int c ;
2017-09-24 02:58:59 +00:00
PyObject * pyrow = PyTuple_New ( dofCount ) ;
2018-09-23 21:17:31 +00:00
for ( c = 0 ; c < dofCount ; + + c )
{
2017-09-24 02:58:59 +00:00
int element = r * dofCount + c ;
PyTuple_SetItem ( pyrow , c ,
2018-09-23 21:17:31 +00:00
PyFloat_FromDouble ( linearJacobian [ element ] ) ) ;
2017-09-24 02:58:59 +00:00
}
PyTuple_SetItem ( pymat , r , pyrow ) ;
}
PyTuple_SetItem ( pyResultList , 0 , pymat ) ;
}
if ( angularJacobian )
{
2017-09-24 16:16:54 +00:00
int r ;
2018-09-23 21:17:31 +00:00
PyObject * pymat = PyTuple_New ( 3 ) ;
for ( r = 0 ; r < 3 ; + + r )
{
2017-09-24 16:16:54 +00:00
int c ;
2017-09-24 02:58:59 +00:00
PyObject * pyrow = PyTuple_New ( dofCount ) ;
2018-09-23 21:17:31 +00:00
for ( c = 0 ; c < dofCount ; + + c )
{
2017-09-24 02:58:59 +00:00
int element = r * dofCount + c ;
PyTuple_SetItem ( pyrow , c ,
2018-09-23 21:17:31 +00:00
PyFloat_FromDouble ( angularJacobian [ element ] ) ) ;
2017-09-24 02:58:59 +00:00
}
PyTuple_SetItem ( pymat , r , pyrow ) ;
}
PyTuple_SetItem ( pyResultList , 1 , pymat ) ;
}
}
}
else
{
PyErr_SetString ( SpamError ,
" Internal error in calculateJacobian " ) ;
}
}
free ( localPoint ) ;
free ( jointPositions ) ;
free ( jointVelocities ) ;
free ( jointAccelerations ) ;
free ( linearJacobian ) ;
free ( angularJacobian ) ;
if ( pyResultList ) return pyResultList ;
}
else
{
PyErr_SetString ( SpamError ,
2018-03-26 09:40:42 +00:00
" calculateJacobian [numDof] needs to be "
2017-09-24 02:58:59 +00:00
" positive, [local position] needs to be of "
" size 3 and [joint positions], "
" [joint velocities], [joint accelerations] "
2018-03-26 09:40:42 +00:00
" need to match the number of DoF. " ) ;
2017-09-24 02:58:59 +00:00
return NULL ;
}
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2017-09-23 02:17:57 +00:00
2017-10-01 03:39:56 +00:00
/// Given an object id, joint positions, joint velocities and joint
/// accelerations, compute the Jacobian
static PyObject * pybullet_calculateMassMatrix ( PyObject * self , PyObject * args , PyObject * keywds )
{
{
int bodyUniqueId ;
PyObject * objPositions ;
int physicsClientId = 0 ;
b3PhysicsClientHandle sm = 0 ;
static char * kwlist [ ] = { " bodyUniqueId " , " objPositions " , " physicsClientId " , NULL } ;
if ( ! PyArg_ParseTupleAndKeywords ( args , keywds , " iO|i " , kwlist ,
2018-09-23 21:17:31 +00:00
& bodyUniqueId , & objPositions , & physicsClientId ) )
2017-10-01 03:39:56 +00:00
{
return NULL ;
}
sm = getPhysicsClient ( physicsClientId ) ;
if ( sm = = 0 )
{
PyErr_SetString ( SpamError , " Not connected to physics server. " ) ;
return NULL ;
}
{
int szObPos = PySequence_Size ( objPositions ) ;
int numJoints = b3GetNumJoints ( sm , bodyUniqueId ) ;
if ( numJoints & & ( szObPos = = numJoints ) )
{
int byteSizeJoints = sizeof ( double ) * numJoints ;
PyObject * pyResultList ;
double * jointPositions = ( double * ) malloc ( byteSizeJoints ) ;
double * massMatrix = NULL ;
int i ;
for ( i = 0 ; i < numJoints ; i + + )
{
jointPositions [ i ] =
pybullet_internalGetFloatFromSequence ( objPositions , i ) ;
}
{
2018-09-11 20:24:35 +00:00
b3SharedMemoryStatusHandle statusHandle ;
2017-10-01 03:39:56 +00:00
int statusType ;
b3SharedMemoryCommandHandle commandHandle =
b3CalculateMassMatrixCommandInit ( sm , bodyUniqueId , jointPositions ) ;
statusHandle = b3SubmitClientCommandAndWaitStatus ( sm , commandHandle ) ;
statusType = b3GetStatusType ( statusHandle ) ;
if ( statusType = = CMD_CALCULATED_MASS_MATRIX_COMPLETED )
{
int dofCount ;
2017-10-05 16:02:33 +00:00
b3GetStatusMassMatrix ( sm , statusHandle , & dofCount , NULL ) ;
2017-10-01 03:39:56 +00:00
if ( dofCount )
{
int byteSizeDofCount = sizeof ( double ) * dofCount ;
2017-10-05 16:02:33 +00:00
pyResultList = PyTuple_New ( dofCount ) ;
2018-09-11 20:24:35 +00:00
2017-10-01 03:39:56 +00:00
massMatrix = ( double * ) malloc ( dofCount * byteSizeDofCount ) ;
2017-10-05 16:02:33 +00:00
b3GetStatusMassMatrix ( sm , statusHandle , NULL , massMatrix ) ;
2017-10-01 03:39:56 +00:00
if ( massMatrix )
{
int r ;
2018-09-23 21:17:31 +00:00
for ( r = 0 ; r < dofCount ; + + r )
{
2017-10-01 03:39:56 +00:00
int c ;
PyObject * pyrow = PyTuple_New ( dofCount ) ;
2018-09-23 21:17:31 +00:00
for ( c = 0 ; c < dofCount ; + + c )
{
2017-10-01 03:39:56 +00:00
int element = r * dofCount + c ;
PyTuple_SetItem ( pyrow , c ,
2018-09-23 21:17:31 +00:00
PyFloat_FromDouble ( massMatrix [ element ] ) ) ;
2017-10-01 03:39:56 +00:00
}
PyTuple_SetItem ( pyResultList , r , pyrow ) ;
}
}
}
}
else
{
PyErr_SetString ( SpamError ,
" Internal error in calculateJacobian " ) ;
}
}
free ( jointPositions ) ;
free ( massMatrix ) ;
if ( pyResultList ) return pyResultList ;
}
else
{
PyErr_SetString ( SpamError ,
" calculateMassMatrix [numJoints] needs to be "
" positive and [joint positions] "
" need to match the number of joints. " ) ;
return NULL ;
}
}
}
Py_INCREF ( Py_None ) ;
return Py_None ;
}
2016-04-30 18:18:54 +00:00
static PyMethodDef SpamMethods [ ] = {
2016-06-10 22:07:41 +00:00
2017-03-13 23:06:52 +00:00
{ " connect " , ( PyCFunction ) pybullet_connectPhysicsServer , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" connect(method, key=SHARED_MEMORY_KEY, options='') \n "
" connect(method, hostname='localhost', port=1234, options='') \n "
2017-03-13 23:06:52 +00:00
" Connect to an existing physics server (using shared memory by default). " } ,
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
{ " disconnect " , ( PyCFunction ) pybullet_disconnectPhysicsServer , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" disconnect(physicsClientId=0) \n "
2017-03-13 23:06:52 +00:00
" Disconnect from the physics server. " } ,
2016-09-08 18:12:58 +00:00
2018-09-23 21:17:31 +00:00
{ " getConnectionInfo " , ( PyCFunction ) pybullet_getConnectionInfo , METH_VARARGS | METH_KEYWORDS ,
" getConnectionInfo(physicsClientId=0) \n "
" Return if a given client id is connected, and using what method. " } ,
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
{ " isConnected " , ( PyCFunction ) pybullet_isConnected , METH_VARARGS | METH_KEYWORDS ,
" isConnected(physicsClientId=0) \n "
" Return if a given client id is connected. " } ,
2018-01-12 05:04:08 +00:00
2017-03-13 23:06:52 +00:00
{ " resetSimulation " , ( PyCFunction ) pybullet_resetSimulation , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" resetSimulation(physicsClientId=0) \n "
2017-03-13 23:06:52 +00:00
" Reset the simulation: remove all objects and start from an empty world. " } ,
2016-06-10 22:07:41 +00:00
2017-03-13 23:06:52 +00:00
{ " stepSimulation " , ( PyCFunction ) pybullet_stepSimulation , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" stepSimulation(physicsClientId=0) \n "
2017-03-13 23:06:52 +00:00
" Step the simulation using forward dynamics. " } ,
2016-05-03 19:59:21 +00:00
2017-03-13 23:06:52 +00:00
{ " setGravity " , ( PyCFunction ) pybullet_setGravity , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" setGravity(gravX, gravY, gravZ, physicsClientId=0) \n "
2017-03-13 23:06:52 +00:00
" Set the gravity acceleration (x,y,z). " } ,
2016-05-10 07:57:54 +00:00
2017-03-13 23:06:52 +00:00
{ " setTimeStep " , ( PyCFunction ) pybullet_setTimeStep , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" setTimeStep(timestep, physicsClientId=0) \n "
2017-03-13 23:06:52 +00:00
" Set the amount of time to proceed at each call to stepSimulation. (unit "
" is seconds, typically range is 0.01 or 0.001) " } ,
2016-05-10 07:57:54 +00:00
2017-03-13 23:06:52 +00:00
{ " setDefaultContactERP " , ( PyCFunction ) pybullet_setDefaultContactERP , METH_VARARGS | METH_KEYWORDS ,
2017-09-24 21:14:24 +00:00
" setDefaultContactERP(defaultContactERP, physicsClientId=0) \n "
2017-03-13 23:06:52 +00:00
" Set the amount of contact penetration Error Recovery Paramater "
" (ERP) in each time step. \
This is an tuning parameter to control resting contact stability . "
" This value depends on the time step. " } ,
2016-12-01 06:24:20 +00:00
2017-03-13 23:06:52 +00:00
{ " setRealTimeSimulation " , ( PyCFunction ) pybullet_setRealTimeSimulation , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" setRealTimeSimulation(enableRealTimeSimulation, physicsClientId=0) \n "
2017-03-13 23:06:52 +00:00
" Enable or disable real time simulation (using the real time clock, "
" RTC) in the physics server. Expects one integer argument, 0 or 1 " } ,
2016-12-01 06:24:20 +00:00
2017-03-13 23:06:52 +00:00
{ " setPhysicsEngineParameter " , ( PyCFunction ) pybullet_setPhysicsEngineParameter , METH_VARARGS | METH_KEYWORDS ,
" Set some internal physics engine parameter, such as cfm or erp etc. " } ,
2016-07-18 06:50:11 +00:00
2018-09-23 21:17:31 +00:00
{ " getPhysicsEngineParameters " , ( PyCFunction ) pybullet_getPhysicsEngineParameters , METH_VARARGS | METH_KEYWORDS ,
2017-10-05 18:43:14 +00:00
" Get the current values of internal physics engine parameters " } ,
2017-03-13 23:06:52 +00:00
{ " setInternalSimFlags " , ( PyCFunction ) pybullet_setInternalSimFlags , METH_VARARGS | METH_KEYWORDS ,
" This is for experimental purposes, use at own risk, magic may or not happen " } ,
2016-12-01 06:24:20 +00:00
2017-03-13 23:06:52 +00:00
{ " loadURDF " , ( PyCFunction ) pybullet_loadURDF , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" bodyUniqueId = loadURDF(fileName, basePosition=[0.,0.,0.], baseOrientation=[0.,0.,0.,1.], "
" useMaximalCoordinates=0, useFixedBase=0, flags=0, globalScaling=1.0, physicsClientId=0) \n "
2017-03-13 23:06:52 +00:00
" Create a multibody by loading a URDF file. " } ,
2016-06-15 21:21:04 +00:00
2017-03-13 23:06:52 +00:00
{ " loadSDF " , ( PyCFunction ) pybullet_loadSDF , METH_VARARGS | METH_KEYWORDS ,
" Load multibodies from an SDF file. " } ,
2018-01-09 02:10:28 +00:00
# ifndef SKIP_SOFT_BODY_MULTI_BODY_DYNAMICS_WORLD
{ " loadSoftBody " , ( PyCFunction ) pybullet_loadSoftBody , METH_VARARGS | METH_KEYWORDS ,
" Load a softbody from an obj file. " } ,
# endif
2017-03-13 23:06:52 +00:00
{ " loadBullet " , ( PyCFunction ) pybullet_loadBullet , METH_VARARGS | METH_KEYWORDS ,
2017-12-28 18:05:51 +00:00
" Load a world from a .bullet file. " } ,
2016-11-11 22:44:50 +00:00
2017-03-13 23:06:52 +00:00
{ " saveBullet " , ( PyCFunction ) pybullet_saveBullet , METH_VARARGS | METH_KEYWORDS ,
" Save the full state of the world to a .bullet file. " } ,
2016-11-11 22:44:50 +00:00
2018-09-23 21:17:31 +00:00
{ " restoreState " , ( PyCFunction ) pybullet_restoreState , METH_VARARGS | METH_KEYWORDS ,
" Restore the full state of an existing world. " } ,
2017-12-28 18:05:51 +00:00
2018-09-23 21:17:31 +00:00
{ " saveState " , ( PyCFunction ) pybullet_saveState , METH_VARARGS | METH_KEYWORDS ,
" Save the full state of the world to memory. " } ,
2017-12-28 18:05:51 +00:00
2017-03-13 23:06:52 +00:00
{ " loadMJCF " , ( PyCFunction ) pybullet_loadMJCF , METH_VARARGS | METH_KEYWORDS ,
" Load multibodies from an MJCF file. " } ,
2016-11-11 22:44:50 +00:00
2017-06-03 17:57:56 +00:00
{ " createCollisionShape " , ( PyCFunction ) pybullet_createCollisionShape , METH_VARARGS | METH_KEYWORDS ,
" Create a collision shape. Returns a non-negative (int) unique id, if successfull, negative otherwise. " } ,
2018-09-23 21:17:31 +00:00
{ " createCollisionShapeArray " , ( PyCFunction ) pybullet_createCollisionShapeArray , METH_VARARGS | METH_KEYWORDS ,
" Create collision shapes. Returns a non-negative (int) unique id, if successfull, negative otherwise. " } ,
2018-01-08 20:25:56 +00:00
2018-09-22 21:18:21 +00:00
{ " removeCollisionShape " , ( PyCFunction ) pybullet_removeCollisionShape , METH_VARARGS | METH_KEYWORDS ,
" Remove a collision shape. Only useful when the collision shape is not used in a body (to perform a getClosestPoint query). " } ,
2018-09-23 21:17:31 +00:00
2017-06-03 17:57:56 +00:00
{ " createVisualShape " , ( PyCFunction ) pybullet_createVisualShape , METH_VARARGS | METH_KEYWORDS ,
" Create a visual shape. Returns a non-negative (int) unique id, if successfull, negative otherwise. " } ,
2018-09-23 21:17:31 +00:00
{ " createVisualShapeArray " , ( PyCFunction ) pybullet_createVisualShapeArray , METH_VARARGS | METH_KEYWORDS ,
" Create visual shapes. Returns a non-negative (int) unique id, if successfull, negative otherwise. " } ,
2018-03-10 02:02:06 +00:00
2017-06-03 17:57:56 +00:00
{ " createMultiBody " , ( PyCFunction ) pybullet_createMultiBody , METH_VARARGS | METH_KEYWORDS ,
" Create a multi body. Returns a non-negative (int) unique id, if successfull, negative otherwise. " } ,
2017-03-13 23:06:52 +00:00
{ " createConstraint " , ( PyCFunction ) pybullet_createUserConstraint , METH_VARARGS | METH_KEYWORDS ,
" Create a constraint between two bodies. Returns a (int) unique id, if successfull. " } ,
2016-11-14 22:08:05 +00:00
2017-01-12 18:30:46 +00:00
{ " changeConstraint " , ( PyCFunction ) pybullet_changeUserConstraint , METH_VARARGS | METH_KEYWORDS ,
2017-03-13 23:06:52 +00:00
" Change some parameters of an existing constraint, such as the child pivot or child frame orientation, using its unique id. " } ,
2017-01-12 18:30:46 +00:00
2016-11-14 22:08:05 +00:00
{ " removeConstraint " , ( PyCFunction ) pybullet_removeUserConstraint , METH_VARARGS | METH_KEYWORDS ,
2017-03-13 23:06:52 +00:00
" Remove a constraint using its unique id. " } ,
{ " enableJointForceTorqueSensor " , ( PyCFunction ) pybullet_enableJointForceTorqueSensor , METH_VARARGS | METH_KEYWORDS ,
" Enable or disable a joint force/torque sensor measuring the joint reaction forces. " } ,
{ " saveWorld " , ( PyCFunction ) pybullet_saveWorld , METH_VARARGS | METH_KEYWORDS ,
" Save a approximate Python file to reproduce the current state of the world: saveWorld "
" (filename). (very preliminary and approximately) " } ,
{ " getNumBodies " , ( PyCFunction ) pybullet_getNumBodies , METH_VARARGS | METH_KEYWORDS ,
" Get the number of bodies in the simulation. " } ,
{ " getBodyUniqueId " , ( PyCFunction ) pybullet_getBodyUniqueId , METH_VARARGS | METH_KEYWORDS ,
" getBodyUniqueId is used after connecting to server with existing bodies. "
2017-01-23 03:08:31 +00:00
" Get the unique id of the body, given a integer range [0.. number of bodies). " } ,
2016-09-27 19:13:45 +00:00
2017-03-13 23:06:52 +00:00
{ " getBodyInfo " , ( PyCFunction ) pybullet_getBodyInfo , METH_VARARGS | METH_KEYWORDS ,
" Get the body info, given a body unique id. " } ,
2018-09-23 21:17:31 +00:00
{ " syncBodyInfo " , ( PyCFunction ) pybullet_syncBodyInfo , METH_VARARGS | METH_KEYWORDS ,
" syncBodyInfo(physicsClientId=0) \n "
" Update body and constraint/joint information, in case other clients made changes. " } ,
2018-09-11 20:24:35 +00:00
2018-06-02 20:40:08 +00:00
{ " syncUserData " , ( PyCFunction ) pybullet_syncUserData , METH_VARARGS | METH_KEYWORDS ,
" syncUserData(physicsClientId=0) \n "
" Update user data, in case other clients made changes. " } ,
{ " addUserData " , ( PyCFunction ) pybullet_addUserData , METH_VARARGS | METH_KEYWORDS ,
2018-07-03 15:45:19 +00:00
" addUserData(bodyUniqueId, key, value, linkIndex=-1, visualShapeIndex=-1, physicsClientId=0) \n "
" Adds or updates a user data entry. Returns user data identifier. " } ,
2018-06-02 20:40:08 +00:00
{ " getUserData " , ( PyCFunction ) pybullet_getUserData , METH_VARARGS | METH_KEYWORDS ,
2018-07-03 15:45:19 +00:00
" getUserData(userDataId, physicsClientId=0) \n "
2018-06-02 20:40:08 +00:00
" Returns the user data value. " } ,
{ " removeUserData " , ( PyCFunction ) pybullet_removeUserData , METH_VARARGS | METH_KEYWORDS ,
2018-07-03 15:45:19 +00:00
" removeUserData(userDataId, physicsClientId=0) \n "
2018-06-02 20:40:08 +00:00
" Removes a user data entry. " } ,
{ " getUserDataId " , ( PyCFunction ) pybullet_getUserDataId , METH_VARARGS | METH_KEYWORDS ,
2018-07-03 15:45:19 +00:00
" getUserDataId(bodyUniqueId, key, linkIndex=-1, visualShapeIndex=-1, physicsClientId=0) \n "
" Retrieves the userDataId given the key and optionally link and visual shape index. " } ,
2018-06-02 20:40:08 +00:00
{ " getNumUserData " , ( PyCFunction ) pybullet_getNumUserData , METH_VARARGS | METH_KEYWORDS ,
2018-07-03 15:45:19 +00:00
" getNumUserData(bodyUniqueId physicsClientId=0) \n "
" Retrieves the number of user data entries in a body. " } ,
2018-06-02 20:40:08 +00:00
{ " getUserDataInfo " , ( PyCFunction ) pybullet_getUserDataInfo , METH_VARARGS | METH_KEYWORDS ,
2018-07-03 15:45:19 +00:00
" getUserDataInfo(bodyUniqueId, userDataIndex, physicsClientId=0) \n "
" Retrieves the key and the identifier of a user data as (userDataId, key, bodyUniqueId, linkIndex, visualShapeIndex). " } ,
2018-06-02 20:40:08 +00:00
2017-05-04 04:53:29 +00:00
{ " removeBody " , ( PyCFunction ) pybullet_removeBody , METH_VARARGS | METH_KEYWORDS ,
" Remove a body by its body unique id. " } ,
2017-03-13 23:06:52 +00:00
{ " getNumConstraints " , ( PyCFunction ) pybullet_getNumConstraints , METH_VARARGS | METH_KEYWORDS ,
" Get the number of user-created constraints in the simulation. " } ,
{ " getConstraintInfo " , ( PyCFunction ) pybullet_getConstraintInfo , METH_VARARGS | METH_KEYWORDS ,
" Get the user-created constraint info, given a constraint unique id. " } ,
2018-09-23 21:17:31 +00:00
{ " getConstraintState " , ( PyCFunction ) pybullet_getConstraintState , METH_VARARGS | METH_KEYWORDS ,
" Get the user-created constraint state (applied forces), given a constraint unique id. " } ,
2017-10-19 02:15:35 +00:00
2017-05-04 01:25:25 +00:00
{ " getConstraintUniqueId " , ( PyCFunction ) pybullet_getConstraintUniqueId , METH_VARARGS | METH_KEYWORDS ,
2017-03-13 23:06:52 +00:00
" Get the unique id of the constraint, given a integer index in range [0.. number of constraints). " } ,
{ " getBasePositionAndOrientation " , ( PyCFunction ) pybullet_getBasePositionAndOrientation ,
METH_VARARGS | METH_KEYWORDS ,
" Get the world position and orientation of the base of the object. "
" (x,y,z) position vector and (x,y,z,w) quaternion orientation. " } ,
2017-06-16 02:46:27 +00:00
{ " getAABB " , ( PyCFunction ) pybullet_getAABB ,
METH_VARARGS | METH_KEYWORDS ,
" Get the axis aligned bound box min and max coordinates in world space. " } ,
2017-03-13 23:06:52 +00:00
{ " resetBasePositionAndOrientation " ,
( PyCFunction ) pybullet_resetBasePositionAndOrientation , METH_VARARGS | METH_KEYWORDS ,
" Reset the world position and orientation of the base of the object "
" instantaneously, not through physics simulation. (x,y,z) position vector "
" and (x,y,z,w) quaternion orientation. " } ,
{ " getBaseVelocity " , ( PyCFunction ) pybullet_getBaseVelocity ,
METH_VARARGS | METH_KEYWORDS ,
" Get the linear and angular velocity of the base of the object "
" in world space coordinates. "
" (x,y,z) linear velocity vector and (x,y,z) angular velocity vector. " } ,
{ " resetBaseVelocity " , ( PyCFunction ) pybullet_resetBaseVelocity , METH_VARARGS | METH_KEYWORDS ,
" Reset the linear and/or angular velocity of the base of the object "
" in world space coordinates. "
" linearVelocity (x,y,z) and angularVelocity (x,y,z). " } ,
{ " getNumJoints " , ( PyCFunction ) pybullet_getNumJoints , METH_VARARGS | METH_KEYWORDS ,
" Get the number of joints for an object. " } ,
{ " getJointInfo " , ( PyCFunction ) pybullet_getJointInfo , METH_VARARGS | METH_KEYWORDS ,
" Get the name and type info for a joint on a body. " } ,
{ " getJointState " , ( PyCFunction ) pybullet_getJointState , METH_VARARGS | METH_KEYWORDS ,
" Get the state (position, velocity etc) for a joint on a body. " } ,
2017-05-14 01:07:49 +00:00
{ " getJointStates " , ( PyCFunction ) pybullet_getJointStates , METH_VARARGS | METH_KEYWORDS ,
" Get the state (position, velocity etc) for multiple joints on a body. " } ,
2017-03-29 22:37:33 +00:00
{ " getLinkState " , ( PyCFunction ) pybullet_getLinkState , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" position_linkcom_world, world_rotation_linkcom, \n "
" position_linkcom_frame, frame_rotation_linkcom, \n "
" position_frame_world, world_rotation_frame, \n "
" linearVelocity_linkcom_world, angularVelocity_linkcom_world \n "
" = getLinkState(objectUniqueId, linkIndex, computeLinkVelocity=0, \n "
" computeForwardKinematics=0, physicsClientId=0) \n "
2017-03-13 23:06:52 +00:00
" Provides extra information such as the Cartesian world coordinates "
" center of mass (COM) of the link, relative to the world reference "
" frame. " } ,
{ " resetJointState " , ( PyCFunction ) pybullet_resetJointState , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" resetJointState(objectUniqueId, jointIndex, targetValue, targetVelocity=0, physicsClientId=0) \n "
" Reset the state (position, velocity etc) for a joint on a body "
" instantaneously, not through physics simulation. " } ,
2018-09-11 20:24:35 +00:00
2017-05-13 16:18:36 +00:00
{ " changeDynamics " , ( PyCFunction ) pybullet_changeDynamicsInfo , METH_VARARGS | METH_KEYWORDS ,
2017-05-09 17:44:33 +00:00
" change dynamics information such as mass, lateral friction coefficient. " } ,
2018-09-11 20:24:35 +00:00
2017-05-09 17:31:28 +00:00
{ " getDynamicsInfo " , ( PyCFunction ) pybullet_getDynamicsInfo , METH_VARARGS | METH_KEYWORDS ,
" Get dynamics information such as mass, lateral friction coefficient. " } ,
2017-03-13 23:06:52 +00:00
{ " setJointMotorControl " , ( PyCFunction ) pybullet_setJointMotorControl , METH_VARARGS ,
" This (obsolete) method cannot select non-zero physicsClientId, use setJointMotorControl2 instead. "
" Set a single joint motor control mode and desired target value. There is "
" no immediate state change, stepSimulation will process the motors. " } ,
{ " setJointMotorControl2 " , ( PyCFunction ) pybullet_setJointMotorControl2 , METH_VARARGS | METH_KEYWORDS ,
2016-12-28 04:25:52 +00:00
" Set a single joint motor control mode and desired target value. There is "
2017-03-13 23:06:52 +00:00
" no immediate state change, stepSimulation will process the motors. " } ,
2017-05-08 20:41:07 +00:00
{ " setJointMotorControlArray " , ( PyCFunction ) pybullet_setJointMotorControlArray , METH_VARARGS | METH_KEYWORDS ,
" Set an array of motors control mode and desired target value. There is "
" no immediate state change, stepSimulation will process the motors. "
" This is similar to setJointMotorControl2, with jointIndices as a list, and optional targetPositions, "
" targetVelocities, forces, kds and kps as lists "
2018-09-23 21:17:31 +00:00
" Using setJointMotorControlArray has the benefit of lower calling overhead. " } ,
2017-05-08 20:41:07 +00:00
2017-03-13 23:06:52 +00:00
{ " applyExternalForce " , ( PyCFunction ) pybullet_applyExternalForce , METH_VARARGS | METH_KEYWORDS ,
" for objectUniqueId, linkIndex (-1 for base/root link), apply a force "
" [x,y,z] at the a position [x,y,z], flag to select FORCE_IN_LINK_FRAME or "
" WORLD_FRAME coordinates " } ,
{ " applyExternalTorque " , ( PyCFunction ) pybullet_applyExternalTorque , METH_VARARGS | METH_KEYWORDS ,
" for objectUniqueId, linkIndex (-1 for base/root link) apply a torque "
" [x,y,z] in Cartesian coordinates, flag to select TORQUE_IN_LINK_FRAME or "
" WORLD_FRAME coordinates " } ,
{ " renderImage " , pybullet_renderImageObsolete , METH_VARARGS ,
" obsolete, please use getCameraImage and getViewProjectionMatrices instead " } ,
{ " getCameraImage " , ( PyCFunction ) pybullet_getCameraImage , METH_VARARGS | METH_KEYWORDS ,
" Render an image (given the pixel resolution width, height, camera viewMatrix "
" , projectionMatrix, lightDirection, lightColor, lightDistance, shadow, lightAmbientCoeff, lightDiffuseCoeff, lightSpecularCoeff, and renderer), and return the "
" 8-8-8bit RGB pixel data and floating point depth values "
2016-09-11 10:35:12 +00:00
# ifdef PYBULLET_USE_NUMPY
2017-03-13 23:06:52 +00:00
" as NumPy arrays "
2016-09-11 10:35:12 +00:00
# endif
2017-03-13 23:06:52 +00:00
} ,
2016-11-17 23:15:52 +00:00
2018-09-23 21:17:31 +00:00
{ " isNumpyEnabled " , ( PyCFunction ) pybullet_isNumpyEnabled , METH_VARARGS | METH_KEYWORDS ,
" return True if PyBullet was compiled with NUMPY support. This makes the getCameraImage API faster " } ,
2018-05-23 03:26:00 +00:00
2017-03-13 23:06:52 +00:00
{ " computeViewMatrix " , ( PyCFunction ) pybullet_computeViewMatrix , METH_VARARGS | METH_KEYWORDS ,
" Compute a camera viewmatrix from camera eye, target position and up vector " } ,
2016-11-17 23:15:52 +00:00
2017-03-13 23:06:52 +00:00
{ " computeViewMatrixFromYawPitchRoll " , ( PyCFunction ) pybullet_computeViewMatrixFromYawPitchRoll , METH_VARARGS | METH_KEYWORDS ,
" Compute a camera viewmatrix from camera eye, target position and up vector " } ,
2016-11-17 23:15:52 +00:00
2017-03-13 23:06:52 +00:00
{ " computeProjectionMatrix " , ( PyCFunction ) pybullet_computeProjectionMatrix , METH_VARARGS | METH_KEYWORDS ,
" Compute a camera projection matrix from screen left/right/bottom/top/near/far values " } ,
2016-06-27 01:18:30 +00:00
2017-03-13 23:06:52 +00:00
{ " computeProjectionMatrixFOV " , ( PyCFunction ) pybullet_computeProjectionMatrixFOV , METH_VARARGS | METH_KEYWORDS ,
" Compute a camera projection matrix from fov, aspect ratio, near, far values " } ,
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
{ " getContactPoints " , ( PyCFunction ) pybullet_getContactPointData , METH_VARARGS | METH_KEYWORDS ,
" Return existing contact points after the stepSimulation command. "
" Optional arguments one or two object unique "
" ids, that need to be involved in the contact. " } ,
2016-11-10 05:01:04 +00:00
2017-03-13 23:06:52 +00:00
{ " getClosestPoints " , ( PyCFunction ) pybullet_getClosestPointData , METH_VARARGS | METH_KEYWORDS ,
" Compute the closest points between two objects, if the distance is below a given threshold. "
" Input is two objects unique ids and distance threshold. " } ,
2016-11-14 15:39:34 +00:00
2017-03-13 23:06:52 +00:00
{ " getOverlappingObjects " , ( PyCFunction ) pybullet_getOverlappingObjects , METH_VARARGS | METH_KEYWORDS ,
" Return all the objects that have overlap with a given "
" axis-aligned bounding box volume (AABB). "
" Input are two vectors defining the AABB in world space [min_x,min_y,min_z],[max_x,max_y,max_z]. " } ,
2016-11-14 15:39:34 +00:00
2018-09-23 21:17:31 +00:00
{ " setCollisionFilterPair " , ( PyCFunction ) pybullet_setCollisionFilterPair , METH_VARARGS | METH_KEYWORDS ,
2018-09-13 02:30:49 +00:00
" Enable or disable collision detection between two object links. "
" Input are two object unique ids and two link indices and an enum "
" to enable or disable collisions. " } ,
2018-09-23 21:17:31 +00:00
{ " setCollisionFilterGroupMask " , ( PyCFunction ) pybullet_setCollisionFilterGroupMask , METH_VARARGS | METH_KEYWORDS ,
2018-09-13 02:30:49 +00:00
" Set the collision filter group and the mask for a body. " } ,
2018-09-23 21:17:31 +00:00
2017-03-13 23:06:52 +00:00
{ " addUserDebugLine " , ( PyCFunction ) pybullet_addUserDebugLine , METH_VARARGS | METH_KEYWORDS ,
2016-11-14 15:39:34 +00:00
" Add a user debug draw line with lineFrom[3], lineTo[3], lineColorRGB[3], lineWidth, lifeTime. "
2017-03-13 23:06:52 +00:00
" A lifeTime of 0 means permanent until removed. Returns a unique id for the user debug item. " } ,
2016-11-14 15:39:34 +00:00
2017-03-13 23:06:52 +00:00
{ " addUserDebugText " , ( PyCFunction ) pybullet_addUserDebugText , METH_VARARGS | METH_KEYWORDS ,
2016-11-14 15:39:34 +00:00
" Add a user debug draw line with text, textPosition[3], textSize and lifeTime in seconds "
2017-03-13 23:06:52 +00:00
" A lifeTime of 0 means permanent until removed. Returns a unique id for the user debug item. " } ,
{ " addUserDebugParameter " , ( PyCFunction ) pybullet_addUserDebugParameter , METH_VARARGS | METH_KEYWORDS ,
" Add a user debug parameter, such as a slider, that can be controlled using a GUI. " } ,
{ " readUserDebugParameter " , ( PyCFunction ) pybullet_readUserDebugParameter , METH_VARARGS | METH_KEYWORDS ,
" Read the current value of a user debug parameter, given the user debug item unique id. " } ,
{ " removeUserDebugItem " , ( PyCFunction ) pybullet_removeUserDebugItem , METH_VARARGS | METH_KEYWORDS ,
" remove a user debug draw item, giving its unique id " } ,
{ " removeAllUserDebugItems " , ( PyCFunction ) pybullet_removeAllUserDebugItems , METH_VARARGS | METH_KEYWORDS ,
" remove all user debug draw items " } ,
{ " setDebugObjectColor " , ( PyCFunction ) pybullet_setDebugObjectColor , METH_VARARGS | METH_KEYWORDS ,
" Override the wireframe debug drawing color for a particular object unique id / link index. "
" If you ommit the color, the custom color will be removed. " } ,
2017-04-10 18:03:41 +00:00
{ " getDebugVisualizerCamera " , ( PyCFunction ) pybullet_getDebugVisualizerCamera , METH_VARARGS | METH_KEYWORDS ,
" Get information about the 3D visualizer camera, such as width, height, view matrix, projection matrix etc. " } ,
2017-03-13 23:06:52 +00:00
{ " configureDebugVisualizer " , ( PyCFunction ) pybullet_configureDebugVisualizer , METH_VARARGS | METH_KEYWORDS ,
" For the 3D OpenGL Visualizer, enable/disable GUI, shadows. " } ,
{ " resetDebugVisualizerCamera " , ( PyCFunction ) pybullet_resetDebugVisualizerCamera , METH_VARARGS | METH_KEYWORDS ,
" For the 3D OpenGL Visualizer, set the camera distance, yaw, pitch and target position. " } ,
{ " getVisualShapeData " , ( PyCFunction ) pybullet_getVisualShapeData , METH_VARARGS | METH_KEYWORDS ,
" Return the visual shape information for one object. " } ,
2018-09-23 21:17:31 +00:00
{ " getCollisionShapeData " , ( PyCFunction ) pybullet_getCollisionShapeData , METH_VARARGS | METH_KEYWORDS ,
" Return the collision shape information for one object. " } ,
2018-01-04 03:17:28 +00:00
2017-05-13 16:18:36 +00:00
{ " changeVisualShape " , ( PyCFunction ) pybullet_changeVisualShape , METH_VARARGS | METH_KEYWORDS ,
" Change part of the visual shape information for one object. " } ,
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
{ " resetVisualShapeData " , ( PyCFunction ) pybullet_changeVisualShape , METH_VARARGS | METH_KEYWORDS ,
2017-05-13 16:18:36 +00:00
" Obsolete method, kept for backward compatibility, use changeVisualShapeData instead. " } ,
2017-03-13 23:06:52 +00:00
{ " loadTexture " , ( PyCFunction ) pybullet_loadTexture , METH_VARARGS | METH_KEYWORDS ,
" Load texture file. " } ,
2017-07-01 02:11:43 +00:00
{ " changeTexture " , ( PyCFunction ) pybullet_changeTexture , METH_VARARGS | METH_KEYWORDS ,
" Change a texture file. " } ,
2018-09-23 21:17:31 +00:00
{ " getQuaternionFromEuler " , ( PyCFunction ) pybullet_getQuaternionFromEuler , METH_VARARGS | METH_KEYWORDS ,
2017-03-13 23:06:52 +00:00
" Convert Euler [roll, pitch, yaw] as in URDF/SDF convention, to "
" quaternion [x,y,z,w] " } ,
2018-09-23 21:17:31 +00:00
{ " getEulerFromQuaternion " , ( PyCFunction ) pybullet_getEulerFromQuaternion , METH_VARARGS | METH_KEYWORDS ,
2017-03-13 23:06:52 +00:00
" Convert quaternion [x,y,z,w] to Euler [roll, pitch, yaw] as in URDF/SDF "
" convention " } ,
2018-09-23 21:17:31 +00:00
{ " multiplyTransforms " , ( PyCFunction ) pybullet_multiplyTransforms , METH_VARARGS | METH_KEYWORDS ,
2017-05-30 04:55:58 +00:00
" Multiply two transform, provided as [position], [quaternion]. " } ,
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
{ " invertTransform " , ( PyCFunction ) pybullet_invertTransform , METH_VARARGS | METH_KEYWORDS ,
2017-05-30 04:55:58 +00:00
" Invert a transform, provided as [position], [quaternion]. " } ,
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
{ " getMatrixFromQuaternion " , ( PyCFunction ) pybullet_getMatrixFromQuaternion , METH_VARARGS | METH_KEYWORDS ,
2017-03-13 23:06:52 +00:00
" Compute the 3x3 matrix from a quaternion, as a list of 9 values (row-major) " } ,
{ " calculateInverseDynamics " , ( PyCFunction ) pybullet_calculateInverseDynamics , METH_VARARGS | METH_KEYWORDS ,
" Given an object id, joint positions, joint velocities and joint "
" accelerations, compute the joint forces using Inverse Dynamics " } ,
2018-09-23 21:17:31 +00:00
{ " calculateJacobian " , ( PyCFunction ) pybullet_calculateJacobian , METH_VARARGS | METH_KEYWORDS ,
2017-10-01 03:39:56 +00:00
" linearJacobian, angularJacobian = calculateJacobian(bodyUniqueId, "
" linkIndex, localPosition, objPositions, objVelocities, objAccelerations, physicsClientId=0) \n "
2017-09-24 02:58:59 +00:00
" Compute the jacobian for a specified local position on a body and its kinematics. \n "
" Args: \n "
" bodyIndex - a scalar defining the unique object id. \n "
" linkIndex - a scalar identifying the link containing the local point. \n "
2017-09-28 05:23:22 +00:00
" localPosition - a list of [x, y, z] of the coordinates defined in the link frame. \n "
2017-09-24 02:58:59 +00:00
" objPositions - a list of the joint positions. \n "
" objVelocities - a list of the joint velocities. \n "
" objAccelerations - a list of the joint accelerations. \n "
" Returns: \n "
" linearJacobian - a list of the partial linear velocities of the jacobian. \n "
" angularJacobian - a list of the partial angular velocities of the jacobian. \n " } ,
2018-09-11 20:24:35 +00:00
2017-10-01 03:39:56 +00:00
{ " calculateMassMatrix " , ( PyCFunction ) pybullet_calculateMassMatrix , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" massMatrix = calculateMassMatrix(bodyUniqueId, objPositions, physicsClientId=0) \n "
2017-10-01 03:39:56 +00:00
" Compute the mass matrix for an object and its chain of bodies. \n "
" Args: \n "
" bodyIndex - a scalar defining the unique object id. \n "
" objPositions - a list of the joint positions. \n "
" Returns: \n "
" massMatrix - a list of lists of the mass matrix components. \n " } ,
2017-09-24 02:58:59 +00:00
2017-03-13 23:06:52 +00:00
{ " calculateInverseKinematics " , ( PyCFunction ) pybullet_calculateInverseKinematics ,
METH_VARARGS | METH_KEYWORDS ,
" Inverse Kinematics bindings: Given an object id, "
" current joint positions and target position "
" for the end effector, "
" compute the inverse kinematics and return the new joint state " } ,
{ " getVREvents " , ( PyCFunction ) pybullet_getVREvents , METH_VARARGS | METH_KEYWORDS ,
" Get Virtual Reality events, for example to track VR controllers position/buttons " } ,
{ " setVRCameraState " , ( PyCFunction ) pybullet_setVRCameraState , METH_VARARGS | METH_KEYWORDS ,
" Set properties of the VR Camera such as its root transform "
" for teleporting or to track objects (camera inside a vehicle for example). " } ,
{ " getKeyboardEvents " , ( PyCFunction ) pybullet_getKeyboardEvents , METH_VARARGS | METH_KEYWORDS ,
2017-06-17 20:29:14 +00:00
" Get keyboard events, keycode and state (KEY_IS_DOWN, KEY_WAS_TRIGGERED, KEY_WAS_RELEASED) " } ,
2018-09-23 21:17:31 +00:00
{ " getMouseEvents " , ( PyCFunction ) pybullet_getMouseEvents , METH_VARARGS | METH_KEYWORDS ,
2017-06-17 20:29:14 +00:00
" Get mouse events, event type and button state (KEY_IS_DOWN, KEY_WAS_TRIGGERED, KEY_WAS_RELEASED) " } ,
2017-03-13 23:06:52 +00:00
{ " startStateLogging " , ( PyCFunction ) pybullet_startStateLogging , METH_VARARGS | METH_KEYWORDS ,
" Start logging of state, such as robot base position, orientation, joint positions etc. "
2017-04-02 23:03:20 +00:00
" Specify loggingType (STATE_LOGGING_MINITAUR, STATE_LOGGING_GENERIC_ROBOT, STATE_LOGGING_VR_CONTROLLERS, STATE_LOGGING_CONTACT_POINTS, etc), "
2017-04-04 20:45:49 +00:00
" fileName, optional objectUniqueId, maxLogDof, bodyUniqueIdA, bodyUniqueIdB, linkIndexA, linkIndexB. Function returns int loggingUniqueId " } ,
2017-03-13 23:06:52 +00:00
{ " stopStateLogging " , ( PyCFunction ) pybullet_stopStateLogging , METH_VARARGS | METH_KEYWORDS ,
" Stop logging of robot state, given a loggingUniqueId. " } ,
2017-04-05 22:21:26 +00:00
{ " rayTest " , ( PyCFunction ) pybullet_rayTestObsolete , METH_VARARGS | METH_KEYWORDS ,
2017-03-13 23:06:52 +00:00
" Cast a ray and return the first object hit, if any. "
2017-04-05 22:21:26 +00:00
" Takes two arguments (from_position [x,y,z] and to_position [x,y,z] in Cartesian world coordinates " } ,
{ " rayTestBatch " , ( PyCFunction ) pybullet_rayTestBatch , METH_VARARGS | METH_KEYWORDS ,
2018-09-23 21:17:31 +00:00
" Cast a batch of rays and return the result for each of the rays (first object hit, if any. or -1) "
2018-06-15 15:46:31 +00:00
" Takes two required arguments (list of from_positions [x,y,z] and a list of to_positions [x,y,z] in Cartesian world coordinates) "
" and one optional argument numThreads to specify the number of threads to use to compute the ray intersections for the batch. "
2018-06-15 15:46:12 +00:00
" Specify 0 to let Bullet decide, 1 (default) for single core execution, 2 or more to select the number of threads to use. " } ,
2017-04-05 22:21:26 +00:00
2018-09-23 21:17:31 +00:00
{ " loadPlugin " , ( PyCFunction ) pybullet_loadPlugin , METH_VARARGS | METH_KEYWORDS ,
" Load a plugin, could implement custom commands etc. " } ,
2017-09-23 02:17:57 +00:00
2018-09-23 21:17:31 +00:00
{ " unloadPlugin " , ( PyCFunction ) pybullet_unloadPlugin , METH_VARARGS | METH_KEYWORDS ,
" Unload a plugin, given the pluginUniqueId. " } ,
2017-09-23 02:17:57 +00:00
2018-09-23 21:17:31 +00:00
{ " executePluginCommand " , ( PyCFunction ) pybullet_executePluginCommand , METH_VARARGS | METH_KEYWORDS ,
" Execute a command, implemented in a plugin. " } ,
2017-09-23 02:17:57 +00:00
2017-05-05 00:51:40 +00:00
{ " submitProfileTiming " , ( PyCFunction ) pybullet_submitProfileTiming , METH_VARARGS | METH_KEYWORDS ,
" Add a custom profile timing that will be visible in performance profile recordings on the physics server. "
2018-09-23 21:17:31 +00:00
" On the physics server (in GUI and VR mode) you can press 'p' to start and/or stop profile recordings " } ,
2017-05-05 00:51:40 +00:00
2017-03-13 23:06:52 +00:00
{ " setTimeOut " , ( PyCFunction ) pybullet_setTimeOut , METH_VARARGS | METH_KEYWORDS ,
" Set the timeOut in seconds, used for most of the API calls. " } ,
2017-06-16 02:46:27 +00:00
2017-08-28 02:34:00 +00:00
{ " setAdditionalSearchPath " , ( PyCFunction ) pybullet_setAdditionalSearchPath ,
METH_VARARGS | METH_KEYWORDS ,
" Set an additional search path, used to load URDF/SDF files. " } ,
2017-06-16 02:46:27 +00:00
{ " getAPIVersion " , ( PyCFunction ) pybullet_getAPIVersion ,
METH_VARARGS | METH_KEYWORDS ,
" Get version of the API. Compatibility exists for connections using the same API version. Make sure both client and server use the same number of bits (32-bit or 64bit). " } ,
2017-03-13 23:06:52 +00:00
// todo(erwincoumans)
// saveSnapshot
// loadSnapshot
// raycast info
// object names
{ NULL , NULL , 0 , NULL } /* Sentinel */
2016-04-30 18:18:54 +00:00
} ;
2017-03-13 23:06:52 +00:00
///copied from CommonWindowInterface.h
2017-03-02 20:33:22 +00:00
2017-03-13 23:06:52 +00:00
enum
{
2017-03-02 20:33:22 +00:00
B3G_ESCAPE = 27 ,
B3G_F1 = 0xff00 ,
B3G_F2 ,
B3G_F3 ,
B3G_F4 ,
B3G_F5 ,
B3G_F6 ,
B3G_F7 ,
B3G_F8 ,
B3G_F9 ,
B3G_F10 ,
B3G_F11 ,
B3G_F12 ,
B3G_F13 ,
B3G_F14 ,
B3G_F15 ,
B3G_LEFT_ARROW ,
B3G_RIGHT_ARROW ,
B3G_UP_ARROW ,
B3G_DOWN_ARROW ,
B3G_PAGE_UP ,
B3G_PAGE_DOWN ,
B3G_END ,
B3G_HOME ,
B3G_INSERT ,
B3G_DELETE ,
B3G_BACKSPACE ,
B3G_SHIFT ,
B3G_CONTROL ,
B3G_ALT ,
B3G_RETURN
} ;
2016-05-10 07:57:54 +00:00
# if PY_MAJOR_VERSION >= 3
2016-09-08 18:12:58 +00:00
static struct PyModuleDef moduledef = {
2017-03-13 23:06:52 +00:00
PyModuleDef_HEAD_INIT , " pybullet " , /* m_name */
" Python bindings for Bullet Physics Robotics API (also known as Shared "
" Memory API) " , /* m_doc */
- 1 , /* m_size */
SpamMethods , /* m_methods */
NULL , /* m_reload */
NULL , /* m_traverse */
NULL , /* m_clear */
NULL , /* m_free */
2016-09-08 18:12:58 +00:00
} ;
2016-05-10 07:57:54 +00:00
# endif
2016-04-30 18:18:54 +00:00
PyMODINIT_FUNC
2016-05-10 07:57:54 +00:00
# if PY_MAJOR_VERSION >= 3
PyInit_pybullet ( void )
# else
2016-04-30 18:18:54 +00:00
initpybullet ( void )
2016-05-10 07:57:54 +00:00
# endif
2016-04-30 18:18:54 +00:00
{
2017-03-13 23:06:52 +00:00
PyObject * m ;
2016-05-10 07:57:54 +00:00
# if PY_MAJOR_VERSION >= 3
2017-03-13 23:06:52 +00:00
m = PyModule_Create ( & moduledef ) ;
2016-05-10 07:57:54 +00:00
# else
2017-03-13 23:06:52 +00:00
m = Py_InitModule3 ( " pybullet " , SpamMethods , " Python bindings for Bullet " ) ;
2016-05-10 07:57:54 +00:00
# endif
2016-05-18 22:07:42 +00:00
# if PY_MAJOR_VERSION >= 3
2017-03-13 23:06:52 +00:00
if ( m = = NULL ) return m ;
2016-05-18 22:07:42 +00:00
# else
2017-03-13 23:06:52 +00:00
if ( m = = NULL ) return ;
2016-05-18 22:07:42 +00:00
# endif
2016-09-08 18:12:58 +00:00
2017-03-13 23:06:52 +00:00
PyModule_AddIntConstant ( m , " SHARED_MEMORY " ,
2018-09-23 21:17:31 +00:00
eCONNECT_SHARED_MEMORY ) ; // user read
PyModule_AddIntConstant ( m , " DIRECT " , eCONNECT_DIRECT ) ; // user read
PyModule_AddIntConstant ( m , " GUI " , eCONNECT_GUI ) ; // user read
PyModule_AddIntConstant ( m , " UDP " , eCONNECT_UDP ) ; // user read
PyModule_AddIntConstant ( m , " TCP " , eCONNECT_TCP ) ; // user read
PyModule_AddIntConstant ( m , " GUI_SERVER " , eCONNECT_GUI_SERVER ) ; // user read
PyModule_AddIntConstant ( m , " GUI_MAIN_THREAD " , eCONNECT_GUI_MAIN_THREAD ) ; // user read
PyModule_AddIntConstant ( m , " SHARED_MEMORY_SERVER " , eCONNECT_SHARED_MEMORY_SERVER ) ; // user read
2018-07-01 21:42:32 +00:00
# ifdef BT_ENABLE_DART
2018-09-23 21:17:31 +00:00
PyModule_AddIntConstant ( m , " DART " , eCONNECT_DART ) ; // user read
2018-07-01 21:42:32 +00:00
# endif
# ifdef BT_ENABLE_MUJOCO
2018-09-23 21:17:31 +00:00
PyModule_AddIntConstant ( m , " MuJoCo " , eCONNECT_MUJOCO ) ; // user read
2018-07-01 21:42:32 +00:00
# endif
2018-09-04 06:13:15 +00:00
# ifdef BT_ENABLE_GRPC
2018-09-23 21:17:31 +00:00
PyModule_AddIntConstant ( m , " GRPC " , eCONNECT_GRPC ) ; // user read
2018-09-04 06:13:15 +00:00
# endif
2018-07-01 21:42:32 +00:00
2018-09-23 21:17:31 +00:00
PyModule_AddIntConstant ( m , " SHARED_MEMORY_KEY " , SHARED_MEMORY_KEY ) ;
PyModule_AddIntConstant ( m , " SHARED_MEMORY_KEY2 " , SHARED_MEMORY_KEY + 1 ) ;
2018-09-11 20:24:35 +00:00
2017-03-13 23:06:52 +00:00
PyModule_AddIntConstant ( m , " JOINT_REVOLUTE " , eRevoluteType ) ; // user read
PyModule_AddIntConstant ( m , " JOINT_PRISMATIC " , ePrismaticType ) ; // user read
PyModule_AddIntConstant ( m , " JOINT_SPHERICAL " , eSphericalType ) ; // user read
PyModule_AddIntConstant ( m , " JOINT_PLANAR " , ePlanarType ) ; // user read
PyModule_AddIntConstant ( m , " JOINT_FIXED " , eFixedType ) ; // user read
PyModule_AddIntConstant ( m , " JOINT_POINT2POINT " , ePoint2PointType ) ; // user read
2018-09-23 21:17:31 +00:00
PyModule_AddIntConstant ( m , " JOINT_GEAR " , eGearType ) ; // user read
2018-09-11 20:24:35 +00:00
2017-03-13 23:06:52 +00:00
PyModule_AddIntConstant ( m , " SENSOR_FORCE_TORQUE " , eSensorForceTorqueType ) ; // user read
2018-05-12 02:52:06 +00:00
PyModule_AddIntConstant ( m , " JOINT_FEEDBACK_IN_WORLD_SPACE " , JOINT_FEEDBACK_IN_WORLD_SPACE ) ; // user read
PyModule_AddIntConstant ( m , " JOINT_FEEDBACK_IN_JOINT_FRAME " , JOINT_FEEDBACK_IN_JOINT_FRAME ) ; // user read
2017-03-13 23:06:52 +00:00
PyModule_AddIntConstant ( m , " TORQUE_CONTROL " , CONTROL_MODE_TORQUE ) ;
PyModule_AddIntConstant ( m , " VELOCITY_CONTROL " ,
CONTROL_MODE_VELOCITY ) ; // user read
PyModule_AddIntConstant ( m , " POSITION_CONTROL " ,
CONTROL_MODE_POSITION_VELOCITY_PD ) ; // user read
2018-09-23 21:17:31 +00:00
PyModule_AddIntConstant ( m , " PD_CONTROL " ,
CONTROL_MODE_PD ) ; // user read
2017-03-13 23:06:52 +00:00
PyModule_AddIntConstant ( m , " LINK_FRAME " , EF_LINK_FRAME ) ;
PyModule_AddIntConstant ( m , " WORLD_FRAME " , EF_WORLD_FRAME ) ;
PyModule_AddIntConstant ( m , " CONTACT_REPORT_EXISTING " , CONTACT_QUERY_MODE_REPORT_EXISTING_CONTACT_POINTS ) ;
PyModule_AddIntConstant ( m , " CONTACT_RECOMPUTE_CLOSEST " , CONTACT_QUERY_MODE_COMPUTE_CLOSEST_POINTS ) ;
2018-09-23 21:17:31 +00:00
PyModule_AddIntConstant ( m , " CONSTRAINT_SOLVER_LCP_SI " , eConstraintSolverLCP_SI ) ;
PyModule_AddIntConstant ( m , " CONSTRAINT_SOLVER_LCP_PGS " , eConstraintSolverLCP_PGS ) ;
PyModule_AddIntConstant ( m , " CONSTRAINT_SOLVER_LCP_DANTZIG " , eConstraintSolverLCP_DANTZIG ) ;
//PyModule_AddIntConstant(m, "CONSTRAINT_SOLVER_LCP_LEMKE",eConstraintSolverLCP_LEMKE);
//PyModule_AddIntConstant(m, "CONSTRAINT_SOLVER_LCP_NNCF",eConstraintSolverLCP_NNCG);
//PyModule_AddIntConstant(m, "CONSTRAINT_SOLVER_LCP_BLOCK",eConstraintSolverLCP_BLOCK_PGS);
2018-09-11 20:24:35 +00:00
2017-03-13 23:06:52 +00:00
PyModule_AddIntConstant ( m , " VR_BUTTON_IS_DOWN " , eButtonIsDown ) ;
PyModule_AddIntConstant ( m , " VR_BUTTON_WAS_TRIGGERED " , eButtonTriggered ) ;
PyModule_AddIntConstant ( m , " VR_BUTTON_WAS_RELEASED " , eButtonReleased ) ;
PyModule_AddIntConstant ( m , " VR_MAX_CONTROLLERS " , MAX_VR_CONTROLLERS ) ;
PyModule_AddIntConstant ( m , " VR_MAX_BUTTONS " , MAX_VR_BUTTONS ) ;
2017-04-08 05:53:36 +00:00
PyModule_AddIntConstant ( m , " VR_DEVICE_CONTROLLER " , VR_DEVICE_CONTROLLER ) ;
PyModule_AddIntConstant ( m , " VR_DEVICE_HMD " , VR_DEVICE_HMD ) ;
PyModule_AddIntConstant ( m , " VR_DEVICE_GENERIC_TRACKER " , VR_DEVICE_GENERIC_TRACKER ) ;
2017-05-18 02:29:12 +00:00
PyModule_AddIntConstant ( m , " VR_CAMERA_TRACK_OBJECT_ORIENTATION " , VR_CAMERA_TRACK_OBJECT_ORIENTATION ) ;
2017-03-13 23:06:52 +00:00
PyModule_AddIntConstant ( m , " KEY_IS_DOWN " , eButtonIsDown ) ;
PyModule_AddIntConstant ( m , " KEY_WAS_TRIGGERED " , eButtonTriggered ) ;
PyModule_AddIntConstant ( m , " KEY_WAS_RELEASED " , eButtonReleased ) ;
PyModule_AddIntConstant ( m , " STATE_LOGGING_MINITAUR " , STATE_LOGGING_MINITAUR ) ;
PyModule_AddIntConstant ( m , " STATE_LOGGING_GENERIC_ROBOT " , STATE_LOGGING_GENERIC_ROBOT ) ;
PyModule_AddIntConstant ( m , " STATE_LOGGING_VR_CONTROLLERS " , STATE_LOGGING_VR_CONTROLLERS ) ;
2017-03-22 03:43:23 +00:00
PyModule_AddIntConstant ( m , " STATE_LOGGING_VIDEO_MP4 " , STATE_LOGGING_VIDEO_MP4 ) ;
2017-04-02 23:03:20 +00:00
PyModule_AddIntConstant ( m , " STATE_LOGGING_CONTACT_POINTS " , STATE_LOGGING_CONTACT_POINTS ) ;
2017-05-05 00:51:40 +00:00
PyModule_AddIntConstant ( m , " STATE_LOGGING_PROFILE_TIMINGS " , STATE_LOGGING_PROFILE_TIMINGS ) ;
2018-06-12 23:56:45 +00:00
PyModule_AddIntConstant ( m , " STATE_LOGGING_ALL_COMMANDS " , STATE_LOGGING_ALL_COMMANDS ) ;
PyModule_AddIntConstant ( m , " STATE_REPLAY_ALL_COMMANDS " , STATE_REPLAY_ALL_COMMANDS ) ;
2018-06-16 13:19:49 +00:00
PyModule_AddIntConstant ( m , " STATE_LOGGING_CUSTOM_TIMER " , STATE_LOGGING_CUSTOM_TIMER ) ;
2018-09-11 20:24:35 +00:00
2017-03-13 23:06:52 +00:00
PyModule_AddIntConstant ( m , " COV_ENABLE_GUI " , COV_ENABLE_GUI ) ;
PyModule_AddIntConstant ( m , " COV_ENABLE_SHADOWS " , COV_ENABLE_SHADOWS ) ;
PyModule_AddIntConstant ( m , " COV_ENABLE_WIREFRAME " , COV_ENABLE_WIREFRAME ) ;
2017-05-15 18:39:39 +00:00
PyModule_AddIntConstant ( m , " COV_ENABLE_VR_PICKING " , COV_ENABLE_VR_PICKING ) ;
PyModule_AddIntConstant ( m , " COV_ENABLE_VR_TELEPORTING " , COV_ENABLE_VR_TELEPORTING ) ;
2017-05-16 19:19:03 +00:00
PyModule_AddIntConstant ( m , " COV_ENABLE_RENDERING " , COV_ENABLE_RENDERING ) ;
2017-10-06 20:46:24 +00:00
PyModule_AddIntConstant ( m , " COV_ENABLE_TINY_RENDERER " , COV_ENABLE_TINY_RENDERER ) ;
2017-11-04 19:51:13 +00:00
PyModule_AddIntConstant ( m , " COV_ENABLE_Y_AXIS_UP " , COV_ENABLE_Y_AXIS_UP ) ;
2017-10-06 20:46:24 +00:00
2017-05-16 19:19:03 +00:00
PyModule_AddIntConstant ( m , " COV_ENABLE_VR_RENDER_CONTROLLERS " , COV_ENABLE_VR_RENDER_CONTROLLERS ) ;
2017-06-17 20:29:14 +00:00
PyModule_AddIntConstant ( m , " COV_ENABLE_KEYBOARD_SHORTCUTS " , COV_ENABLE_KEYBOARD_SHORTCUTS ) ;
PyModule_AddIntConstant ( m , " COV_ENABLE_MOUSE_PICKING " , COV_ENABLE_MOUSE_PICKING ) ;
2017-05-16 19:19:03 +00:00
2017-11-17 21:33:27 +00:00
PyModule_AddIntConstant ( m , " COV_ENABLE_RGB_BUFFER_PREVIEW " , COV_ENABLE_RGB_BUFFER_PREVIEW ) ;
PyModule_AddIntConstant ( m , " COV_ENABLE_DEPTH_BUFFER_PREVIEW " , COV_ENABLE_DEPTH_BUFFER_PREVIEW ) ;
PyModule_AddIntConstant ( m , " COV_ENABLE_SEGMENTATION_MARK_PREVIEW " , COV_ENABLE_SEGMENTATION_MARK_PREVIEW ) ;
2018-04-11 08:03:36 +00:00
PyModule_AddIntConstant ( m , " COV_ENABLE_PLANAR_REFLECTION " , COV_ENABLE_PLANAR_REFLECTION ) ;
2018-09-15 00:17:11 +00:00
PyModule_AddIntConstant ( m , " COV_ENABLE_SINGLE_STEP_RENDERING " , COV_ENABLE_SINGLE_STEP_RENDERING ) ;
2018-04-11 08:03:36 +00:00
2017-03-13 23:06:52 +00:00
PyModule_AddIntConstant ( m , " ER_TINY_RENDERER " , ER_TINY_RENDERER ) ;
PyModule_AddIntConstant ( m , " ER_BULLET_HARDWARE_OPENGL " , ER_BULLET_HARDWARE_OPENGL ) ;
2017-12-28 20:37:07 +00:00
PyModule_AddIntConstant ( m , " ER_SEGMENTATION_MASK_OBJECT_AND_LINKINDEX " , ER_SEGMENTATION_MASK_OBJECT_AND_LINKINDEX ) ;
2018-10-04 21:14:24 +00:00
PyModule_AddIntConstant ( m , " ER_NO_SEGMENTATION_MASK " , ER_NO_SEGMENTATION_MASK ) ;
2018-03-19 00:01:23 +00:00
PyModule_AddIntConstant ( m , " ER_USE_PROJECTIVE_TEXTURE " , ER_USE_PROJECTIVE_TEXTURE ) ;
2017-12-28 20:37:07 +00:00
2017-10-19 21:00:53 +00:00
PyModule_AddIntConstant ( m , " IK_DLS " , IK_DLS ) ;
PyModule_AddIntConstant ( m , " IK_SDLS " , IK_SDLS ) ;
PyModule_AddIntConstant ( m , " IK_HAS_TARGET_POSITION " , IK_HAS_TARGET_POSITION ) ;
PyModule_AddIntConstant ( m , " IK_HAS_TARGET_ORIENTATION " , IK_HAS_TARGET_ORIENTATION ) ;
PyModule_AddIntConstant ( m , " IK_HAS_NULL_SPACE_VELOCITY " , IK_HAS_NULL_SPACE_VELOCITY ) ;
PyModule_AddIntConstant ( m , " IK_HAS_JOINT_DAMPING " , IK_HAS_JOINT_DAMPING ) ;
2017-03-13 23:06:52 +00:00
2017-03-27 15:30:20 +00:00
PyModule_AddIntConstant ( m , " URDF_USE_INERTIA_FROM_FILE " , URDF_USE_INERTIA_FROM_FILE ) ;
2018-01-09 18:10:36 +00:00
PyModule_AddIntConstant ( m , " URDF_USE_IMPLICIT_CYLINDER " , URDF_USE_IMPLICIT_CYLINDER ) ;
2018-01-10 19:16:50 +00:00
PyModule_AddIntConstant ( m , " URDF_GLOBAL_VELOCITIES_MB " , URDF_GLOBAL_VELOCITIES_MB ) ;
2018-01-12 05:04:08 +00:00
PyModule_AddIntConstant ( m , " MJCF_COLORS_FROM_FILE " , MJCF_COLORS_FROM_FILE ) ;
2018-05-23 03:26:00 +00:00
PyModule_AddIntConstant ( m , " URDF_ENABLE_CACHED_GRAPHICS_SHAPES " , URDF_ENABLE_CACHED_GRAPHICS_SHAPES ) ;
2018-05-31 01:37:08 +00:00
PyModule_AddIntConstant ( m , " URDF_ENABLE_SLEEPING " , URDF_ENABLE_SLEEPING ) ;
2018-06-13 22:35:56 +00:00
PyModule_AddIntConstant ( m , " URDF_INITIALIZE_SAT_FEATURES " , URDF_INITIALIZE_SAT_FEATURES ) ;
2018-10-14 19:54:34 +00:00
PyModule_AddIntConstant ( m , " URDF_USE_MATERIAL_COLORS_FROM_MTL " , URDF_USE_MATERIAL_COLORS_FROM_MTL ) ;
PyModule_AddIntConstant ( m , " URDF_USE_MATERIAL_TRANSPARANCY_FROM_MTL " , URDF_USE_MATERIAL_TRANSPARANCY_FROM_MTL ) ;
2018-06-16 04:26:26 +00:00
PyModule_AddIntConstant ( m , " ACTIVATION_STATE_ENABLE_SLEEPING " , eActivationStateEnableSleeping ) ;
PyModule_AddIntConstant ( m , " ACTIVATION_STATE_DISABLE_SLEEPING " , eActivationStateDisableSleeping ) ;
PyModule_AddIntConstant ( m , " ACTIVATION_STATE_WAKE_UP " , eActivationStateWakeUp ) ;
PyModule_AddIntConstant ( m , " ACTIVATION_STATE_SLEEP " , eActivationStateSleep ) ;
2018-01-12 05:04:08 +00:00
2017-04-04 19:47:34 +00:00
PyModule_AddIntConstant ( m , " URDF_USE_SELF_COLLISION " , URDF_USE_SELF_COLLISION ) ;
2017-05-10 22:01:25 +00:00
PyModule_AddIntConstant ( m , " URDF_USE_SELF_COLLISION_EXCLUDE_PARENT " , URDF_USE_SELF_COLLISION_EXCLUDE_PARENT ) ;
2018-09-08 21:46:43 +00:00
PyModule_AddIntConstant ( m , " URDF_USE_SELF_COLLISION_INCLUDE_PARENT " , URDF_USE_SELF_COLLISION_INCLUDE_PARENT ) ;
2018-09-11 20:24:35 +00:00
2017-05-10 22:01:25 +00:00
PyModule_AddIntConstant ( m , " URDF_USE_SELF_COLLISION_EXCLUDE_ALL_PARENTS " , URDF_USE_SELF_COLLISION_EXCLUDE_ALL_PARENTS ) ;
2017-04-05 22:21:26 +00:00
2018-07-08 09:23:12 +00:00
PyModule_AddIntConstant ( m , " VISUAL_SHAPE_DATA_TEXTURE_UNIQUE_IDS " , eVISUAL_SHAPE_DATA_TEXTURE_UNIQUE_IDS ) ;
2018-06-16 19:28:21 +00:00
PyModule_AddIntConstant ( m , " MAX_RAY_INTERSECTION_BATCH_SIZE " , MAX_RAY_INTERSECTION_BATCH_SIZE_STREAMING ) ;
2017-04-05 22:21:26 +00:00
2017-03-13 23:06:52 +00:00
PyModule_AddIntConstant ( m , " B3G_F1 " , B3G_F1 ) ;
PyModule_AddIntConstant ( m , " B3G_F2 " , B3G_F2 ) ;
PyModule_AddIntConstant ( m , " B3G_F3 " , B3G_F3 ) ;
PyModule_AddIntConstant ( m , " B3G_F4 " , B3G_F4 ) ;
PyModule_AddIntConstant ( m , " B3G_F5 " , B3G_F5 ) ;
PyModule_AddIntConstant ( m , " B3G_F6 " , B3G_F6 ) ;
PyModule_AddIntConstant ( m , " B3G_F7 " , B3G_F7 ) ;
PyModule_AddIntConstant ( m , " B3G_F8 " , B3G_F8 ) ;
PyModule_AddIntConstant ( m , " B3G_F9 " , B3G_F9 ) ;
PyModule_AddIntConstant ( m , " B3G_F10 " , B3G_F10 ) ;
PyModule_AddIntConstant ( m , " B3G_F11 " , B3G_F11 ) ;
PyModule_AddIntConstant ( m , " B3G_F12 " , B3G_F12 ) ;
PyModule_AddIntConstant ( m , " B3G_F13 " , B3G_F13 ) ;
PyModule_AddIntConstant ( m , " B3G_F14 " , B3G_F14 ) ;
PyModule_AddIntConstant ( m , " B3G_F15 " , B3G_F15 ) ;
PyModule_AddIntConstant ( m , " B3G_LEFT_ARROW " , B3G_LEFT_ARROW ) ;
PyModule_AddIntConstant ( m , " B3G_RIGHT_ARROW " , B3G_RIGHT_ARROW ) ;
PyModule_AddIntConstant ( m , " B3G_UP_ARROW " , B3G_UP_ARROW ) ;
PyModule_AddIntConstant ( m , " B3G_DOWN_ARROW " , B3G_DOWN_ARROW ) ;
PyModule_AddIntConstant ( m , " B3G_PAGE_UP " , B3G_PAGE_UP ) ;
PyModule_AddIntConstant ( m , " B3G_PAGE_DOWN " , B3G_PAGE_DOWN ) ;
PyModule_AddIntConstant ( m , " B3G_END " , B3G_END ) ;
PyModule_AddIntConstant ( m , " B3G_HOME " , B3G_HOME ) ;
PyModule_AddIntConstant ( m , " B3G_INSERT " , B3G_INSERT ) ;
PyModule_AddIntConstant ( m , " B3G_DELETE " , B3G_DELETE ) ;
PyModule_AddIntConstant ( m , " B3G_BACKSPACE " , B3G_BACKSPACE ) ;
PyModule_AddIntConstant ( m , " B3G_SHIFT " , B3G_SHIFT ) ;
PyModule_AddIntConstant ( m , " B3G_CONTROL " , B3G_CONTROL ) ;
PyModule_AddIntConstant ( m , " B3G_ALT " , B3G_ALT ) ;
PyModule_AddIntConstant ( m , " B3G_RETURN " , B3G_RETURN ) ;
2017-06-03 17:57:56 +00:00
PyModule_AddIntConstant ( m , " GEOM_SPHERE " , GEOM_SPHERE ) ;
PyModule_AddIntConstant ( m , " GEOM_BOX " , GEOM_BOX ) ;
PyModule_AddIntConstant ( m , " GEOM_CYLINDER " , GEOM_CYLINDER ) ;
PyModule_AddIntConstant ( m , " GEOM_MESH " , GEOM_MESH ) ;
PyModule_AddIntConstant ( m , " GEOM_PLANE " , GEOM_PLANE ) ;
PyModule_AddIntConstant ( m , " GEOM_CAPSULE " , GEOM_CAPSULE ) ;
2017-06-23 21:43:28 +00:00
PyModule_AddIntConstant ( m , " GEOM_FORCE_CONCAVE_TRIMESH " , GEOM_FORCE_CONCAVE_TRIMESH ) ;
2018-02-17 03:44:33 +00:00
PyModule_AddIntConstant ( m , " GEOM_CONCAVE_INTERNAL_EDGE " , GEOM_CONCAVE_INTERNAL_EDGE ) ;
2018-09-11 20:24:35 +00:00
2017-08-31 02:41:15 +00:00
PyModule_AddIntConstant ( m , " STATE_LOG_JOINT_MOTOR_TORQUES " , STATE_LOG_JOINT_MOTOR_TORQUES ) ;
PyModule_AddIntConstant ( m , " STATE_LOG_JOINT_USER_TORQUES " , STATE_LOG_JOINT_USER_TORQUES ) ;
2018-09-23 21:17:31 +00:00
PyModule_AddIntConstant ( m , " STATE_LOG_JOINT_TORQUES " , STATE_LOG_JOINT_USER_TORQUES + STATE_LOG_JOINT_MOTOR_TORQUES ) ;
2018-09-11 20:24:35 +00:00
state 2 of FileIO plugin: adding/removing FileIO types, search through all registered FileIO types.
(not enabled by default yet)
Example:
fileIO = p.loadPlugin("fileIOPlugin")
print("fileIO=",fileIO)
p.executePluginCommand(fileIO,"e:/develop/bullet3/data/plane.zip", [p.AddFileIOAction,p.ZipFileIO])
p.executePluginCommand(fileIO,"e:/develop/bullet3/data/test2.zip", [p.AddFileIOAction,p.ZipFileIO])
planeId = p.loadURDF("plane.urdf")
duckId = p.loadURDF("duck_vhacd.urdf",[0,0,1])
2018-10-11 21:39:31 +00:00
PyModule_AddIntConstant ( m , " AddFileIOAction " , eAddFileIOAction ) ;
PyModule_AddIntConstant ( m , " RemoveFileIOAction " , eRemoveFileIOAction ) ;
PyModule_AddIntConstant ( m , " PosixFileIO " , ePosixFileIO ) ;
PyModule_AddIntConstant ( m , " ZipFileIO " , eZipFileIO ) ;
PyModule_AddIntConstant ( m , " CNSFileIO " , eCNSFileIO ) ;
2017-03-13 23:06:52 +00:00
SpamError = PyErr_NewException ( " pybullet.error " , NULL , NULL ) ;
Py_INCREF ( SpamError ) ;
PyModule_AddObject ( m , " error " , SpamError ) ;
2018-09-23 21:17:31 +00:00
printf ( " pybullet build time: %s %s \n " , __DATE__ , __TIME__ ) ;
2018-09-11 20:24:35 +00:00
2018-09-23 21:17:31 +00:00
Py_AtExit ( b3pybulletExitFunc ) ;
2017-03-30 20:50:02 +00:00
2016-09-11 10:09:51 +00:00
# ifdef PYBULLET_USE_NUMPY
2017-03-13 23:06:52 +00:00
// Initialize numpy array.
import_array ( ) ;
# endif //PYBULLET_USE_NUMPY
2016-09-11 10:09:51 +00:00
2016-05-10 07:57:54 +00:00
# if PY_MAJOR_VERSION >= 3
2017-03-13 23:06:52 +00:00
return m ;
2016-05-10 07:57:54 +00:00
# endif
2016-04-30 18:18:54 +00:00
}