Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
a6ff885
add folder for STLIB
bakpaul Apr 14, 2025
60352a4
Add reusable methods
bakpaul Apr 14, 2025
d024105
Add working files
bakpaul Apr 14, 2025
10082bf
Created example scenes
bakpaul Apr 14, 2025
d167479
Fix example
bakpaul Apr 14, 2025
dd9cc34
orga folders
hugtalbot Apr 14, 2025
7589706
Fix package
bakpaul Apr 14, 2025
2f844d7
bootstrap examples
bakpaul Apr 14, 2025
2c55e7d
start beginner scene
hugtalbot Apr 14, 2025
9b9e057
Move around files
bakpaul Apr 14, 2025
b989159
Move examples into SofaPython3 main example folder
bakpaul Apr 14, 2025
b42833b
Add unsaved modifications
bakpaul Apr 14, 2025
fa0bd74
reoganisation after discussion
EulalieCoevoet Apr 14, 2025
4380356
Add gemetries
bakpaul Apr 14, 2025
ba978ce
WIP FileParameters
bakpaul Apr 14, 2025
fc88100
Add beginner example
bakpaul Apr 14, 2025
7c314c6
Add unsaved changes
bakpaul Apr 14, 2025
b70a52b
Start work on visual and collision
bakpaul Apr 14, 2025
7cedc42
work on Tuesday : visual, geometry
hugtalbot Apr 15, 2025
5f183d5
add basePrefabParameters.py
hugtalbot Apr 15, 2025
97a2381
Add extracted geometry
bakpaul Apr 15, 2025
00fd16b
Fix visual example
bakpaul Apr 15, 2025
423a484
Finished collisions
bakpaul Apr 15, 2025
c97bfa3
[stlib-splib] work on prefabs: cleaning (#501)
EulalieCoevoet Jun 2, 2025
995d1b3
[stlib] adds README
EulalieCoevoet Jun 2, 2025
01531ca
[stlib] minor changes from discussion
EulalieCoevoet Jun 2, 2025
fc1404a
[splib] updates entity
EulalieCoevoet Jun 3, 2025
dd230b9
update README
hugtalbot Jun 3, 2025
57efa1d
add init in prefab
hugtalbot Jun 3, 2025
938f05b
Add first implem of entity
bakpaul Jun 3, 2025
592c13d
before the train 3/3
hugtalbot Jun 3, 2025
ca864d8
very last commit befor train
EulalieCoevoet Jun 3, 2025
1d8cdd3
WIP
bakpaul Jun 3, 2025
bacb258
Retore original. Still crash due to wrong string conversion
bakpaul Jun 3, 2025
09f45c5
[stlib] Deformable Entity (#502)
EulalieCoevoet Jun 13, 2025
d4b6042
Fix linkpath by introducing init method + make addDeformableMaterial …
bakpaul Jun 13, 2025
aad2a5e
[STLIB] Add the unified "add" in Sofa.Core.Node (#503)
damienmarchal Jul 17, 2025
1b15154
Add new tests for prefabs
bakpaul Jul 17, 2025
e2fff56
Revert modification of __genericAdd
bakpaul Jul 17, 2025
9de87d4
update addMass using elementType
hugtalbot Jul 17, 2025
5dd9eef
Add and "apply" méthod to node
damienmarchal Oct 29, 2025
475b564
Add a spot model
damienmarchal Oct 29, 2025
84a22bd
Add few experiment with prefabs
damienmarchal Oct 30, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
30 changes: 30 additions & 0 deletions examples/stlib/PrefabScene_beginner.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
from stlib.entities.rigid import Rigid
from stlib.entities.deformable import Deformable
from stlib.geometry.cube import CubeParameters
from stlib.geometry.file import FileParameters
from splib.simulation.headers import setupLagrangianCollision
from splib.simulation.linear_solvers import addLinearSolver
from splib.simulation.ode_solvers import addImplicitODE

#To be added in splib
def addSolvers(root):
addLinearSolver(root)
addImplicitODE(root)
root.addObject("LinearSolverConstraintCorrection", linearsolver="@LinearSolver")

def createScene(root):
root.gravity = [0, 0, -9.81]

setupLagrangianCollision(root)
addSolvers(root)

rigidParams = Rigid.getParameters()
rigidParams.geometry = CubeParameters([0, 0, 0], 1, 3)
root.add(Rigid,rigidParams)

deformableParams = Deformable.getParameters()
#Add transformation somewhere here
deformableParams.geometry = FileParameters("SofaScene/Logo.vtk")
root.add(Deformable,deformableParams)

return root
14 changes: 14 additions & 0 deletions examples/stlib/PrefabScene_expert.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
from splib.helper import exportScene
from stlib.misc.entity import Entity


def createScene(root):
Entity.Deformable(Mesh,MechaProperties)

return root


if __name__=="__main__":
root = exportScene()
createScene(root)
pass
8 changes: 8 additions & 0 deletions examples/stlib/PrefabScene_intermediate.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
from splib.helper import exportScene
from stlib.misc.entity import Entity


def createScene(root):


return root
Empty file.
Empty file.
59 changes: 59 additions & 0 deletions live-example/models/compliancerobotics/robots/spot/__entity__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
from stlib.entities import Entity
from compliancerobotics.robots.spot.__parameters__ import SpotRobotParameters
import numpy as np

class SpotRobot(Entity):
"""Boston dynamic spot robots"""
@staticmethod
def get_asset(name) -> str:
import os
return os.path.join(os.path.join(os.path.dirname(__file__), "assets"), name)

@staticmethod
def getParameters(**kwargs) -> SpotRobotParameters:
return SpotRobotParameters(**kwargs)

def __init__(self, parameter : SpotRobotParameters = None, **kwargs):
if parameter is None:
parameter = SpotRobotParameters(**kwargs)
Entity.__init__(self, parameter)

self.create(parameter)

def create(self, parameter):
# Robot node
settings = self.addChild('settings')
settings.addObject("RequiredPlugin", name="SoftRobots")
settings.addObject("RequiredPlugin", name="Sofa.RigidBodyDynamics") # Needed to use components [URDFModelLoader]
settings.addObject('RequiredPlugin', name='Sofa.Component.Mapping.NonLinear') # Needed to use components [RigidMapping]
settings.addObject('RequiredPlugin', name='Sofa.Component.Mass') # Needed to use components [UniformMass]
settings.addObject('RequiredPlugin', name='Sofa.Component.Topology.Container.Constant') # Needed to use components [MeshTopology]
settings.addObject('RequiredPlugin', name='Sofa.GL.Component.Rendering3D') # Needed to use components [OglModel]

self.addObject('URDFModelLoader',
filename=SpotRobot.get_asset("model.urdf"),
modelDirectory=SpotRobot.get_asset(""),
useFreeFlyerRootJoint=False,
printLog=False,
addCollision=False,
addJointsActuators=False)

robot = self.getChild("Robot")
robot.name = "model"
mechanical = robot.Model.getMechanicalState()
mechanical.showObject = False
mechanical.showObjectScale = 0.01
mechanical.drawMode = 0

# Direct problem
names = robot.Joints.children
positions = np.copy(robot.getMechanicalState().position.value)
for i in range(len(positions)):
jointName = names[i+1].name.value
value = 0 if jointName not in parameter.spot_ctrl_joint_infos else parameter.spot_ctrl_joint_infos[jointName].pos_desired
positions[i] = value
joint = robot.addObject('JointConstraint', template='Vec1', name='joint' + jointName, index=i,
valueType="angle",
value=value
)

Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
from __entity__ import SpotRobot
from __scene__ import createScene as ExampleScene
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
from stlib.core.baseParameters import BaseParameters, dataclasses

@dataclasses.dataclass
class ControlJointValue:
Kp: float = 0.0
Kd: float = 0.0
Ki: float = 0.0
i_clamp: float = 0.0
pos_desired: float = 0.0
vel_desired: float = 0.0

@dataclasses.dataclass
class SpotRobotParameters(BaseParameters):
name : str = "SpotRobot"

spot_ctrl_joint_infos = {
"fl.hy": ControlJointValue( 10000.0, 0.01, 1.0, 14.0, 0.91, 0.0),
"fl.kn": ControlJointValue( 10000.0, 0.01, 1.0, 14.0, -1.52, 0.0),
"fr.hy": ControlJointValue( 10000.0, 0.01, 1.0, 14.0, 0.91, 0.0),
"fr.kn": ControlJointValue( 10000.0, 0.01, 1.0, 14.0, -1.52, 0.0),
"hl.hy": ControlJointValue( 10000.0, 0.01, 1.0, 14.0, 0.91, 0.0),
"hl.kn": ControlJointValue( 10000.0, 0.01, 1.0, 14.0, -1.52, 0.0),
"hr.hy": ControlJointValue( 10000.0, 0.01, 1.0, 14.0, 0.91, 0.0),
"hr.kn": ControlJointValue( 10000.0, 0.01, 1.0, 14.0, -1.52, 0.0),
}

def toDict(self):
return dataclasses.asdict(self)
Loading