OCS2::legged_robot::LeggedRobotInterface.cpp

news/2025/1/5 3:02:15/文章来源:https://www.cnblogs.com/penuel/p/18647568

这个文件主要是对最优问题的构造。

1. setupOptimalConrolProblem

void LeggedRobotInterface::setupOptimalConrolProblem(const std::string& taskFile, const std::string& urdfFile,const std::string& referenceFile, bool verbose)
{//pinocchio接口pinocchioInterfacePtr_.reset(new PinocchioInterface(centroidal_model::createPinocchioInterface(urdfFile, modelSettings_.jointNames)));//质心动力学centroidalModelInfo_ = centroidal_model::createCentroidalModelInfo(*pinocchioInterfacePtr_, centroidal_model::loadCentroidalType(taskFile),centroidal_model::loadDefaultJointState(pinocchioInterfacePtr_->getModel().nq - 6, referenceFile), modelSettings_.contactNames3DoF,modelSettings_.contactNames6DoF);  // 足迹规划auto swingTrajectoryPlanner =std::make_unique<SwingTrajectoryPlanner>(loadSwingTrajectorySettings(taskFile, "swing_trajectory_config", verbose), 4);// 参考器初始化referenceManagerPtr_ =std::make_shared<SwitchedModelReferenceManager>(loadGaitSchedule(referenceFile, verbose), std::move(swingTrajectoryPlanner));// 最优化问题构造:problemPtr_.reset(new OptimalControlProblem);//动力学  problemPtr_->dynamicsPtr = new LeggedRobotDynamicsAD(*pinocchioInterfacePtr_, centroidalModelInfo_, modelName, modelSettings_);//costproblemPtr_->costPtr->add("baseTrackingCost", getBaseTrackingCost(taskFile, centroidalModelInfo_, false));std::unique_ptr<EndEffectorKinematics<scalar_t>> eeKinematicsPtr;eeKinematicsPtr.reset(new PinocchioEndEffectorKinematicsCppAd(*pinocchioInterfacePtr_, pinocchioMappingCppAd, {footName},centroidalModelInfo_.stateDim, centroidalModelInfo_.inputDim,velocityUpdateCallback, footName, modelSettings_.modelFolderCppAd,modelSettings_.recompileLibrariesCppAd, modelSettings_.verboseCppAd));//约束problemPtr_->inequalityConstraintPtr->add(footName + "_frictionCone", getFrictionConeConstraint(i, frictionCoefficient));problemPtr_->equalityConstraintPtr->add(footName + "_zeroForce", getZeroForceConstraint(i));problemPtr_->equalityConstraintPtr->add(footName + "_zeroVelocity",getZeroVelocityConstraint(*eeKinematicsPtr, i, useAnalyticalGradientsConstraints));problemPtr_->equalityConstraintPtr->add(footName + "_normalVelocity",getNormalVelocityConstraint(*eeKinematicsPtr, i, useAnalyticalGradientsConstraints));//预计算problemPtr_->preComputationPtr.reset(new LeggedRobotPreComputation(*pinocchioInterfacePtr_, centroidalModelInfo_,*referenceManagerPtr_->getSwingTrajectoryPlanner(), modelSettings_));//rolloutrolloutPtr_.reset(new TimeTriggeredRollout(*problemPtr_->dynamicsPtr, rolloutSettings_));//initializationinitializerPtr_.reset(new LeggedRobotInitializer(centroidalModelInfo_, *referenceManagerPtr_, extendNormalizedMomentum));
}

2. 最优问题构建

