In the middle of something

This commit is contained in:
René Fuhry 2023-04-28 23:54:45 +02:00 committed by GitHub
parent acedb7ddb8
commit 295f6f688b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 155 additions and 19 deletions

View File

@ -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;
} }

View File

@ -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);
} }
} }