mujoco构建无物理约束的几何体运动

mujoco构建无物理约束的几何体运动。

中心位置放置立方块,一个圆球围绕中心按照圆的轨迹进行运动。

具体模型定义、代码实现具体如下:

bash 复制代码
#-*-coding:utf-8-*-
# date:2025-12-07
# Author: Eric

import mujoco
import mujoco.viewer
import numpy as np
import time

# 1. 定义MuJoCo XML模型(修复range参数+优化关节)
xml = """
<mujoco model="sphere_circle_trajectory">
    <compiler angle="degree"/>
    <option timestep="0.005"/>  <!-- 仿真步长,越小越平滑 -->
    <worldbody>
        <light diffuse="0.5 0.5 0.5" pos="0 0 3" dir="0 0 -1"/>
        <geom name="ground" type="plane" size="2 2 0.1" rgba="0.5 0.5 0.5 1"/>

        <body name="cube" pos="0 0 0.1">
            <joint type="free"/>
            <geom type="box" size="0.1 0.1 0.1" rgba="0.0 0.0 0.5 1"/>
        </body>

        <!-- 球体 -->
        <body name="sphere" pos="0.0 0.0 0.09">  <!-- z=0.09:球体半径,刚好贴地面 -->
            <!-- 关节:仅允许x/y平移,z轴通过微小range+高阻尼固定 -->
            <joint name="sphere_x" type="slide" axis="1 0 0" damping="1"/>
            <joint name="sphere_y" type="slide" axis="0 1 0" damping="1"/>
            <joint name="sphere_z" type="slide" axis="0 0 1" limited="true"
                   range="0.089 0.091" damping="100"/>  <!-- 微小范围+高阻尼固定z轴 -->
            <geom type="sphere" size="0.09" rgba="0.0 0.9 0.0 1"/>
        </body>
    </worldbody>

    <!-- 控制器:为x/y关节添加位置控制 -->
    <actuator>
        <position name="act_x" joint="sphere_x" kp="1000"/>  <!-- kp:位置增益 -->
        <position name="act_y" joint="sphere_y" kp="1000"/>
    </actuator>
</mujoco>
"""
# from_xml_path
# 2. 初始化MuJoCo模型和数据
model = mujoco.MjModel.from_xml_string(xml)

data = mujoco.MjData(model)

# 3. 定义圆形轨迹参数
circle_radius = 1.0       # 圆半径
center_x, center_y = 0, 0 # 圆心坐标
angular_velocity = 0.3    # 角速度(rad/s),控制运动速度

# 4. 仿真循环(带可视化)
with mujoco.viewer.launch_passive(model, data) as viewer:
    # 固定仿真帧率
    viewer._paused = False
    start_time = time.time()

    while viewer.is_running():
        # 计算当前时间和角度
        current_time = time.time() - start_time
        theta = angular_velocity * current_time  # 随时间变化的角度

        # 计算圆形轨迹的目标位置(x,y)
        target_x = center_x + circle_radius * np.cos(theta)
        target_y = center_y + circle_radius * np.sin(theta)

        # 方式:直接修改物体状态(无物理约束,慎用)
        data.joint("sphere_x").qpos = target_x
        data.joint("sphere_y").qpos = target_y

        # 运行一步仿真
        mujoco.mj_step(model, data)

        # 同步可视化
        viewer.sync()

        # 控制仿真帧率(避免过快)
        time.sleep(model.opt.timestep)

代码执行效果如下:

相关推荐
冷雨夜中漫步8 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
郝学胜-神的一滴9 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再9 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
喵手10 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
2501_9449347310 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
helloworldandy11 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
肖永威12 小时前
macOS环境安装/卸载python实践笔记
笔记·python·macos
TechWJ12 小时前
PyPTO编程范式深度解读:让NPU开发像写Python一样简单
开发语言·python·cann·pypto
枷锁—sha12 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
abluckyboy13 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法