getBaseTrackingCost()
{
return std::make_unique<LeggedRobotStateInputQuadraticCost>(std::move(Q), std::move(R), info, *referenceManagerPtr_);
}
getFrictionConeConstraint()
{FrictionConeConstraint::Config frictionConeConConfig(frictionCoefficient);std::make_unique<FrictionConeConstraint>(*referenceManagerPtr_, std::move(frictionConeConConfig), contactPointIndex,centroidalModelInfo_);
}
getFrictionConeSoftConstraint()
{
return std::make_unique<StateInputSoftConstraint>(getFrictionConeConstraint(contactPointIndex, frictionCoefficient),std::make_unique<RelaxedBarrierPenalty>(barrierPenaltyConfig));
}
getZeroForceConstraint()
{
return std::make_unique<ZeroForceConstraint>(*referenceManagerPtr_, contactPointIndex, centroidalModelInfo_);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/862908.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

茶饮门店食品安全升级战:看板软件如何成为制胜关键?

茶饮门店可以通过选择适合的看板软件、设计与食品安全相关的看板、细化食品安全管理任务、实时更新与跟踪任务进度、利用数据分析功能优化管理以及确保信息安全性与合规性等策略来利用看板软件提升食品安全管理水平。这些措施有助于门店提高食品安全管理的效率和效果,保障消费…

Google Chrome cursor auto edit mode bug All In One

Google Chrome cursor auto text edit mode bug All In One Google Chrome 光标自动进入文本编辑模式 bug 插入符号浏览 模式 Caret Browsing Mode Google Chrome cursor auto text edit mode bug All In OneGoogle Chrome 光标自动进入文本编辑模式 bugtext cursor bug问题分析…

关于 Webstorm 2024 安装激活教程以及常见问题(激活至2026,实际上永久,亲测!)

申明:本教程 Webstorm补丁、激活码均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除。若条件允许,希望大家购买正版 !卸载老版本 Webstorm 首先,如果小伙伴的电脑上有安装老版本的 Webstorm , 需要将其彻底卸载掉,如下所示(没有安装则不用管,直接安…

k8s资源服务质量管理(Resource QoS)

10.4.3 资源服务质量管理(Resource QoS) 本节对Kubernetes如何根据Pod的Requests和Limits配置来实现针对Pod的不同级别的资源服务质量控制(QoS)进行说明。 在Kubernetes的资源QoS体系中,需要保证高可靠性的Pod可以申请可靠资源,而一些不需要高可靠性的Pod可以申请可靠性…

车联网HIL仿真测试解决方案

经纬恒润结合硬件在环技术、通信信息、云平台、场景仿真、车载单元仿真技术,开发了针对车联网V2N测试&V2X应用场景测试的仿真系统,可为车载终端TBOX/OBU软硬件开发与测试、数据后台系统功能开发与验证以及智能网联车辆系统级测试等提供全方位的仿真与测试环境,为车联网相…

数据库中的基本数据类型:整型、浮点型与字符型的探讨

title: 数据库中的基本数据类型:整型、浮点型与字符型的探讨 date: 2025/1/2 updated: 2025/1/2 author: cmdragon excerpt: 数据类型是数据库管理系统(DBMS)中的基本构建块,它决定了数据的存储方式、操作方式以及有效性。在设计数据库时,合理选择和使用数据类型至关重要。…

RoboMaster电控 STM32开发环境搭建

CPU工作频率可以达到168MHz,基本可以满足比赛中所有的控制需求。 stm32的主流开发方式包括寄存器开发,标准库开发,HAL库(LL库)开发。 寄存器开发即直接控制32的寄存器,工程运行效率高,但是开发难度大,可读性与可移植性差; 标准库开发即使用ST官方开源的一套标准固件库…

负载均衡

负载均衡(Load Balancing)是一种分布式系统架构中的技术,用于将网络请求或任务分散到多个服务器或资源上。 比如:当系统面临大量用户访问,负载过高的时候,通常会使用增加服务器数量来进行横向扩展来提高整个系统的处理能力。 如下图所示:上图的:tomcat-node1、tomcat-n…

Html启动特定的输入法

注册表 shurufa-Handinput.regWindows Registry Editor Version 5.00[HKEY_CLASSES_ROOT\Handinput]@="URL:Handinput Protocol Handler""URL Protocol"=""[HKEY_CLASSES_ROOT\Handinput\DefaultIcon]@="C:\\Program Files (x86)\\SogouInp…

详解AQS五:深入理解共享锁CountDownLatch

CountDownLatch是一个常用的共享锁,其功能相当于一个多线程环境下的倒数门闩。CountDownLatch可以指定一个计数值,在并发环境下由线程进行减一操作,当计数值变为0之后,被await方法阻塞的线程将会唤醒。本篇文章深入剖析CountDownLatch和AQS的关系,并逐行源码解析其实现。C…

线段树从入门到出门

线段树详介(带lazy) 线段树和树状数组不同,它维护的是一个个子序列。如上图,对于一个区间 \([l, r]\),它的左儿子就是 \([l, mid]\),右儿子就是 \([mid + 1, r]\),其中 \(mid = \frac{l+r}{2}\)。 我们可以给线段树上的每一个结点编号,假设父节点编号为 \(x\),左儿子编…

(回顾)2023年度项目管理软件全方位对比:14款最佳工具推荐

在当今竞争激烈的商业环境中,高效的项目管理是企业成功的关键因素之一。无论是初创公司还是大型企业,选择一款合适的项目管理软件能够极大地提升团队协作效率、优化资源分配,并确保项目按时交付。2023 年,市场上涌现出众多优秀的项目管理工具,每一款都有其独特的优势和适用…