In the middle of something
This commit is contained in:
parent
acedb7ddb8
commit
295f6f688b
168
src/Graph.java
168
src/Graph.java
@ -4,28 +4,37 @@ public class Graph {
|
|||||||
private Matrix adjazenzMatrix;
|
private Matrix adjazenzMatrix;
|
||||||
private Matrix distanzMatrix;
|
private Matrix distanzMatrix;
|
||||||
private Matrix wegMatrix;
|
private Matrix wegMatrix;
|
||||||
|
private boolean zusammenhaengend;
|
||||||
private int[] exzentrizitäten;
|
private int[] exzentrizitäten;
|
||||||
private int radius;
|
private int radius;
|
||||||
private int durchmesser;
|
private int durchmesser;
|
||||||
private int[] zentrum;
|
private int[] zentrum;
|
||||||
|
private int[][] components;
|
||||||
|
private int[][] bridges;
|
||||||
|
private int[] articulations;
|
||||||
|
|
||||||
|
|
||||||
public static void main(String[] args) {}
|
public static void main(String[] args) {}
|
||||||
|
|
||||||
public Graph(String file) {
|
public Graph(String file) {
|
||||||
|
zusammenhaengend = true;
|
||||||
adjazenzMatrix = new Matrix(file);
|
adjazenzMatrix = new Matrix(file);
|
||||||
calculateDistanzMatrix(adjazenzMatrix);
|
calculateDistanzMatrix();
|
||||||
calculateWegMatrix(adjazenzMatrix);
|
calculateWegMatrix();
|
||||||
calculateExzentrizitäten();
|
calculateExzentrizitäten();
|
||||||
calculateProperties();
|
calculateProperties();
|
||||||
|
findComponents();
|
||||||
|
findComponents();
|
||||||
|
findArticulations();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void calculateDistanzMatrix(Matrix matrix) {
|
public void calculateDistanzMatrix() {
|
||||||
distanzMatrix = new Matrix(matrix.getRowLength(), matrix.getColumnLength());
|
distanzMatrix = new Matrix(adjazenzMatrix.getRowLength(), adjazenzMatrix.getColumnLength());
|
||||||
Matrix potenzMatrix = adjazenzMatrix;
|
Matrix potenzMatrix = adjazenzMatrix;
|
||||||
|
|
||||||
for(int columnIndex=0; columnIndex < distanzMatrix.getColumnLength(); columnIndex++) {
|
for(int columnIndex=0; columnIndex < distanzMatrix.getColumnLength(); columnIndex++) {
|
||||||
for(int rowIndex=0; rowIndex < distanzMatrix.getRowLength(); rowIndex++) {
|
for(int rowIndex=0; rowIndex < distanzMatrix.getRowLength(); rowIndex++) {
|
||||||
if(matrix.getValueAt(rowIndex, columnIndex) == 1) {
|
if(adjazenzMatrix.getValueAt(rowIndex, columnIndex) == 1) {
|
||||||
distanzMatrix.insert(rowIndex, columnIndex, 1);
|
distanzMatrix.insert(rowIndex, columnIndex, 1);
|
||||||
} else if(columnIndex == rowIndex) {
|
} else if(columnIndex == rowIndex) {
|
||||||
distanzMatrix.insert(rowIndex, columnIndex, 0);
|
distanzMatrix.insert(rowIndex, columnIndex, 0);
|
||||||
@ -48,22 +57,22 @@ public class Graph {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void calculateWegMatrix(Matrix matrix) {
|
public void calculateWegMatrix() {
|
||||||
wegMatrix = new Matrix(matrix.getRowLength(), matrix.getColumnLength());
|
wegMatrix = new Matrix(adjazenzMatrix.getRowLength(), adjazenzMatrix.getColumnLength());
|
||||||
Matrix potenzMatrix = matrix;
|
Matrix potenzMatrix = adjazenzMatrix;
|
||||||
|
|
||||||
for(int columnIndex=0; columnIndex < wegMatrix.getColumnLength(); columnIndex++) {
|
for(int columnIndex=0; columnIndex < wegMatrix.getColumnLength(); columnIndex++) {
|
||||||
for(int rowIndex=0; rowIndex < wegMatrix.getRowLength(); rowIndex++) {
|
for(int rowIndex=0; rowIndex < wegMatrix.getRowLength(); rowIndex++) {
|
||||||
if(columnIndex == rowIndex) {
|
if(columnIndex == rowIndex) {
|
||||||
wegMatrix.insert(rowIndex, columnIndex, 1);
|
wegMatrix.insert(rowIndex, columnIndex, 1);
|
||||||
} else if(matrix.getValueAt(rowIndex, columnIndex) > 0 && wegMatrix.getValueAt(rowIndex, columnIndex) == 0) {
|
} else if(adjazenzMatrix.getValueAt(rowIndex, columnIndex) > 0 && wegMatrix.getValueAt(rowIndex, columnIndex) == 0) {
|
||||||
wegMatrix.insert(rowIndex, columnIndex, 1);
|
wegMatrix.insert(rowIndex, columnIndex, 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for(int k = 2; k < wegMatrix.getRowLength(); k++) {
|
for(int k = 2; k < wegMatrix.getRowLength(); k++) {
|
||||||
potenzMatrix = potenzMatrix.multiply(matrix);
|
potenzMatrix = potenzMatrix.multiply(adjazenzMatrix);
|
||||||
|
|
||||||
for(int columnIndex=0; columnIndex < wegMatrix.getColumnLength(); columnIndex++) {
|
for(int columnIndex=0; columnIndex < wegMatrix.getColumnLength(); columnIndex++) {
|
||||||
for(int rowIndex=0; rowIndex < wegMatrix.getRowLength(); rowIndex++) {
|
for(int rowIndex=0; rowIndex < wegMatrix.getRowLength(); rowIndex++) {
|
||||||
@ -78,10 +87,10 @@ public class Graph {
|
|||||||
public void calculateExzentrizitäten() {
|
public void calculateExzentrizitäten() {
|
||||||
exzentrizitäten = new int[distanzMatrix.getRowLength()];
|
exzentrizitäten = new int[distanzMatrix.getRowLength()];
|
||||||
for(int rowIndex = 0; rowIndex < distanzMatrix.getRowLength(); rowIndex++) {
|
for(int rowIndex = 0; rowIndex < distanzMatrix.getRowLength(); rowIndex++) {
|
||||||
int exzentrizität = -1;
|
int exzentrizität = 0;
|
||||||
|
|
||||||
for(int columnIndex = 0; columnIndex < distanzMatrix.getColumnLength(); columnIndex++) {
|
for(int columnIndex = 0; columnIndex < distanzMatrix.getColumnLength(); columnIndex++) {
|
||||||
if(distanzMatrix.getValueAt(columnIndex, rowIndex) > exzentrizität) {
|
if(distanzMatrix.getValueAt(columnIndex, rowIndex) > exzentrizität && rowIndex != columnIndex) {
|
||||||
exzentrizität = distanzMatrix.getValueAt(columnIndex, rowIndex);
|
exzentrizität = distanzMatrix.getValueAt(columnIndex, rowIndex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -91,8 +100,8 @@ public class Graph {
|
|||||||
|
|
||||||
public void calculateProperties() {
|
public void calculateProperties() {
|
||||||
radius = Integer.MAX_VALUE;
|
radius = Integer.MAX_VALUE;
|
||||||
durchmesser = 0;
|
durchmesser = -1;
|
||||||
int sum = 1;
|
int sum = 0;
|
||||||
|
|
||||||
for(int rowIndex = 0; rowIndex < exzentrizitäten.length; rowIndex++) {
|
for(int rowIndex = 0; rowIndex < exzentrizitäten.length; rowIndex++) {
|
||||||
if(exzentrizitäten[rowIndex] < radius) {
|
if(exzentrizitäten[rowIndex] < radius) {
|
||||||
@ -106,6 +115,11 @@ public class Graph {
|
|||||||
sum = 1;
|
sum = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(durchmesser == 0 && exzentrizitäten.length > 1) {
|
||||||
|
zusammenhaengend = false;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
zentrum = new int[sum];
|
zentrum = new int[sum];
|
||||||
|
|
||||||
for(int rowIndex = 0, index = 0; rowIndex < exzentrizitäten.length; rowIndex++) {
|
for(int rowIndex = 0, index = 0; rowIndex < exzentrizitäten.length; rowIndex++) {
|
||||||
@ -116,11 +130,135 @@ public class Graph {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void findComponents() {
|
||||||
|
components = new int[wegMatrix.getRowLength()][wegMatrix.getColumnLength()];
|
||||||
|
int[] component = new int[wegMatrix.getRowLength()];
|
||||||
|
|
||||||
|
for(int rowIndex = 0; rowIndex < wegMatrix.getRowLength(); rowIndex++) {
|
||||||
|
for(int columnIndex = 0, index = 0; columnIndex < wegMatrix.getColumnLength(); columnIndex++) {
|
||||||
|
if(wegMatrix.getValueAt(rowIndex, columnIndex) == 1) {
|
||||||
|
component[index] = columnIndex + 1;
|
||||||
|
index++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
components[rowIndex] = component;
|
||||||
|
}
|
||||||
|
if(!zusammenhaengend) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for(int rowIndex = 0; rowIndex < components.length; rowIndex++) {
|
||||||
|
for(int index = 1; index < components.length; index++) {
|
||||||
|
if(components[index] != null && components[rowIndex].equals(components[index])) {
|
||||||
|
components[index] = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public int[] findComponents(Matrix matrix) {
|
||||||
|
int[][] components = new int[][];
|
||||||
|
int[] component = new int[matrix.getRowLength()];
|
||||||
|
|
||||||
|
for(int rowIndex = 0; rowIndex < matrix.getRowLength(); rowIndex++) {
|
||||||
|
for(int columnIndex = 0, index = 0; columnIndex < matrix.getColumnLength(); columnIndex++) {
|
||||||
|
if(matrix.getValueAt(rowIndex, columnIndex) == 1) {
|
||||||
|
component[index] = columnIndex + 1;
|
||||||
|
index++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
components[rowIndex] = component;
|
||||||
|
}
|
||||||
|
if(!zusammenhaengend) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
for(int rowIndex = 0; rowIndex < components.length; rowIndex++) {
|
||||||
|
for(int index = 1; index < components.length; index++) {
|
||||||
|
if(components[index] != null && components[rowIndex].equals(components[index])) {
|
||||||
|
components[index] = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void findBridges() {
|
||||||
|
bridges = new int[wegMatrix.getRowLength()][2];
|
||||||
|
Matrix matrix = wegMatrix;
|
||||||
|
int[][] newComponents = new int[wegMatrix.getRowLength()][wegMatrix.getColumnLength()];
|
||||||
|
|
||||||
|
for(int rowIndex = 0; rowIndex < matrix.getRowLength(); rowIndex++) {
|
||||||
|
for(int columnIndex = 0; columnIndex < matrix.getColumnLength(); columnIndex++) {
|
||||||
|
if(rowIndex != columnIndex) {
|
||||||
|
matrix.insert(rowIndex, columnIndex, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(components.length == newComponents.length) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void findArticulations() {
|
||||||
|
articulations = new int[wegMatrix.getRowLength()];
|
||||||
|
Matrix matrix = wegMatrix;
|
||||||
|
int[][] newComponents = new int[wegMatrix.getRowLength()][wegMatrix.getColumnLength()];
|
||||||
|
|
||||||
|
for(int rowIndex = 0; rowIndex < matrix.getRowLength(); rowIndex++) {
|
||||||
|
for(int columnIndex = 0; columnIndex < matrix.getColumnLength(); columnIndex++) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(components.length == newComponents.length) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
String s = "";
|
String s = "";
|
||||||
|
|
||||||
s += "Adjazenzmatrix:\n" + adjazenzMatrix + "\nDistanzmatrix:\n" + distanzMatrix + "\nWegmatrix:\n" + wegMatrix;
|
s += "Adjazenzmatrix:\n" + adjazenzMatrix + "\nDistanzmatrix:\n" + distanzMatrix + "\nWegmatrix:\n" + wegMatrix;
|
||||||
s += "\nExzentrizitäten: " + Arrays.toString(exzentrizitäten) + "\nRadius: " + radius + "\nDurchmesser: " + durchmesser + "\nZentrum: " + Arrays.toString(zentrum);
|
|
||||||
|
if(!zusammenhaengend) {
|
||||||
|
s += "\nExzentrizitäten/Radius/Durchmesser: Kein zusammenhängender Graph";
|
||||||
|
} else {
|
||||||
|
s += "\nExzentrizitäten: " + Arrays.toString(exzentrizitäten) + "\nRadius: " + radius + "\nDurchmesser: " + durchmesser;
|
||||||
|
}
|
||||||
|
|
||||||
|
s += "\nZentrum: ";
|
||||||
|
if(zusammenhaengend) {
|
||||||
|
s += Arrays.toString(zentrum);
|
||||||
|
} else {
|
||||||
|
s += "Kein zusammenhängender Graph";
|
||||||
|
}
|
||||||
|
|
||||||
|
s += "\nKomponente: {";
|
||||||
|
for(int rowIndex = 0; rowIndex < components.length; rowIndex++) {
|
||||||
|
if(components[rowIndex] != null) {
|
||||||
|
s += Arrays.toString(components[rowIndex]);
|
||||||
|
if(rowIndex < components.length - 1) {
|
||||||
|
if(components[rowIndex + 1] != null) {
|
||||||
|
s += ",";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
s += "}";
|
||||||
|
|
||||||
|
s += "\nBrücken: {";
|
||||||
|
for(int rowIndex = 0; rowIndex < components.length; rowIndex++) {
|
||||||
|
if(components[rowIndex] != null) {
|
||||||
|
s += Arrays.toString(components[rowIndex]);
|
||||||
|
if(rowIndex < components.length - 1) {
|
||||||
|
if(components[rowIndex + 1] != null) {
|
||||||
|
s += ",";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
s += "}";
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
public class TestGraph {
|
public class TestGraph {
|
||||||
public static void main(String[] args) {
|
public static void main(String[] args) {
|
||||||
Graph g = new Graph("/home/old/projects/Java/graphprogram/graph.csv");
|
Graph g = new Graph("/home/old/projects/Java/graphprogram/24n_01.csv");
|
||||||
g.calculateExzentrizitäten();
|
|
||||||
g.calculateProperties();
|
|
||||||
System.out.println(g);
|
System.out.println(g);
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user