Program Listing for File inference_memory_nlp.hpp#

Return to documentation for file (python/morpheus/morpheus/_lib/include/morpheus/messages/memory/inference_memory_nlp.hpp)

/*
 * SPDX-FileCopyrightText: Copyright (c) 2021-2025, NVIDIA CORPORATION & AFFILIATES. All rights reserved.
 * SPDX-License-Identifier: Apache-2.0
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#pragma once

#include "morpheus/export.h"
#include "morpheus/messages/memory/inference_memory.hpp"
#include "morpheus/objects/tensor_object.hpp"
#include "morpheus/types.hpp"  // for TensorIndex

#include <pybind11/pytypes.h>

#include <memory>

namespace morpheus {
/****** Component public implementations *******************/
/****** InferenceMemoryNLP**********************************/
class MORPHEUS_EXPORT InferenceMemoryNLP : public InferenceMemory
{
  public:
    InferenceMemoryNLP(TensorIndex count, TensorObject&& input_ids, TensorObject&& input_mask, TensorObject&& seq_ids);

    const TensorObject& get_input_ids() const;

    const TensorObject& get_input_mask() const;

    const TensorObject& get_seq_ids() const;

    void set_input_ids(TensorObject&& input_ids);

    void set_input_mask(TensorObject&& input_mask);

    void set_seq_ids(TensorObject&& seq_ids);
};

/****** InferenceMemoryNLPInterfaceProxy********************/

struct MORPHEUS_EXPORT InferenceMemoryNLPInterfaceProxy : public InferenceMemoryInterfaceProxy
{
    static std::shared_ptr<InferenceMemoryNLP> init(TensorIndex count,
                                                    pybind11::object input_ids,
                                                    pybind11::object input_mask,
                                                    pybind11::object seq_ids);

    static pybind11::object get_input_ids(InferenceMemoryNLP& self);

    static void set_input_ids(InferenceMemoryNLP& self, pybind11::object cupy_values);

    static pybind11::object get_input_mask(InferenceMemoryNLP& self);

    static void set_input_mask(InferenceMemoryNLP& self, pybind11::object cupy_values);

    static pybind11::object get_seq_ids(InferenceMemoryNLP& self);

    static void set_seq_ids(InferenceMemoryNLP& self, pybind11::object cupy_values);
};  // end of group
}  // namespace morpheus