Skip to content

Commit

Permalink
Fix RemapTask support for global remapping
Browse files Browse the repository at this point in the history
  • Loading branch information
Levi-Armstrong committed Aug 13, 2024
1 parent 0776b5b commit 2dc8c14
Show file tree
Hide file tree
Showing 3 changed files with 49 additions and 16 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -45,9 +45,12 @@ class RemapTask : public TaskComposerTask
using UPtr = std::unique_ptr<RemapTask>;
using ConstUPtr = std::unique_ptr<const RemapTask>;

// Requried
static const std::string INOUT_KEYS_PORT;

RemapTask();
explicit RemapTask(std::string name,
std::map<std::string, std::string> remap,
const std::map<std::string, std::string>& remap,
bool copy = false,
bool is_conditional = false);
explicit RemapTask(std::string name, const YAML::Node& config, const TaskComposerPluginFactory& plugin_factory);
Expand All @@ -57,14 +60,15 @@ class RemapTask : public TaskComposerTask
bool operator!=(const RemapTask& rhs) const;

protected:
std::map<std::string, std::string> remap_;
bool copy_{ false };

friend struct tesseract_common::Serialization;
friend class boost::serialization::access;
template <class Archive>
void serialize(Archive& ar, const unsigned int version); // NOLINT

static TaskComposerNodePorts ports();

std::unique_ptr<TaskComposerNodeInfo>
runImpl(TaskComposerContext& context, OptionalTaskComposerExecutor executor = std::nullopt) const override final;
};
Expand Down
51 changes: 39 additions & 12 deletions tesseract_task_composer/core/src/nodes/remap_task.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -38,30 +38,59 @@ TESSERACT_COMMON_IGNORE_WARNINGS_POP

namespace tesseract_planning
{
RemapTask::RemapTask() : TaskComposerTask("RemapTask", TaskComposerNodePorts{}, false) {}
RemapTask::RemapTask(std::string name, std::map<std::string, std::string> remap, bool copy, bool is_conditional)
: TaskComposerTask(std::move(name), TaskComposerNodePorts{}, is_conditional), remap_(std::move(remap)), copy_(copy)
const std::string RemapTask::INOUT_KEYS_PORT = "keys";

RemapTask::RemapTask() : TaskComposerTask("RemapTask", RemapTask::ports(), false) {}
RemapTask::RemapTask(std::string name, const std::map<std::string, std::string>& remap, bool copy, bool is_conditional)
: TaskComposerTask(std::move(name), RemapTask::ports(), is_conditional), copy_(copy)
{
if (remap_.empty())
if (remap.empty())
throw std::runtime_error("RemapTask, remap should not be empty!");

std::vector<std::string> ikeys;
std::vector<std::string> okeys;
ikeys.reserve(remap.size());
okeys.reserve(remap.size());
for (const auto& pair : remap)
{
ikeys.push_back(pair.first);
okeys.push_back(pair.second);
}

input_keys_.add(INOUT_KEYS_PORT, ikeys);
output_keys_.add(INOUT_KEYS_PORT, okeys);
validatePorts();
}
RemapTask::RemapTask(std::string name, const YAML::Node& config, const TaskComposerPluginFactory& /*plugin_factory*/)
: TaskComposerTask(std::move(name), TaskComposerNodePorts{}, config)
: TaskComposerTask(std::move(name), RemapTask::ports(), config)
{
if (YAML::Node n = config["remap"])
remap_ = n.as<std::map<std::string, std::string>>();
else
throw std::runtime_error("RemapTask missing config key: 'remap'");
if (input_keys_.get<std::vector<std::string>>(INOUT_KEYS_PORT).size() !=
output_keys_.get<std::vector<std::string>>(INOUT_KEYS_PORT).size())
throw std::runtime_error("RemapTask, input and ouput port 'keys' must be same size");

if (YAML::Node n = config["copy"])
copy_ = n.as<bool>();
}

TaskComposerNodePorts RemapTask::ports()
{
TaskComposerNodePorts ports;
ports.input_required[INOUT_KEYS_PORT] = TaskComposerNodePorts::MULTIPLE;
ports.output_required[INOUT_KEYS_PORT] = TaskComposerNodePorts::MULTIPLE;
return ports;
}

std::unique_ptr<TaskComposerNodeInfo> RemapTask::runImpl(TaskComposerContext& context,
OptionalTaskComposerExecutor /*executor*/) const
{
auto info = std::make_unique<TaskComposerNodeInfo>(*this);
if (context.data_storage->remapData(remap_, copy_))
const auto& ikeys = input_keys_.get<std::vector<std::string>>(INOUT_KEYS_PORT);
const auto& okeys = output_keys_.get<std::vector<std::string>>(INOUT_KEYS_PORT);
std::map<std::string, std::string> remapping;
for (std::size_t i = 0; i < ikeys.size(); ++i)
remapping[ikeys[i]] = okeys[i];

if (context.data_storage->remapData(remapping, copy_))
{
info->color = "green";
info->return_value = 1;
Expand All @@ -81,7 +110,6 @@ std::unique_ptr<TaskComposerNodeInfo> RemapTask::runImpl(TaskComposerContext& co
bool RemapTask::operator==(const RemapTask& rhs) const
{
bool equal = true;
equal &= (remap_ == rhs.remap_);
equal &= (copy_ == rhs.copy_);
equal &= TaskComposerNode::operator==(rhs);
return equal;
Expand All @@ -92,7 +120,6 @@ template <class Archive>
void RemapTask::serialize(Archive& ar, const unsigned int /*version*/)
{
ar& BOOST_SERIALIZATION_BASE_OBJECT_NVP(TaskComposerTask);
ar& boost::serialization::make_nvp("remap_data", remap_);
ar& boost::serialization::make_nvp("copy", copy_);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1732,8 +1732,10 @@ TEST(TesseractTaskComposerCoreUnit, TaskComposerRemapTaskTests) // NOLINT
std::string str = R"(config:
conditional: true
copy: true
remap:
test: test2)";
inputs:
keys: [test]
outputs:
keys: [test2])";
YAML::Node config = YAML::Load(str);
RemapTask task("abc", config["config"], factory);
EXPECT_EQ(task.getName(), "abc");
Expand Down

0 comments on commit 2dc8c14

Please sign in to comment.