MuJoCo 解析 qfrc 三种力!带你测试鼠标拖拽物理交互效果

yumo6661周前 (05-15)技术文章5

视频讲解:MuJoCo 解析 qfrc 三种力!带你测试鼠标拖拽物理交互效果_哔哩哔哩_bilibili

代码仓库:GitHub -
LitchiCheng/mujoco-learning

今天分享下,在MuJoCo中有三种力,可以在官方文档中的mjData中看到如下定义

1. mjData.qfrc_actuator 对于关节电机,表现为力矩,如电机驱动关节转动;对于线性执行器,表现为线性力,如活塞推动连杆

2. mjData.qfrc_passive:由被动力学元件产生,像关节的弹簧力、阻尼力、摩擦力、接触力,比如 xml 中定义的关节的 ,接触,摩擦

3. mjData.qfrc_applied:外部施加的,比如手动给模型中的某个点施加力或力矩

力类型

来源

可控方式

qfrc_actuator

执行器(如电机)

通过data.ctrl数组控制

qfrc_passive

弹簧、阻尼、接触、摩擦等

修改模型参数(如stiffness)

qfrc_applied

手动施加或鼠标拖拽

直接修改data.qfrc_applied或鼠标交互

当在 MuJoCo 的可视化窗口中用鼠标拖拽模型时,MuJoCo 会自动计算并施加以下两种力:

位置拖拽(Position Drag):双击接触点或物体,按住Ctrl键,然后鼠标右键点击并拖动模型时,MuJoCo 会在接触点(或选中的物体)上施加一个位置约束,使物体跟随鼠标移动,等效于在接触点上施加一个弹簧阻尼力

旋转拖拽(Rotation Drag):双击接触点或物体,按住Ctrl键,然后鼠标左键按住旋转模型时,MuJoCo 会在物体上施加力矩,使其绕指定轴旋转。

记录拖拽过程中的 qfrc_actuator,完整代码如下

import mujoco_viewer
import numpy as np
# matplotlib.use('TkAgg')
import matplotlib.pyplot as plt
import time,math

class Test(mujoco_viewer.CustomViewer):
    def __init__(self, path):
        super().__init__(path, 3, azimuth=180, elevation=-30)
        self.path = path
    
    def runBefore(self):
        # 存储关节力矩的列表
        self.torque_history = []
        self.time_history = []
       
    def runFunc(self):
        if True:
            self.time_history.append(self.data.time)
            self.torque_history.append(self.data.qfrc_actuator.copy())  # 存储关节力矩
            if len(self.torque_history) > 20000:
                torque_history = np.array(self.torque_history)
                # 绘制关节力矩曲线
                plt.figure(figsize=(10, 6))
                for i in range(torque_history.shape[1]):
                    plt.subplot(torque_history.shape[1], 1, i + 1)
                    plt.plot(self.time_history, torque_history[:, i], label=f'Joint {i + 1} Torque')
                    plt.xlabel('Time (s)')
                    plt.ylabel('Torque (N·m)')
                    plt.title(f'Joint {i + 1} Torque Over Time')
                    plt.legend()
                    plt.grid(True)
                # plt.tight_layout()
                plt.show()

if __name__ == "__main__":
    test = Test("model/trs_so_arm100/scene.xml")
    test.run_loop()

    

相关文章

电脑录屏如何追随鼠标移动轨迹?EV录屏 追随鼠标功能

EV录屏追随鼠标效果演示。·打开EV录屏,需要5.3.6及以上版本。·切换录制区域,点击追随鼠标,选择画面尺寸,有16:9、4.3等多种尺寸可以选择。·点击开始录屏,录屏完成可以看到视频是追随着鼠标录...

EV录屏新功能:追随鼠标,让你的视频瞬间升级!

无论是制作教学视频、演示产品,还是录制游戏攻略,一款好用的电脑录屏软件都是必不可少的。今天,我要给大家介绍一款超实用的录屏工具——EV录屏。最近,它更新到了v5.3.6版本,新增了一个特别酷炫的功能—...

让交互更加生动!有意思的鼠标跟随 3D 旋转动效

今天,群友问了这样一个问题,如下所示的鼠标跟随交互效果,如何实现:简单分析一下,这个交互效果主要有两个核心:借助了 CSS 3D 的能力元素的旋转需要和鼠标的移动相结合本文,就将讲述如何使用纯 CSS...

全屏的十字准星跟随鼠标箭头移动奇怪的问题原因分析及处理方法

今天遇见一个奇怪的问题,有一个全屏的十字准星,然后跟随鼠标的移动而移动。大家可以看一下,现在有一个全屏的十字,我们的鼠标左右移动的时候也会跟着移动,我们点东西的时候也是可以点到的,遇见这种情况就特别奇...

Axure教程:手把手教你做截获鼠标指针

来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。昨天突发感想,教大家做了个Axure导航栏或广告悬停的效果。今天我又心血来潮了,再教你们一个很实用的 应用场景:截获鼠...