lib/browser/GraphBrowser/Region.java
author wenzelm
Thu, 29 Aug 2013 21:17:46 +0200
changeset 53292 f567c1c7b180
parent 50473 ca4088bf8365
permissions -rw-r--r--
option to insert unique completion immediately into buffer;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3599
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
     1
/***************************************************************************
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
     2
  Title:      GraphBrowser/Region.java
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
     3
  Author:     Stefan Berghofer, TU Muenchen
50473
ca4088bf8365 added speculative options for jEdit;
wenzelm
parents: 37738
diff changeset
     4
  Options:    :tabSize=4:
3599
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
     5
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
     6
  This is an auxiliary class which is used by the layout algorithm when
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
     7
  calculating coordinates with the "pendulum method". A "region" is a
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
     8
  group of nodes which "stick together".
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
     9
***************************************************************************/
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    10
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    11
package GraphBrowser;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    12
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    13
import java.util.*;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    14
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    15
class Region {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    16
	Vector vertices=new Vector(10,10);
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    17
	Graph gra;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    18
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    19
	public Region(Graph g) { gra=g; }
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    20
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    21
	public void addVertex(Vertex v) {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    22
		vertices.addElement(v);
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    23
	}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    24
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    25
	public Enumeration getVertices() {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    26
		return vertices.elements();
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    27
	}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    28
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    29
	public int pred_deflection() {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    30
		float d1=0;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    31
		int n=0;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    32
		Enumeration e1=vertices.elements();
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    33
		while (e1.hasMoreElements()) {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    34
			float d2=0;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    35
			int p=0;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    36
			n++;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    37
			Vertex v=(Vertex)(e1.nextElement());
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    38
			Enumeration e2=v.getParents();
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    39
			while (e2.hasMoreElements()) {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    40
				p++;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    41
				d2+=((Vertex)(e2.nextElement())).getX()-v.getX();
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    42
			}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    43
			if (p>0) d1+=d2/p;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    44
		}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    45
		return (int)(Math.round(d1/n));
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    46
	}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    47
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    48
	public int succ_deflection() {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    49
		float d1=0;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    50
		int n=0;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    51
		Enumeration e1=vertices.elements();
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    52
		while (e1.hasMoreElements()) {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    53
			float d2=0;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    54
			int p=0;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    55
			n++;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    56
			Vertex v=(Vertex)(e1.nextElement());
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    57
			Enumeration e2=v.getChildren();
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    58
			while (e2.hasMoreElements()) {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    59
				p++;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    60
				d2+=((Vertex)(e2.nextElement())).getX()-v.getX();
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    61
			}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    62
			if (p>0) d1+=d2/p;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    63
		}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    64
		return (int)(Math.round(d1/n));
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    65
	}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    66
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    67
	public void move(int x) {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    68
		Enumeration e1=vertices.elements();
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    69
		while (e1.hasMoreElements()) {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    70
			Vertex v=(Vertex)(e1.nextElement());
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    71
			v.setX(v.getX()+x);
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    72
		}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    73
	}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    74
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    75
	public void combine(Region r2) {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    76
		Enumeration e1=r2.getVertices();
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    77
		while (e1.hasMoreElements()) addVertex((Vertex)(e1.nextElement()));
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    78
	}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    79
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    80
	public int spaceBetween(Region r2) {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    81
		return ((Vertex)(r2.getVertices().nextElement())).leftX()-
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    82
			((Vertex)(vertices.lastElement())).rightX()-
37738
7bf3ec9e7b0c Boxes may now have different widths.
berghofe
parents: 33686
diff changeset
    83
			20;
3599
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    84
	}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    85
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    86
	public boolean touching(Region r2) {
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    87
		return spaceBetween(r2)==0;
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    88
	}
89cbba12863d Source files for Isabelle theory graph browser.
berghofe
parents:
diff changeset
    89
}