All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.datavec.nlp.movingwindow.ContextLabelRetriever Maven / Gradle / Ivy

There is a newer version: 1.0.0-beta7
Show newest version
/*
 *  * Copyright 2016 Skymind, Inc.
 *  *
 *  *    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.
 */

package org.datavec.nlp.movingwindow;


import org.datavec.api.berkeley.Pair;
import org.datavec.api.berkeley.StringUtils;
import org.datavec.api.util.MultiDimensionalMap;
import org.datavec.nlp.tokenization.tokenizer.Tokenizer;
import org.datavec.nlp.tokenization.tokenizerfactory.TokenizerFactory;

import java.util.ArrayList;
import java.util.List;

/**
 * Context Label Retriever
 *
 * @author Adam Gibson
 */
public class ContextLabelRetriever {


  private static String BEGIN_LABEL = "<([A-Za-z]+|\\d+)>";
  private static String END_LABEL = "";


  private ContextLabelRetriever() {
  }


  /**
   * Returns a stripped sentence with the indices of words
   * with certain kinds of labels.
   *
   * @param sentence the sentence to process
   * @return a pair of a post processed sentence
   * with labels stripped and the spans of
   * the labels
   */
  public static Pair> stringWithLabels(String sentence, TokenizerFactory tokenizerFactory) {
    MultiDimensionalMap map = MultiDimensionalMap.newHashBackedMap();
    Tokenizer t = tokenizerFactory.create(sentence);
    List currTokens = new ArrayList<>();
    String currLabel = null;
    String endLabel = null;
    List>> tokensWithSameLabel = new ArrayList<>();
    while (t.hasMoreTokens()) {
      String token = t.nextToken();
      if (token.matches(BEGIN_LABEL)) {
        currLabel = token;

        //no labels; add these as NONE and begin the new label
        if (!currTokens.isEmpty()) {
          tokensWithSameLabel.add(new Pair<>("NONE", (List) new ArrayList<>(currTokens)));
          currTokens.clear();

        }

      } else if (token.matches(END_LABEL)) {
        if (currLabel == null)
          throw new IllegalStateException("Found an ending label with no matching begin label");
        endLabel = token;
      } else
        currTokens.add(token);

      if (currLabel != null && endLabel != null) {
        currLabel = currLabel.replaceAll("[<>/]", "");
        endLabel = endLabel.replaceAll("[<>/]", "");
        assert !currLabel.isEmpty() : "Current label is empty!";
        assert !endLabel.isEmpty() : "End label is empty!";
        assert currLabel.equals(endLabel) : "Current label begin and end did not match for the parse. Was: " + currLabel + " ending with " + endLabel;

        tokensWithSameLabel.add(new Pair<>(currLabel, (List) new ArrayList<>(currTokens)));
        currTokens.clear();


        //clear out the tokens
        currLabel = null;
        endLabel = null;
      }


    }

    //no labels; add these as NONE and begin the new label
    if (!currTokens.isEmpty()) {
      tokensWithSameLabel.add(new Pair<>("none", (List) new ArrayList<>(currTokens)));
      currTokens.clear();

    }

    //now join the output
    StringBuilder strippedSentence = new StringBuilder();
    for (Pair> tokensWithLabel : tokensWithSameLabel) {
      String joinedSentence = StringUtils.join(tokensWithLabel.getSecond(), " ");
      //spaces between separate parts of the sentence
      if (!(strippedSentence.length() < 1))
        strippedSentence.append(" ");
      strippedSentence.append(joinedSentence);
      int begin = strippedSentence.toString().indexOf(joinedSentence);
      int end = begin + joinedSentence.length();
      map.put(begin, end, tokensWithLabel.getFirst());
    }


    return new Pair<>(strippedSentence.toString(), map);
  }


}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy