星星上的毛豆 · python opencv轮廓检测 - ...· 4 月前 · |
爱看球的围巾 · Pandas|排序,分组,组内排序-腾讯云开 ...· 1 年前 · |
另类的路灯 · 管理从Python到redis的连接· 1 年前 · |
才高八斗的柳树 · Python 截图 2+ ...· 1 年前 · |
没人理的路灯 · Git 使用指南(篇七):提交更新到 ...· 1 年前 · |
成熟的春卷
1 年前 |
Department of Information Engineering and Mathematics, University of Siena, Siena, Italy
Department of Engineering, University of Perugia, Perugia, Italy
Department of Engineering, University of Perugia, Perugia, Italy
Department of Information Engineering and Mathematics, University of Siena, Siena, Italy Department of Information Engineering and Mathematics, University of Siena, Siena, Italy Department of Engineering, University of Perugia, Perugia, Italy
Weiwei Wan , Osaka University, Japan
Egidio Falotico , Sant'Anna School of Advanced Studies, Italy
Enrico Donato , Sant’Anna School of Advanced Studies, Italy, in collaboration with reviewer [EF]
In this paper, we adopted Simscape Multibody as it is fully integrated within the MATLAB framework and is thus easy to use in conjunction with the SynGrasp Toolbox. Simscape is also rather versatile, allowing the creation of models both in a programmatic way, and by manually assembling blocks. Notwithstanding Simscape Multibody is still less exploited than other simulation environments, also due to its more recent development, examples of robot modeling with Simscape have already been presented, including parallel ( Olaya et al., 2017 ; Noskievič and Walica, 2020 ), industrial ( Udai et al., 2011 ; Ahn, 2014 ; Le Ngoc and Nguyen, 2020 ), aerial ( De Simone et al., 2017 ), legged ( Eldirdiry and Zaier, 2018 ; Aldair et al., 2020 ), mobile ( Khnissi et al., 2019 ; Siwek et al., 2019 ), and surgical ( Taghizadegan et al., 2016 ) robots.
The paper is organized as follows. The main components and features of the proposed simulation framework are presented in Section 2 . Results of grasp simulations conducted with the newly developed functions are reported in Section 3 and discussed in Section 4 . Lastly, the current limitations and envisaged future developments of the toolbox are summarized in Section 5 .
The basic elements of the presented framework are the SynGrasp toolbox ( Malvezzi et al., 2015 ), Simscape Multibody, and the MATLAB Programmatic Model Editing functions. The latter allow to seamlessly connect the quasi-static model of a grasp defined in SynGrasp to its corresponding multibody dynamic model in Simscape. The presented framework is depicted in Figure 1 and described in the following, starting from its fundamental components.
SynGrasp is a MATLAB toolbox for grasp analysis of fully or underactuated robotic hands, in which lumped parameter models of compliant elements and synergistic coordination between joint variables can be modeled. Compliant and deformable elements can be modeled at contact points, in the joints or in the actuation system, including the transmission.
Hand structure and simulation conditions can be set by means of a Graphical User Interface or directly with a MATLAB script. The available functions allow to perform grasp evaluation in quasi-static conditions in terms of contact forces, actuator torques/forces, manipulability properties, grasp quality measures, and grasp stiffness. SynGrasp functions can be easily combined and modified to account for different grasping scenarios. Grasps can be described either using the provided grasp planner or directly defining contact points on the hand with the respective contact normal directions. Functions for the graphical representation of the hand and the object are provided. The toolbox is freely available at http://syngrasp.dii.unisi.it .
Since its release, SynGrasp has been used for analysing grasp properties of both human and robotic hands, for robotic hand design and also as a learning tool. In ( Yao and Billard, 2020 ), the authors used the anthropomorphic hand model provided in SynGrasp to develop a kinematic procedure for estimating hand postures in bimanual tasks, whereas in ( Fattahi Sani et al., 2019 ), the toolbox was used to develop a hand tracking system in surgical operations. Katyara et al. (2021) investigated the role of postural synergies in manipulation tasks and used SynGrasp to validate the proposed framework. Garate et al. (2017 , 2018) exploited SynGrasp to implement in-hand manipulation strategies with a fully actuated hand based on Common-Mode Stiffness (CMS) and Configuration-Dependent Stiffness (CDS) principles, and to simulate control strategies for hand-arm systems subject to underactuation constraints ( Ruiz Garate and Ajoudani, 2020 ). Using SynGrasp, Almeida and Moreno (2020) further developed the concept of Potential Grasp Robustness ( Pozzi et al., 2017 ), devising new heuristics for managing computational load, and analysing the influence of uncertainties on its computation ( Almeida and Moreno, 2021 ). Hybrid Cartesian-joint mapping procedures for anthropomorphic hands were analysed with SynGrasp by Meattini et al. (2021) . Orabona et al. (2020) exploited the possibility of modeling underactuated hands in SynGrasp, to design a 3D-printed hand with a simple, yet versatile, structure. Zaidi et al. (2017) presented a method to model robotic hands grasping 3D deformable object, and SynGrasp functions were used for the graphical representation of grasps.
As previously introduced, multibody simulation aims at solving the kinematic and dynamic problems of mechanical systems, and is particularly useful to study the behaviour of complex mechanical and robotic systems like grippers and manipulators ( Achilli et al., 2021a ).
The main parameters used to describe bodies in the multibody simulator are: a local reference frame having the origin in the body’s center of mass and the principal axes, the mass, the tensor of inertia in the local reference frame, and other auxiliary references to define the constraints that are represented by relationships between the motion parameters. Both rigid and flexible bodies are modeled with a single or combining multiple blocks able to describe their mechanical behaviour. All bodies are connected by means of joints or with proper constrains and all is assembled into an articulated mechanism, with a number of degrees of freedom resulting from the kinematic relationships provided by the constraint blocks.
Several tools for performing multibody simulations are available. In this paper, we chose to exploit the application Simscape Multibody, as it is a MATLAB toolbox and can thus be easily integrated with SynGrasp. Simscape Multibody can use data from external 3D CAD, like SolidWorks (Dassault Systèmes, Vélizy-Villacoublay, France), to import 3D models obtained from 3D scanning ( Valigi et al., 2020b ), and to create bodies, constraints, actions, and joints with parametrization by mathematical expressions described in MATLAB. The bodies are characterised by their geometry and consequent inertial properties, which can be modified by the user according to the studied physical system. Forces and moments can be applied to bodies, and contact constraints can be defined. Simscape allows to model physical systems by connecting blocks representing different mechanical elements. Simscape and Simulink blocks can be mixed inside a model and linked through appropriate connectors. In the multibody system presented in this work, hand models are composed of subsystems including more than one block, and contact constraints are defined between the object to be grasped and the gripper’s phalanges and palm.
The programmatic modelling functions available in MATLAB allow to create and edit Simulink models programmatically, i.e., through a MATLAB script . This feature is particularly suited for our objective of connecting SynGrasp, which is natively composed of MATLAB scripts and functions, with Simulink models including Simscape Multibody blocks. Through rather intuitive functions it is possible to programmatically add and connect blocks in models and set their parameters and properties.
In this work, we defined a library of basic Simscape Multibody subsystems (i.e., sets of blocks) that can be combined to create hand and object models (see Section 2.2 ). Based on the system that must be simulated, these blocks can be added to a new model and their parameters can be set according to the envisaged application.
The proposed toolbox is composed of a library of basic blocks in.slx format and a set of MATLAB functions aimed at manipulating them to create custom grasping systems, i.e. systems with a custom hand and a custom object that can interact with each other. In this work, we focus on grasping tasks, but the toolbox could be expanded to simulate also in-hand manipulation strategies ( Prattichizzo et al., 2020 ).
Table 1 briefly describes the functions and the blocks of the new toolbox, which are available together with demonstrative scripts at http://syngrasp.dii.unisi.it . In the following, we first describe how the two main entities of a grasp, i.e., the hand and the object, are defined in the proposed framework, and then we detail how a grasp can be simulated.
Name | Description |
---|---|
SG2Sim_Hand.m | Defines the Simscape model of a hand |
SG2Sim_Palm.m | Defines the Simscape model of the palm of a given hand |
SG2Sim_Finger.m | Defines the Simscape models of the fingers of a given hand |
SG2Sim_BuildObject.m | Defines the Simscape model of an object |
SG2Sim_Contacts.m | Given a hand and an object defines contact contraints between them |
SG2Sim_SimulateGrasp.m | Simulates the closure of the hand over an object and stores the |
achieved contact points and joint angles in the SynGrasp hand structure | |
SG2Sim_StartConfiguration.slx | Contains the World frame, the Solver Configuration and the |
Mechanism Configuration | |
SG2Sim_module_RJ.slx | Contains the module representing the finger phalanx |
SG2Sim_PalmBlock.slx | Contains palm blocks configured to support a different number |
of fingers | |
SG2Sim_NoPalm.slx | This block is loaded in case the fingers have coincident bases |
SG2Sim_Object.slx | Models different objects |
SG2Sim_ExportData.slx | Allows to export simulation outcomes to the Workspace |
In SynGrasp, hand models are defined based on the Denavit-Hartenberg (DH) parameters of the fingers ( Siciliano et al., 2009 ), which are considered to be open kinematic chains with several links connected through revolute joints ( Malvezzi et al., 2015 ) . The fingers are connected to a palm that is built starting from the positions of the fingers’ bases. In the MATLAB workspace, SynGrasp hands are represented as structures with several fields (e.g., number of fingers, number of joints, etc.). The function SG2Sim_Hand takes as input a hand structure and builds the corresponding hand model in Simscape Multibody, starting from its palm ( SG2Sim_Palm ) and then defining the fingers ( SG2Sim_Finger ). One of the simplest and one of the most complex hand models available in SynGrasp and their Simscape Multibody counterparts are shown in Figure 2A .
The creation of a hand in Simscape Multibody follows a modular approach. The hand is made of a palm and one or more fingers, composed of one or more phalanges. An example of hand structure is shown in Figure 2B . Depending on the number of fingers, a certain palm structure is loaded in the Simulink model through the function SG2Sim_Palm , and then phalanx modules are assembled to model the fingers with SGSim_Finger . Each phalanx has the same structure and is called module_RJ_xy , where x indicates the finger and y indicates the phalanx. As shown in Figure 3 , a phalanx module contains a Body representing the phalanx , a revolute joint representing the joint at the base of the phalanx, and several rigid body transformations blocks, which implement the DH rotations and translations. In hand models having two joints placed at the same position, the SGSim_Finger function automatically comments out the Body block of the first involved phalanx. In this way, the approach can flexibly handle different hand models, while keeping a modular structure. The anthropomorphic hand shown in Figure 2 , for example, has two revolute joints at the base of each finger to account for flexion/extension and adduction/abduction motions ( Gioioso et al., 2013 ; Marullo et al., 2022 ). Thus, in the first phalanx of each finger in the Simscape model, the Body block is commented.
Each phalanx module also contains the subsystems implementing the contact detection and the actuation system (see Section 2.2.3.1 and Section 2.2.3.2 for more details).
In the proposed framework, the object to be grasped is first defined in SynGrasp, where the main parameters are set, and then inserted into Simscape thanks to the function SG2Sim_BuildObject . The Object subsystem ( Figure 4 ) contains: 1 ) a rigid body transformation that sets the pose of the object, 2 ) a joint that chooses the allowed object motions (e.g., a Weld Joint fixes the object in the workspace, whereas a Bushing Joint allows its unconstrained motion in 3D), 3 ) a subsystem for sensing the object pose, and 4 ) a solid block where the geometrical and material properties of the object can be specified.
The object to be inserted in the model can be chosen from a set of four different types of solid bodies: three primitive solids, Cylinder , Parallelepiped or Sphere , and a 3D solid, whose model can be imported by the user. For primitive solids, the main parameters (e.g., radius, height, length, etc.) must be specified either manually or exploiting the function SG2Sim_BuildObject , which sets them based on the object structure defined in SynGrasp. The File_Solid block, instead, allows the user to load a file in common formats used in 3D modeling such as STL, SAT, JT and STEP, but also proprietary software formats such as CATIA, Creo, Inventor, Unigraphics NX, Solid Edge, SolidWorks, and Parasolid. All four types of solid body blocks require Inertia parameters to be entered, where the mass or density of the object can be indicated.
Once a hand and an object are defined in the Simulink model file, contact constraints between them need to be defined through the function SG2Sim_Contacts . Then, a grasp can be simulated by activating the closure of the hand through SG2Sim_SimulateGrasp .
The interaction between solids within the multibody simulator is an important aspect for the grasping evaluation. The Simscape Multibody toolbox contains a block dedicated to this function, called Spatial_Contact_Force . This block allows to develop a contact model between a pair of bodies. Among the contact-force models in multibody dynamics ( Skrinjar et al., 2018 ), Simscape Multibody uses as default the Kelvin-Voigt model, which was used in ( Machado et al., 2012 ; Corral et al., 2021 ). The model is based on a regularized approach, also known as compliance or visco-elastic method, in which the contacting bodies are considered to be deformable at the contact zone, and the contact forces can be expressed as a continuous function of the local deformation between the contacting surfaces. In this block, the normal contact force F N is estimated through the interpenetration between the solid bodies:
where K is the stiffness coefficient and D is the damping coefficient, δ is the relative indentation between the contacting bodies, and is the relative normal contact velocity. The first term is referred to the linear elastic force component, while the second one accounts for the energy dissipation during contact ( Shigley, 1972 ). The normal contact force is proportional both to the indentation velocity and depth.
Another parameter that can be set in the Spatial_Contact_Force block is the transition region width, which characterizes the transitional region to the force equations . As the depth of indentation gets to the end of the transition region, the normal force increases, until the maximum stiffness and damping forces are reached. By varying the transition region width, the transition is sharper for low values, while it is smoother for high values.
The main parameters of the contact model and the corresponding values adopted in the developed Simscape subsystems are shown in Table 2 .
Normal Force | |
---|---|
Stiffness | 10 6 N / m |
Damping | 10 3 N /( m / s ) |
Transition region width | 10 −6 Frictional Force |
Method | Smooth Stick-slip |
Coefficient of static friction | 0.5 |
Coefficient of dynamic friction | 0.3 |
Critical velocity | 10 −3 m / s |
The Spatial_Contact_Force block uses a sensing output system, which shows how certain calculated parameters vary between the two solids in contact. The sensing output parameters available in this module allow to monitor the separation distance between the two solid elements, the modulus of the normal contact force between the two elements of the solid body, and the modulus of the frictional contact force between the two elements of the solid body.
The function SG2Sim_Contacts allows to connect each phalanx of the hand model and the palm to the object via a Spatial_Contact_Force block (see Figure 3 ). The modulus of the normal contact force is selected as the parameter to establish the presence of contact between bodies. A threshold can be chosen beyond which it can be considered that the interaction between the solid elements is present, and thus a contact is detected. The contact module contains a logic that evaluates the ten previous samples of the measured normal contact force and compares them: if all the samples are higher than the selected threshold, the contact can be considered as established. The signal, passing through ten Delay blocks, is processed in a Product block: if a sample is lower than the threshold, the output value is 0, otherwise it is 1. The number of Delay blocks used in the subsystem is obtained from experimental trials during the development of the toolbox. This control system is necessary to avoid that incorrect values of the modulus of the normal force are considered as established contacts. In fact, there are cases in which peaks in the normal force values occur due to the contact model main parameters. Indeed, the combination of stiffness and damping limits the possibility of interpenetration between the bodies; thus, the presence of rebounds between the surfaces is possible, but it cannot be considered as an established contact between solid bodies.
Each Contact subsystem output port ends in a tag block. These tag blocks are handles: they send the data present at the head of the GoTo block (sender block) to that present in the From block (receiver block). Each tag block is named as FxPy , where x indicates the finger and y indicates the phalanx, in accordance with the naming of phalanx modules. Notice that two types of signals are used in Simscape Multibody: the Physical type and the Simulink type. Only Simulink signals can be sent with tags, and this is why Simulink-PS Converter blocks are used to connect Simulink sources to inputs to a physical Simscape Multibody network (see Figure 3 ).
Tags are used throughout the model to send data in a user-friendly and intuitive way, avoiding the large number of lines that would otherwise be needed to achieve the same result without them. The data obtained after a simulation are stored in the SG2Sim_ExportData subsystem and sent to the MATLAB Workspace.
As hand models are composed of links connected through revolute joints, the actuation systems that can be implemented are either based on angular position inputs or based on torque commands. In this work, we adopted the first option. Once a hand and an object are defined in the Simulink model file, and so are the contacts between them, a grasp can be simulated by activating the closure of the hand. To this aim we created an ad-hoc subsystem implementing the position control of the hand fingers which is activated by the function SG2Sim_SimulateGrasp . Starting from a predefined initial configuration, the hand actuation system closes all the joints of the hand over the object, increasing them by a pre-defined constant value which can be specified for each joint.
The increment in the joint value is applied only if no contact is detected on the related phalanx or on the successive ones. To implement this logic we adopted a Logical_Operator_OR that is present in each phalanx module (see Figure 3 ). In case a contact is detected, the phalanx remains in the same position. With a delay block, the joint angle of the previous instant is stored throughout the simulation. In this way, if the object and the phalanx are no longer in contact due to the object motion, the actuation system restarts increasing the joint position until the next contact occurs.
The presented framework was tested in two sets of simulations: 1 ) grasps of objects with different shapes, and 2 ) grasps of objects made of different materials.
In all the simulated grasps, the hand was closed over the object using the actuation system detailed in Section 2.2.3.2 , and contacts were detected with the strategy described in Section 2.2.3.1 . Objects with primitive shapes (sphere, cylinder, cuboid), as well as object models from the YCB Dataset ( Calli et al., 2015 ) were considered. The effect of gravity was deactivated, to show the working principles of the proposed contact detection and actuation strategies without external loads.
For the simulations, an explicit continuous fixed-step solver was chosen. Different solvers of this type are available in Simulink, according to the used numerical integration technique. As the order of the integration technique increases, also the computational complexity grows. We adopted the Ode3 solver, which computes the model state using the Bogacki-Shampine formula integration technique to evaluate state derivatives ( Hosea and Shampine, 1994 ). Among the integration algorithms available in Simulink, we selected a fixed-step one also to simplify the post-processing phase and the analysis of the results (e.g. analysis in the frequency domain). The simulations described in this section were conducted with MATLAB R2021b version on a Laptop with Windows 10, Intel R Core™ i7-10750H CPU @2.60GHz, and 16 GB RAM.
To increase the accuracy of the simulation, the model requires to use a step size that is as low as possible. The balance between solver order and step size can only be obtained through iterative trials, to achieve accurate results with a low computational burden. Furthermore, to simulate the grasp with generic objects, the contact model requires a high number of steps to avoid conditions in which the solution diverges. Through numerous tests, the value 10 −5 s was identified as a suitable step size, that gives accurate solutions in a reasonable amount of time, and with several different objects.
In the next sections the results obtained with a four fingered gripper having the structure shown in Figure 5 are described. However, the conducted simulations can be easily performed with other types of hands.
To simulate precision grasps we fixed all the object degrees of freedom through a Simscape Multibody Weld Joint, so that even when touched by the hand the object did not move, allowing the precise positioning of the fingertips over it. Examples of the obtained final grasps are shown in Figure 6A .
To simulate power grasps, instead, the object was left free to move in the 3D space. To this aim, the Simscape Object block was attached to the startConfig block through a Bushing Joint that has three translational and three rotational degrees of freedom. As a result, while closing over the object, the hand could drag it towards the palm, ending up in a power grasp involving the phalanges of the fingers as well as the palm itself. Examples of achieved power grasps are depicted in Figure 6B .
Both types of grasps were performed over primitive shapes (sphere, cylinder, cuboid). In addition, for precision grasps we chose two small objects from the YCB Dataset, i.e., the screwdriver and the strawberry, whereas for power grasp we chose two larger objects, i.e., the metal mug and the pear.
In precision grasps, objects were oriented in different ways and positioned so that they would enter in contact first with the hand fingertips, thus achieving a pinch grasp. Figure 7 shows the results obtained for the grasp of the strawberry in terms of contact detection and performed motion.
The simulation of a power grasp of a sphere is analysed in terms of joints trajectories, contact detection, and object motion in Figures 8 – 11 .
To fully show the capabilities of the multibody simulator, we tested the grasp of objects with different realistic densities: ρ = 160 kg/ m 3 (balsa wood), ρ = 700 kg/ m 3 (fir wood), ρ = 2,300 kg/ m 3 (chalk), ρ = 7,860 kg/ m 3 (steel), ρ = 19250 kg/ m 3 (gold) . We used the same gripper and spherical object adopted in the previous simulations and we initially placed the sphere as in Figure 10A . Figure 12 shows the results obtained varying the density of the spherical body in terms of object position and orientation and of final grasps.
As shown in Figure 6 , the developed tools allow to simulate the grasp of objects with different shapes. We decided to present the results obtained for the strawberry, as they clearly show the working principle of the proposed grasping strategy. As soon as a finger touches the object with its fingertip, and the contact is stable, the whole finger stops moving. As depicted in 7(B), the Fingers 1 and 2 come into contact with the object slightly before the others. As a result, the contact signals corresponding to the last phalanges of Fingers 1 and 2 activate (passing from 0 to 1) slightly before other ones.
To show the capability of the simulator to compute the object motion when the object is free to move (even though not subjected to gravity), we simulated power grasps in which the object is dragged by the fingers towards the hand palm. We reported the data related to the grasp of the sphere, as already with a simple object we can appreciate different aspects of the simulation. The sphere was initially positioned closer to Fingers 2 and 4 as shown in Figure 5B . As a result, the first contacts are detected on the first phalanges of these two fingers (contacts 4 and 10, Figure 9 ). While closing, Fingers 2 and 4 go in contact also with their second phalanges (contacts 5 and 11) and lastly with the fingertips (contacts 6 and 12). At t ≈ 0.32 s, the contact with the last phalanges of Fingers 1 and 3 (contacts 3 and 9) is detected, and from t ≈ 0.33 s it becomes stable. Figure 10A shows the main steps of the grasping task. From t ≈ 0.33 s the contacts on the fingertips as well as that on the palm (see Figure 10B ) become stable and the final grasp is achieved.
Regarding the hand trajectory, it is interesting to notice that the joint value of the first phalanges of Fingers 2 and 4 ( q 4 and q 10) stays almost constant for a few milliseconds around t = 0.15 s, that is when the contact with the first phalanges of Fingers 2 and 4 is detected.
Figure 11A shows the translation of the object in the world reference frame, which can be seen in Figure 5B . The x -axis is along the direction of closure of the Fingers 2 and 4, the y -axis is in the direction connecting the bases of the Fingers 2 and 4, and the z -axis is normal to the plane of the hand palm and points upwards. As expected, the sphere is dragged in the positive x direction. It initially tends to go downwards due to the contact force exerted by the first phalanges of Fingers 2 and 4, but then comes back upwards transported by the fingertips. The motion in the y direction is null, whereas the rotation with respect to it is the only change of orientation that is observed for the sphere (see the θ angle in Figure 11B ).
This set of simulations demonstrates that even though the gravity is not activated, changing the inertial properties of the object influences its resulting motion when it is grasped by the gripper. In particular, the higher the density, the less the object tends to go downward in the z direction, and the closer it arrives to Fingers 2 and 4 at the end of the simulation ( Figure 12A,C ). Fore more dense materials, not only the translation, but also the rotation is more limited ( Figure 12B ).
In this paper, we introduced a numerical tool for the simulation of robotic grasping using Simulink and Simscape Multibody. The tool is based on SynGrasp, a previously developed MATLAB toolbox allowing purely kinematics or quasi-static analyses. The library of functions and blocks developed in this work adds a fundamental module enabling dynamics simulations. The Simscape Multibody model of a robotic hand can be defined in a straightforward way from SynGrasp models thanks to a series of functions based on programmatic model editing. In this way, even users with limited experience with the Simscape Multibody environment can build robotic hand models and run dynamics simulations. More expert users can improve hand models, for example importing realistic CAD representations of links and structural components, or introducing specific mechanical transmission systems, or completing the model with advanced hand control systems. Grasped objects can be selected among a series of primitive geometric shapes, or can be defined by means of their 3D CAD representation. Contact detection and contact force evaluation are defined by means of a specific block.
The developed library is presented and its features are demonstrated through a set of simulations performed using a multifingered gripper interacting with different objects. In the presented simulations, to better highlight the basic system characteristics, the effect of gravity was not considered. In particular, contact point detection was analysed, since it represents the most challenging part of the simulation, in terms of numerical complexity and in terms of result stability and reliability. In the first set of simulations, grasps with different objects were simulated, whereas in the second set we investigated grasping of objects with the same shapes but different inertial properties. The obtained results were coherent with the expected system behaviour in all the simulated cases.
Future developments of this work are manifold. To make the simulation more realistic, we will introduce the gravity, and the contact detection between the links of the hand themselves. In addition, we will study how to simulate the simultaneous grasping of multiple objects, and we will introduce the environment in the simulations. In this way, grasping strategies exploiting environmental constraints ( Bimbo et al., 2019 ; Pozzi et al., 2020 ) could be tested. A deeper investigation on contact modeling and detection will also be conducted. As it is implemented now, the contact detection only allows retrieving the phalanx in which the contact was detected, and not the exact contact point on the phalanx surface. For this, it would be necessary to explicitly build and use a contact mesh. In addition, other contact models will be considered and possibly compared, depending on the type of simulated interactions and tasks ( Skrinjar et al., 2018 ).
We will also consider the inclusion of blocks evaluating, during the simulation, specific grasp properties (e.g., grasp robustness, manipulability indices, grasp quality measures, etc.). Since the toolbox is capable of performing numerical dynamic simulations, it is particularly suitable to model and simulate soft robotic hands ( Pozzi et al., 2018 ). The dynamic equations governing the motion of soft bodies are highly nonlinear and in most cases cannot be solved analytically in a closed form. For this reason, one must resort to the numerical solution of the resulting dynamic equations. We also plan to implement the complete simulation of the hand-arm system in grasping and manipulation tasks, possibly introducing dual-arm systems capable of executing complex bimanual tasks.
1 https://www.mscsoftware.com/it/product/adams https://www.ode.org/ https://opensim.stanford.edu/ https://www.mbdyn.org/?Software_Download http://www.freedyn.at/new-download/ https://www.ansys.com/it-it/products/structures/ansys-motion https://www.comsol.com/multibody-dynamics-module https://www.solidworks.com/
9 Programmatic Model Editing (MathWorks, Inc., Natick, Massachusetts, United States): https://it.mathworks.com/help/simulink/programmatic-modeling.html
10 Notice that since human and robotic hands are usually modelled with only revolute joints, also in this work we consider only this type of joints. In principle, however, the implementation could be easily extended to include also prismatic joints, as they are available within Simscape Multibody.
11 To maintain the connection with the hand models defined in SynGrasp, we assume that phalanges have cylindrical shapes. However, the models can be customized to account for different designs.
12 https://it.mathworks.com/help/physmod/sm/ref/spatialcontactforce.html.
13 Notice that although we chose realistic values for the density, we did not aim at replicating the properties of specific types of materials, as this would require the adjustment also of other material properties and this is out of the scope of this work.
The original contributions presented in the study are included in the article/Supplementary Material, further inquiries can be directed to the corresponding author.
MP, GA idea conceptualization; MP, GA, MM, hand modelling; GA, MP library implementation; MP, GA, MM, and MV writing of the manuscript; MM and MV supervision of the writing process. All authors reviewed the manuscript.
The authors declare that the research was conducted in the absence of any commercial or financial relationships that could be construed as a potential conflict of interest.
All claims expressed in this article are solely those of the authors and do not necessarily represent those of their affiliated organizations, or those of the publisher, the editors and the reviewers. Any product that may be evaluated in this article, or claim that may be made by its manufacturer, is not guaranteed or endorsed by the publisher.
另类的路灯 · 管理从Python到redis的连接 1 年前 |