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

cc.mallet.classify.constraints.pr.MaxEntPRConstraint Maven / Gradle / Ivy

Go to download

MALLET is a Java-based package for statistical natural language processing, document classification, clustering, topic modeling, information extraction, and other machine learning applications to text.

There is a newer version: 2.0.12
Show newest version
/* Copyright (C) 2011 Univ. of Massachusetts Amherst, Computer Science Dept.
   This file is part of "MALLET" (MAchine Learning for LanguagE Toolkit).
   http://www.cs.umass.edu/~mccallum/mallet
   This software is provided under the terms of the Common Public License,
   version 1.0, as published by http://www.opensource.org.  For further
   information, see the file `LICENSE' included with this distribution. */

package cc.mallet.classify.constraints.pr;

import java.util.BitSet;

import cc.mallet.types.FeatureVector;
import cc.mallet.types.InstanceList;

/**
 * Interface for expectation constraints for use with Posterior Regularization (PR).
 * 
 * @author Gregory Druck
 */

public interface MaxEntPRConstraint {

  int numDimensions();
  
  double getScore(FeatureVector input, int label, double[] parameters);
  
  void incrementExpectations(FeatureVector fv, double[] dist, double weight);

  double getAuxiliaryValueContribution(double[] parameters);
  
  double getCompleteValueContribution();
  
  void getGradient(double[] parameters, double[] gradient);
  
  /**
   * Zero expectation values. Called before re-computing gradient.
   */
  void zeroExpectations();
  
  /**
   * @param data Unlabeled data
   * @return Returns a bitset of the size of the data, with the bit set if a constraint feature fires in that instance.
   */
  BitSet preProcess(InstanceList data);
  
  /**
   * Gives the constraint the option to do some caching
   * using only the FeatureVector.  For example, the
   * constrained input features could be cached.
   * 
   * @param input FeatureVector input
   */
  void preProcess(FeatureVector input);
  
  /**
   * This is used in multi-threading.  
   * 
   * @return A copy of the GEConstraint.  
   */
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy