/*
* Copyright (C) 2018 The Android Open Source Project
*
* 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.
*/
#ifndef NLP_SAFT_COMPONENTS_LANG_ID_MOBILE_CUSTOM_TOKENIZER_H_
#define NLP_SAFT_COMPONENTS_LANG_ID_MOBILE_CUSTOM_TOKENIZER_H_
#include <string>
#include "lang_id/common/fel/task-context.h"
#include "lang_id/common/lite_strings/stringpiece.h"
#include "lang_id/light-sentence.h"
namespace libtextclassifier3 {
namespace mobile {
namespace lang_id {
// Custom tokenizer for the LangId model.
class TokenizerForLangId {
public:
void Setup(TaskContext *context);
// Tokenizes |text|, placing the tokens into |sentence|. Customized for
// LangId. Currently (Sep 15, 2016) we tokenize on space, newline, tab, and
// any other 1-byte UTF8 character which is not a letter, ignore all empty
// tokens, and (for each of the remaining tokens) prepend "^" (special token
// begin marker) and append "$" (special token end marker).
//
// Tokens are stored into the "repeated Token token;" field of *sentence.
void Tokenize(StringPiece text, LightSentence *sentence) const;
private:
// If true, during tokenization, we use the lowercase version of each Unicode
// character from the text to tokenize. E.g., if this is true, the text "Foo
// bar" is tokenized as ["foo", "bar"]; otherwise, we get ["Foo", "bar"].
bool lowercase_input_ = false;
};
} // namespace lang_id
} // namespace mobile
} // namespace nlp_saft
#endif // NLP_SAFT_COMPONENTS_LANG_ID_MOBILE_CUSTOM_TOKENIZER_H_