Spaces:
Running
Running
| // Copyright 2025 The ODML Authors. | |
| // | |
| // 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. | |
| namespace litert::lm { | |
| // Model resources for the litert lm model. | |
| class ModelResourcesLitertLm : public ModelResources { | |
| public: | |
| static absl::StatusOr<std::unique_ptr<ModelResources>> Create( | |
| std::unique_ptr<LitertLmLoader> litert_lm_loader); | |
| absl::StatusOr<const litert::Model*> GetTFLiteModel( | |
| ModelType model_type) override; | |
| absl::StatusOr<absl::string_view> GetTFLiteModelBuffer( | |
| ModelType model_type) override; | |
| std::optional<std::string> GetTFLiteModelBackendConstraint( | |
| ModelType model_type) override; | |
| // Returns the tokenizer from the *.litertlm file. If both SentencePiece and | |
| // HuggingFace tokenizer are present and supported by the current build | |
| // configuration, the SentencePiece tokenizer will be used. | |
| absl::StatusOr<std::unique_ptr<Tokenizer>> GetTokenizer() override; | |
| absl::StatusOr<const proto::LlmMetadata*> GetLlmMetadata() override; | |
| absl::StatusOr<std::reference_wrapper<ScopedFile>> GetScopedFile() override; | |
| absl::StatusOr<std::pair<size_t, size_t>> GetWeightsSectionOffset( | |
| ModelType model_type) override; | |
| protected: | |
| explicit ModelResourcesLitertLm( | |
| std::unique_ptr<LitertLmLoader> litert_lm_loader) | |
| : litert_lm_loader_(std::move(litert_lm_loader)) {} | |
| // The litert lm loader, used to mmap the tokenizer and tflite model etc from | |
| // the .litertlm model file. | |
| std::unique_ptr<LitertLmLoader> litert_lm_loader_; | |
| private: | |
| absl::flat_hash_map<ModelType, std::unique_ptr<litert::Model>> model_map_; | |
| std::unique_ptr<proto::LlmMetadata> llm_metadata_; | |
| }; | |
| } // namespace litert::lm | |