Source code for zoo.models.textmatching.text_matcher

#
# Copyright 2018 Analytics Zoo 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.
#

from zoo.models.common import *

if sys.version >= '3':
    long = int
    unicode = str


[docs]class TextMatcher(ZooModel, Ranker): """ The base class for text matching models in Analytics Zoo. Referred to MatchZoo implementation: https://github.com/NTMC-Community/MatchZoo """ def __init__(self, text1_length, vocab_size, embed_size=300, embed_weights=None, train_embed=True, target_mode="ranking", bigdl_type="float"): self.text1_length = text1_length self.vocab_size = vocab_size self.embed_size = embed_size self.embed_weights = embed_weights self.train_embed = train_embed assert target_mode == "ranking" or target_mode == "classification",\ "target_mode should be either ranking or classification" self.target_mode = target_mode self.bigdl_type = bigdl_type