]> granicus.if.org Git - graphviz/commitdiff
Add the vpsc library for IPSEPCOLA features
authorerg <devnull@localhost>
Fri, 28 Apr 2006 19:03:46 +0000 (19:03 +0000)
committererg <devnull@localhost>
Fri, 28 Apr 2006 19:03:46 +0000 (19:03 +0000)
lib/vpsc/block.h [new file with mode: 0644]

diff --git a/lib/vpsc/block.h b/lib/vpsc/block.h
new file mode 100644 (file)
index 0000000..5292745
--- /dev/null
@@ -0,0 +1,74 @@
+/**
+ * \brief A block is a group of variables that must be moved together to improve
+ * the goal function without violating already active constraints.
+ * The variables in a block are spanned by a tree of active constraints.
+ *
+ * Authors:
+ *   Tim Dwyer <tgdwyer@gmail.com>
+ *
+ * Copyright (C) 2005 Authors
+ *
+ * This version is released under the CPL (Common Public License) with
+ * the Graphviz distribution.
+ * A version is also available under the LGPL as part of the Adaptagrams
+ * project: http://sourceforge.net/projects/adaptagrams.  
+ * If you make improvements or bug fixes to this code it would be much
+ * appreciated if you could also contribute those changes back to the
+ * Adaptagrams repository.
+ */
+
+#ifndef SEEN_REMOVEOVERLAP_BLOCK_H
+#define SEEN_REMOVEOVERLAP_BLOCK_H
+
+#include <vector>
+#include <iostream>
+class Variable;
+class Constraint;
+template <class T> class PairingHeap;
+class StupidPriorityQueue;
+
+class Block
+{
+       friend std::ostream& operator <<(std::ostream &os,const Block &b);
+public:
+       std::vector<Variable*> *vars;
+       double posn;
+       double weight;
+       double wposn;
+       Block(Variable *v=NULL);
+       ~Block(void);
+       Constraint* findMinLM();
+       Constraint* findMinLMBetween(Variable* lv, Variable* rv);
+       Constraint* findMinInConstraint();
+       Constraint* findMinOutConstraint();
+       void deleteMinInConstraint();
+       void deleteMinOutConstraint();
+       double desiredWeightedPosition();
+       void merge(Block *b, Constraint *c, double dist);
+       void merge(Block *b, Constraint *c);
+       void mergeIn(Block *b);
+       void mergeOut(Block *b);
+       void split(Block *&l, Block *&r, Constraint *c);
+       Constraint* splitBetween(Variable* vl, Variable* vr, Block* &lb, Block* &rb);
+       void setUpInConstraints();
+       void setUpOutConstraints();
+       double cost();
+       bool deleted;
+       long timeStamp;
+       PairingHeap<Constraint*> *in;
+       PairingHeap<Constraint*> *out;
+private:
+       typedef enum {NONE, LEFT, RIGHT} Direction;
+       typedef std::pair<double, Constraint*> Pair;
+       void reset_active_lm(Variable *v, Variable *u);
+       double compute_dfdv(Variable *v, Variable *u, Constraint *&min_lm);
+       Pair compute_dfdv_between(
+                       Variable*, Variable*, Variable*, Direction, bool);
+       bool canFollowLeft(Constraint *c, Variable *last);
+       bool canFollowRight(Constraint *c, Variable *last);
+       void populateSplitBlock(Block *b, Variable *v, Variable *u);
+       void addVariable(Variable *v);
+       void setUpConstraintHeap(PairingHeap<Constraint*>* &h,bool in);
+};
+
+#endif // SEEN_REMOVEOVERLAP_BLOCK_H