diff options
| author | Patrick Simianer <p@simianer.de> | 2012-04-23 21:44:02 +0200 | 
|---|---|---|
| committer | Patrick Simianer <p@simianer.de> | 2012-04-23 21:44:02 +0200 | 
| commit | 2f427278616cbe3fa6f56d6b97c40b3894dbd950 (patch) | |
| tree | 6998435e4677437c474cf0f835ce9f72d70d3945 /rst_parser/arc_factored_marginals.cc | |
| parent | 6d0d0eb6bbfaee6b6998659a55e2195977ccd217 (diff) | |
| parent | 217c4aaeba1c9f19b3420b526235bffd86c7a92b (diff) | |
Merge remote-tracking branch 'upstream/master'
Conflicts:
	Makefile.am
	configure.ac
Diffstat (limited to 'rst_parser/arc_factored_marginals.cc')
| -rw-r--r-- | rst_parser/arc_factored_marginals.cc | 58 | 
1 files changed, 58 insertions, 0 deletions
| diff --git a/rst_parser/arc_factored_marginals.cc b/rst_parser/arc_factored_marginals.cc new file mode 100644 index 00000000..3e8c9f86 --- /dev/null +++ b/rst_parser/arc_factored_marginals.cc @@ -0,0 +1,58 @@ +#include "arc_factored.h" + +#include <iostream> + +#include "config.h" + +using namespace std; + +#if HAVE_EIGEN + +#include <Eigen/Dense> +typedef Eigen::Matrix<prob_t, Eigen::Dynamic, Eigen::Dynamic> ArcMatrix; +typedef Eigen::Matrix<prob_t, Eigen::Dynamic, 1> RootVector; + +void ArcFactoredForest::EdgeMarginals(prob_t *plog_z) { +  ArcMatrix A(num_words_,num_words_); +  RootVector r(num_words_); +  for (int h = 0; h < num_words_; ++h) { +    for (int m = 0; m < num_words_; ++m) { +      if (h != m) +        A(h,m) = edges_(h,m).edge_prob; +      else +        A(h,m) = prob_t::Zero(); +    } +    r(h) = root_edges_[h].edge_prob; +  } + +  ArcMatrix L = -A; +  L.diagonal() = A.colwise().sum(); +  L.row(0) = r; +  ArcMatrix Linv = L.inverse(); +  if (plog_z) *plog_z = Linv.determinant(); +  RootVector rootMarginals = r.cwiseProduct(Linv.col(0)); +  static const prob_t ZERO(0); +  static const prob_t ONE(1); +//  ArcMatrix T = Linv; +  for (int h = 0; h < num_words_; ++h) { +    for (int m = 0; m < num_words_; ++m) { +      const prob_t marginal = (m == 0 ? ZERO : ONE) * A(h,m) * Linv(m,m) - +                              (h == 0 ? ZERO : ONE) * A(h,m) * Linv(m,h); +      edges_(h,m).edge_prob = marginal; +//      T(h,m) = marginal; +    } +    root_edges_[h].edge_prob = rootMarginals(h); +  } +//   cerr << "ROOT MARGINALS: " << rootMarginals.transpose() << endl; +//  cerr << "M:\n" << T << endl; +} + +#else + +void ArcFactoredForest::EdgeMarginals(prob_t *) { +  cerr << "EdgeMarginals() requires --with-eigen!\n"; +  abort(); +} + +#endif + | 
