diff --git a/README.md b/README.md index 6c3fd2e..6f81b49 100644 --- a/README.md +++ b/README.md @@ -17,5 +17,7 @@ With the implied additional rules: 5. Any dead cell who doesn’t have exactly 3 living neighbors stays dead, unchanged. - -TEST \ No newline at end of file +To download the json library: +https://code.google.com/archive/p/json-simple/downloads +tutorial to install it on vscode: +https://www.youtube.com/watch?v=g6vvEEm2hhs \ No newline at end of file diff --git a/conwayRule.json b/conwayRule.json new file mode 100644 index 0000000..12cb7a9 --- /dev/null +++ b/conwayRule.json @@ -0,0 +1,17 @@ +[{"cell": { + "value" : 1, + "color" : [167,237,139], + "conditionCountNear" : [2,3], + "conditionHighestNear" : [], + "ifValue" : 1, + "elseValue" : 0 +}}, +{"cell": { + "value" : 0, + "color" : [37,52,31], + "conditionCountNear" : [3], + "conditionHighestNear" : [], + "ifValue" : 1, + "elseValue" : 0 +}} +] \ No newline at end of file diff --git a/gasRule.json b/gasRule.json new file mode 100644 index 0000000..9c4290b --- /dev/null +++ b/gasRule.json @@ -0,0 +1,48 @@ +[{"cell": { + "value" : 5, + "color" : [255,255,255], + "conditionCountNear" : [], + "conditionHighestNear" : [], + "ifValue" : 4, + "elseValue" : 4 +}}, +{"cell": { + "value" : 4, + "color" : [204,204,204], + "conditionCountNear" : [], + "conditionHighestNear" : [], + "ifValue" : 3, + "elseValue" : 3 +}}, +{"cell": { + "value" : 3, + "color" : [153,153,153], + "conditionCountNear" : [], + "conditionHighestNear" : [], + "ifValue" : 2, + "elseValue" : 2 +}}, +{"cell": { + "value" : 2, + "color" : [102,102,102], + "conditionCountNear" : [], + "conditionHighestNear" : [], + "ifValue" : 1, + "elseValue" : 1 +}}, +{"cell": { + "value" : 1, + "color" : [51,51,51], + "conditionCountNear" : [], + "conditionHighestNear" : [], + "ifValue" : 0, + "elseValue" : 0 +}}, +{"cell": { + "value" : 0, + "color" : [0,0,0], + "conditionCountNear" : [], + "conditionHighestNear" : [5], + "ifValue" : 5, + "elseValue" : 0 +}}] \ No newline at end of file diff --git a/ressources/Rule/cutsomrule.csv b/ressources/Rule/cutsomrule.csv new file mode 100644 index 0000000..e16241f --- /dev/null +++ b/ressources/Rule/cutsomrule.csv @@ -0,0 +1,2 @@ +0;1;2;3;4 +3 \ No newline at end of file diff --git a/ressources/World/randomFive.csv b/ressources/World/randomFive.csv new file mode 100644 index 0000000..96026f8 --- /dev/null +++ b/ressources/World/randomFive.csv @@ -0,0 +1,100 @@ +5;0;0;5;5;0;0;0;0;5;5;5;0;5;5;5;5;0;5;0;5;0;0;5;5;0;5;0;0;5;0;0;0;0;0;5;5;0;0;0;5;0;0;0;0;0;5;5;0;0;0;0;5;0;5;0;5;0;0;0;0;0;0;5;0;5;5;0;5;5;0;0;5;0;0;5;5;0;0;5;5;5;0;0;5;5;0;0;5;5;5;0;5;5;5;0;5;5;5;5 +5;0;0;5;0;0;0;0;0;5;5;0;0;0;0;0;5;0;0;5;0;0;5;5;5;0;5;5;5;5;0;0;0;0;5;5;0;5;0;0;5;0;5;0;0;5;0;5;0;5;5;5;5;0;0;5;0;0;0;5;5;5;0;5;0;5;0;5;5;5;0;0;5;5;5;0;0;5;0;5;0;0;5;5;0;5;5;5;5;0;0;5;0;5;0;5;0;0;0;5 +0;5;0;0;0;0;0;5;0;0;0;0;0;0;0;0;5;0;0;0;0;5;0;0;5;5;5;0;0;5;5;0;5;5;0;5;0;5;0;5;5;0;0;0;0;0;5;0;0;0;0;0;0;0;5;5;5;0;0;0;5;5;0;5;0;0;0;0;0;5;5;0;5;0;5;0;5;5;5;5;5;5;0;0;0;0;0;0;0;0;5;5;0;5;0;0;0;0;5;0 +5;5;0;5;0;0;0;0;0;0;5;5;0;0;5;5;0;0;0;0;0;0;5;0;0;5;0;0;5;0;5;0;5;0;5;5;5;5;5;0;0;5;0;0;0;5;5;0;0;5;5;0;5;0;0;0;0;0;5;5;0;0;5;0;5;5;5;0;5;0;5;0;0;5;5;5;0;5;0;5;0;5;5;5;5;0;0;5;5;0;5;5;5;5;0;5;0;0;5;5 +5;5;0;0;0;5;5;0;0;5;5;0;5;5;5;0;5;0;0;5;0;5;5;5;5;5;5;5;0;0;0;0;5;5;5;0;5;5;0;5;5;5;5;0;0;0;0;0;0;5;5;0;0;0;0;5;5;5;5;5;0;5;5;5;0;5;5;0;0;5;0;0;0;0;5;5;0;5;0;0;0;5;0;5;0;0;5;0;0;5;0;0;5;0;0;5;0;0;0;5 +5;0;5;0;5;0;0;5;5;5;0;5;0;5;0;0;5;5;5;0;0;0;0;5;5;0;0;0;5;0;0;0;0;5;5;0;5;5;5;0;0;5;5;5;0;0;5;5;0;5;5;0;0;0;0;5;0;5;5;0;5;5;0;5;0;0;0;0;5;0;0;5;0;5;5;0;0;5;0;5;5;5;0;0;5;0;0;5;5;0;0;0;5;5;5;5;0;5;5;0 +0;0;0;0;0;0;5;0;0;0;5;5;5;0;5;0;5;5;5;5;0;5;0;5;5;5;0;0;5;0;5;0;0;5;0;5;5;5;0;5;0;0;0;5;0;0;5;5;0;0;0;0;0;5;5;5;5;0;0;5;5;5;5;5;5;5;0;5;0;5;5;0;0;5;0;0;5;5;0;0;5;5;5;5;0;5;5;0;0;0;5;5;0;0;5;5;0;5;0;0 +5;5;0;0;0;0;5;0;0;0;5;5;5;0;5;5;0;0;5;0;5;0;5;5;5;5;0;5;0;5;0;0;5;0;5;0;5;0;0;0;0;0;0;5;5;0;0;5;5;5;5;0;5;5;0;5;0;5;5;0;5;0;0;0;5;5;5;0;5;5;0;5;0;0;0;0;0;0;5;5;0;0;0;0;0;0;0;0;0;5;5;0;5;0;0;0;5;0;0;0 +5;5;5;5;5;0;0;5;5;0;0;0;0;0;5;0;0;5;0;5;5;5;5;5;0;5;5;5;5;5;0;5;0;0;0;5;0;0;5;5;0;0;5;5;0;0;5;5;5;0;0;0;0;0;0;0;5;5;0;5;5;0;0;0;5;5;5;0;0;0;5;5;0;0;0;5;5;0;5;5;5;5;0;5;5;0;0;5;0;0;5;5;5;0;5;5;5;0;0;5 +5;5;0;0;0;5;5;5;0;5;5;0;5;5;5;5;0;5;5;0;5;5;0;0;5;5;5;5;5;0;5;0;0;0;0;0;5;5;5;5;5;0;5;5;5;5;5;5;5;0;0;5;0;5;5;0;5;5;5;0;5;0;5;0;5;0;5;0;5;5;5;0;5;0;5;5;0;0;5;0;5;5;5;5;5;0;0;0;0;0;0;5;5;0;5;0;5;0;5;5 +0;5;0;0;0;5;0;0;0;5;0;5;0;5;5;0;5;0;5;5;0;5;0;5;5;0;0;5;5;0;0;0;0;0;5;0;0;5;5;5;5;5;5;5;5;0;0;0;5;5;0;0;5;5;5;5;5;5;5;5;5;0;5;5;5;0;5;5;0;0;0;5;0;0;0;0;5;0;0;5;0;0;5;0;5;5;5;0;5;5;0;5;5;5;5;5;0;5;0;5 +5;5;0;0;5;5;0;5;0;5;5;5;0;5;5;0;0;0;5;5;5;0;5;5;5;0;5;5;5;0;5;0;5;0;0;0;5;0;0;0;5;0;0;5;0;5;0;0;5;0;0;5;0;5;0;0;0;0;0;5;5;0;0;5;5;5;0;0;0;0;0;5;0;0;5;0;5;0;5;5;0;5;0;5;0;0;0;0;0;0;5;0;0;0;0;5;5;5;5;5 +5;5;5;5;0;5;5;5;5;5;5;5;0;5;5;0;5;5;5;0;0;5;5;0;0;5;5;5;5;0;5;0;5;5;5;0;0;5;0;0;5;0;5;5;0;0;0;5;5;5;5;0;5;5;0;5;5;5;0;5;0;5;0;0;0;0;5;0;5;0;0;0;5;5;5;5;5;0;0;5;5;5;0;5;5;5;5;5;5;5;5;0;5;0;5;0;0;0;0;5 +5;5;0;0;0;0;0;5;5;0;5;5;0;5;0;0;0;5;5;0;5;5;5;0;5;5;0;5;5;0;0;0;0;5;0;5;5;0;5;0;0;0;0;0;5;5;0;0;0;5;0;5;0;5;0;0;0;5;5;5;0;5;5;0;5;5;0;0;0;5;5;5;0;5;5;5;5;0;0;5;5;5;0;0;0;0;5;5;0;0;0;0;0;0;5;0;0;0;5;5 +5;5;5;0;0;0;5;5;0;5;5;0;5;5;0;0;0;0;5;0;0;5;5;5;0;5;0;0;5;5;0;5;0;5;0;5;0;5;5;0;5;5;5;5;5;5;5;5;0;5;0;5;5;0;0;0;0;5;0;0;5;0;0;5;5;5;5;5;0;0;5;0;0;0;5;0;0;0;5;0;0;0;0;0;0;0;0;0;5;5;0;0;5;0;5;0;0;5;0;5 +5;0;0;5;0;5;5;0;0;5;5;0;5;5;0;0;0;5;0;5;0;0;0;5;0;5;0;5;5;5;0;0;0;0;5;5;0;0;5;5;0;5;5;5;0;5;0;5;5;5;5;5;5;0;0;5;5;5;0;0;0;0;0;5;0;0;0;0;0;5;5;5;5;0;0;5;5;5;5;5;5;5;5;0;0;5;0;0;5;0;5;5;5;5;5;5;0;5;0;0 +0;5;0;0;0;0;5;0;5;5;5;0;0;0;0;0;5;5;0;0;5;0;5;5;0;5;0;5;0;0;0;5;0;5;0;5;0;0;0;0;0;0;5;0;0;0;0;0;5;0;5;0;5;5;0;5;0;0;5;5;0;0;5;0;0;0;5;5;0;0;0;5;5;5;5;5;5;0;0;5;5;0;0;5;0;0;5;5;5;0;5;0;5;0;5;5;0;0;5;0 +5;5;0;5;5;5;0;5;5;5;0;0;0;0;5;5;0;0;0;5;0;5;5;5;0;5;5;5;5;5;0;5;5;0;0;0;5;5;5;0;0;0;0;5;0;0;0;5;5;0;0;0;0;0;0;0;5;5;0;0;5;0;0;0;5;5;0;5;0;0;5;5;5;5;5;0;0;0;0;0;0;0;5;5;0;5;5;5;0;0;0;5;5;5;5;5;0;0;5;5 +0;5;5;0;5;5;0;0;0;5;5;0;0;0;5;5;5;0;0;0;5;0;5;0;0;5;0;0;5;5;5;5;0;5;0;5;0;5;5;5;5;5;0;0;0;5;5;0;5;0;5;5;5;5;5;0;5;5;0;5;0;5;5;5;0;5;0;0;0;0;0;0;0;5;5;5;5;5;0;5;5;5;5;0;0;0;0;0;0;5;0;0;0;5;0;0;0;0;5;5 +0;5;5;0;5;5;0;5;0;5;0;0;5;5;0;5;0;5;0;5;0;0;5;5;5;0;0;5;0;5;5;0;5;5;0;0;0;5;0;5;5;0;5;0;5;0;0;5;0;0;5;5;0;0;0;0;5;5;0;5;5;0;5;0;5;5;0;5;0;0;5;5;5;5;5;0;0;5;0;5;5;5;5;0;5;5;0;0;0;5;5;5;5;5;5;0;5;5;0;5 +5;5;5;5;5;5;5;5;0;0;5;0;0;0;0;5;0;0;5;5;5;5;5;0;0;5;0;5;0;5;5;0;5;5;5;0;0;0;5;0;0;0;5;5;0;0;5;0;0;0;5;5;5;5;5;0;0;5;0;0;0;5;5;0;5;5;5;5;0;0;0;0;5;5;0;5;5;5;0;5;5;0;0;0;5;0;0;0;0;5;0;0;0;0;5;5;0;0;5;0 +0;0;0;5;0;0;0;0;0;5;0;5;0;5;5;5;0;0;0;5;5;5;5;0;5;0;0;5;5;0;0;5;5;5;5;0;5;5;5;0;5;0;5;0;0;0;0;0;5;0;0;0;5;0;5;5;0;0;5;5;5;5;5;0;0;5;5;5;5;0;5;5;0;5;0;5;5;5;0;0;0;5;0;5;0;5;5;5;5;5;5;5;0;0;5;5;0;5;0;5 +5;0;0;5;5;5;5;0;5;0;5;5;0;0;0;0;5;0;0;5;5;5;5;0;0;0;5;0;5;5;0;5;0;0;0;0;5;0;0;0;0;0;0;5;0;0;5;0;5;0;5;0;5;5;0;5;0;0;0;5;0;0;0;0;0;0;5;5;0;5;5;5;0;5;5;0;0;0;5;5;5;5;0;0;5;5;0;0;5;0;5;5;5;5;5;5;0;5;5;0 +5;0;0;0;5;0;5;0;5;5;5;5;0;0;5;5;5;5;0;5;5;5;5;5;0;0;5;0;5;0;0;0;5;5;0;0;0;0;5;5;0;0;5;0;5;5;5;0;5;5;0;0;5;0;0;5;0;5;5;5;5;0;5;0;0;0;0;0;0;5;5;5;0;5;5;0;5;5;5;0;5;5;5;0;0;5;0;0;0;5;0;0;0;5;0;0;5;5;5;0 +5;0;5;0;0;5;0;0;0;0;0;5;5;0;0;5;0;0;0;5;0;0;5;0;5;0;0;5;5;0;5;5;0;0;0;5;5;5;5;5;0;5;5;5;0;0;0;0;5;5;5;0;0;5;5;5;5;5;0;0;0;5;0;5;0;0;5;0;5;5;5;0;0;5;5;0;0;5;0;0;0;5;0;0;0;5;0;0;5;0;5;5;5;0;5;0;5;0;5;5 +5;0;5;5;5;5;5;5;0;0;0;0;0;0;0;5;0;0;5;0;5;0;5;0;5;5;5;5;5;5;5;5;0;0;5;5;0;5;0;5;5;0;0;5;5;0;5;5;5;0;5;0;0;5;0;0;5;0;5;5;0;5;5;5;0;0;5;0;5;0;0;0;0;5;0;5;5;5;0;5;5;0;5;0;0;0;5;0;5;0;5;0;5;0;0;0;0;5;5;5 +5;5;0;5;5;5;0;0;5;0;0;5;0;5;0;0;5;0;5;0;0;5;0;5;5;0;0;5;0;5;0;5;0;0;5;5;5;0;5;5;5;5;0;5;5;0;5;5;0;0;5;5;0;0;0;0;5;0;0;0;0;5;5;0;5;0;5;0;0;0;0;0;5;0;5;0;5;5;5;5;0;0;0;5;0;5;0;0;0;5;5;5;0;5;0;0;0;5;0;0 +0;5;0;0;0;5;0;5;0;5;5;0;5;0;0;5;5;5;0;5;5;0;0;5;0;5;5;0;0;5;0;5;0;5;0;0;0;5;5;0;0;5;0;0;5;0;5;0;0;0;0;5;5;0;0;5;0;5;5;5;5;5;0;0;0;0;0;5;0;0;5;0;0;5;0;5;0;5;5;5;0;0;5;5;0;0;5;0;0;5;5;0;0;0;0;0;5;5;5;5 +0;5;0;5;0;5;5;0;0;5;0;0;5;5;0;5;0;5;0;5;0;5;0;0;0;5;5;5;0;5;0;5;0;5;0;5;5;5;5;5;5;5;5;0;0;5;0;0;5;0;5;0;0;0;5;0;0;0;0;0;0;0;5;5;0;5;5;5;0;5;5;5;0;5;0;5;0;0;0;0;0;0;0;5;5;5;5;0;5;5;0;0;0;5;0;0;5;0;5;5 +0;0;5;0;0;0;0;0;0;0;0;5;0;5;0;0;0;5;0;0;0;5;5;5;0;5;5;5;0;5;5;0;0;5;0;5;5;5;0;5;5;5;5;0;0;0;5;0;5;5;5;0;5;0;0;0;0;0;0;5;5;0;5;0;5;5;5;5;5;0;5;5;0;5;0;5;0;5;0;0;5;0;5;0;0;0;0;5;0;0;0;0;5;5;5;0;5;5;5;0 +5;5;0;5;5;5;0;0;0;5;0;0;5;5;5;5;5;5;0;0;0;0;0;0;5;5;5;0;5;5;0;0;0;0;0;5;5;0;0;5;0;0;5;5;0;5;5;5;5;5;0;5;5;0;5;5;5;5;5;5;0;5;0;5;5;0;0;5;0;0;0;5;5;0;5;0;0;0;5;0;0;5;0;0;0;5;0;5;0;0;5;5;5;0;0;0;5;0;5;5 +0;5;0;5;0;5;0;0;5;0;5;0;5;5;5;5;5;0;0;0;0;0;0;5;5;0;0;0;5;0;5;0;5;0;5;0;5;0;5;5;0;5;5;5;0;5;5;5;0;0;0;0;0;5;0;0;0;5;5;0;0;5;0;0;0;0;5;5;5;5;0;5;0;0;0;5;5;5;0;5;5;0;0;0;5;0;0;0;5;5;0;5;0;0;0;0;5;0;5;5 +5;0;5;0;0;5;5;5;0;0;5;5;5;0;0;0;5;0;0;5;0;5;0;0;5;0;5;5;0;0;5;0;0;5;0;0;0;5;5;0;5;5;5;5;5;5;5;5;5;0;0;0;0;5;5;0;0;5;5;0;0;0;0;5;0;5;5;0;0;0;5;0;5;0;5;5;5;0;0;5;0;5;5;0;0;0;0;5;5;0;5;0;0;0;5;0;5;5;0;5 +0;5;5;0;5;5;5;0;0;5;0;0;5;5;5;5;0;5;0;5;5;5;0;5;0;0;5;0;5;5;0;5;5;0;0;0;0;0;0;0;5;5;0;0;0;5;5;0;5;5;5;0;5;5;5;0;5;0;5;0;0;5;5;5;5;0;0;5;0;5;0;0;5;5;0;5;0;5;5;5;0;5;5;5;0;0;5;5;5;5;0;0;5;5;5;5;0;5;5;5 +0;5;0;5;5;5;5;0;0;5;0;0;0;0;0;5;0;0;0;5;5;5;5;0;5;5;0;5;0;5;5;5;5;0;0;5;5;0;5;0;0;5;0;0;0;5;5;0;5;0;0;0;0;5;5;5;0;0;0;0;5;5;0;5;0;0;5;5;5;5;0;5;0;0;0;5;0;0;5;0;0;0;0;0;0;0;5;5;0;5;5;0;5;0;0;0;0;5;0;0 +0;0;0;5;5;5;5;0;0;0;5;5;0;5;5;5;0;5;5;0;5;0;0;5;5;0;0;5;0;0;0;5;5;5;5;0;0;5;5;0;5;0;5;0;5;0;0;0;0;5;0;0;5;0;5;5;5;0;0;5;0;0;0;0;0;5;0;0;0;5;5;0;5;5;0;0;5;0;0;5;0;0;5;5;5;0;0;5;0;0;5;5;0;5;5;5;0;0;5;0 +5;5;5;0;0;5;5;0;0;0;0;0;5;0;0;0;5;5;0;0;0;0;5;5;5;5;5;0;5;5;0;5;5;5;0;5;5;0;0;0;0;5;5;5;0;5;0;0;5;5;0;0;5;0;5;0;0;5;0;0;5;0;0;0;5;0;0;5;5;5;0;0;5;0;0;5;5;0;0;0;5;5;0;0;0;0;5;0;5;5;5;0;0;5;5;5;0;5;0;5 +0;0;0;5;0;0;5;0;5;5;5;0;0;5;5;5;0;0;0;0;5;5;5;0;5;0;5;5;5;0;0;0;0;5;5;5;5;5;0;0;0;0;5;0;0;0;5;0;0;5;0;5;5;0;0;5;0;0;5;5;5;0;0;5;5;5;0;0;0;0;0;0;0;0;5;0;0;5;0;0;0;5;0;0;5;0;5;5;0;5;5;0;0;0;5;0;0;0;5;0 +5;5;5;0;0;0;5;0;0;5;0;5;5;0;5;5;0;0;5;0;5;0;5;5;5;0;0;5;0;0;5;5;5;0;0;0;5;0;0;0;5;5;0;5;0;5;5;0;5;0;0;0;5;5;5;0;0;0;0;5;0;0;0;5;0;5;5;5;0;5;0;5;0;5;0;0;5;5;5;5;5;0;5;0;0;5;5;5;5;0;0;0;0;0;5;5;0;0;5;5 +0;5;5;0;5;0;0;5;5;0;5;5;5;0;0;0;0;0;5;5;5;5;5;5;0;5;0;0;0;0;0;0;5;0;0;0;5;5;0;0;0;5;0;0;5;5;0;0;5;5;0;0;5;0;5;5;5;0;0;5;0;0;5;5;5;5;0;5;5;5;0;5;0;0;0;5;5;5;0;0;5;0;5;5;5;0;5;5;0;5;5;5;5;5;0;5;5;5;5;0 +0;0;5;5;0;0;0;5;5;5;5;5;5;0;5;5;5;0;0;5;5;5;0;0;0;0;5;5;5;0;5;5;5;0;0;0;5;5;0;0;0;0;5;5;5;0;0;5;5;0;5;0;0;5;0;0;0;5;5;0;0;5;5;0;0;0;0;5;5;5;0;0;0;5;5;0;0;5;5;0;0;5;5;0;0;5;5;5;0;5;5;0;0;5;0;0;0;5;5;0 +5;0;0;0;0;0;0;0;5;5;0;0;5;5;0;0;0;0;0;5;5;0;5;0;5;0;5;0;0;0;5;0;5;0;0;5;5;0;0;0;0;5;5;5;0;5;5;0;0;5;5;0;5;5;5;5;0;0;5;0;0;5;5;5;0;5;5;5;0;0;0;0;5;0;0;0;0;0;0;0;0;0;5;0;5;0;5;5;0;0;0;5;0;0;5;0;0;5;5;0 +0;0;5;0;0;5;5;5;0;0;0;0;5;5;5;5;0;5;5;0;0;0;0;5;5;5;5;5;5;0;0;0;5;5;5;5;0;0;0;0;5;5;0;5;0;0;5;0;0;5;5;5;5;5;5;5;0;0;0;0;5;5;5;5;5;5;5;0;5;5;5;0;5;5;0;0;0;0;0;5;0;5;5;0;5;5;5;5;0;0;0;0;5;0;0;0;5;0;5;0 +0;5;5;5;5;5;0;5;5;0;5;0;5;5;0;5;0;5;0;5;5;5;0;5;5;5;0;0;0;0;0;5;5;5;0;5;0;5;5;0;5;0;5;5;0;5;0;0;0;0;5;0;0;0;0;5;0;5;0;5;5;5;5;5;5;5;0;5;0;0;5;5;5;0;0;5;0;5;5;5;0;0;0;5;5;5;5;0;5;5;0;0;5;0;5;0;5;0;5;0 +0;5;0;0;5;5;0;0;0;0;5;5;5;0;5;0;5;5;0;0;5;5;0;5;0;5;5;0;0;5;0;5;5;5;0;0;0;5;5;0;0;0;5;5;5;5;0;5;0;0;0;5;0;5;5;5;5;0;0;5;0;5;5;5;5;5;0;0;5;5;0;5;5;5;0;0;0;5;0;0;0;0;5;0;0;0;0;0;0;5;5;5;0;5;5;0;0;5;0;5 +0;5;5;5;0;0;0;5;5;0;5;5;0;5;5;0;0;5;0;5;0;0;5;0;5;5;0;0;0;0;0;0;0;5;5;0;5;0;0;5;5;5;5;0;5;5;5;0;0;0;5;5;0;5;0;0;0;5;0;0;0;0;5;5;0;0;5;5;0;5;5;0;0;0;0;5;0;5;5;5;5;0;0;5;5;5;0;0;0;5;5;5;5;0;5;0;0;0;5;0 +5;0;0;5;5;5;0;0;5;5;0;5;0;0;0;5;0;5;0;5;5;5;5;5;0;0;5;5;5;5;0;5;5;0;0;0;5;0;0;0;0;5;5;5;5;0;5;0;0;5;5;5;5;0;0;0;5;5;0;5;0;0;0;0;0;5;5;5;0;0;5;0;5;5;5;5;0;0;5;0;5;5;5;0;5;5;5;0;0;5;0;0;5;5;0;0;0;0;5;5 +5;0;5;5;5;0;0;5;0;0;0;0;0;5;0;0;0;5;0;5;0;0;0;5;5;5;5;5;5;0;0;0;0;5;5;0;0;0;0;5;0;5;0;0;0;0;0;0;5;5;0;5;0;0;0;5;0;5;5;5;5;0;0;5;0;0;5;0;5;0;5;0;0;5;0;0;0;5;0;5;5;5;0;5;5;5;0;5;5;0;5;5;0;0;5;5;5;5;5;0 +5;0;5;5;0;5;5;0;0;5;0;5;0;0;5;0;5;5;5;0;5;0;0;0;5;0;5;5;5;0;5;0;0;5;5;5;5;0;0;5;0;0;0;0;5;5;0;0;0;0;0;0;0;5;5;5;0;0;5;5;5;0;5;0;5;0;5;5;5;5;0;0;5;5;0;0;5;5;5;5;0;0;0;5;5;0;5;0;5;5;5;0;5;5;5;5;5;0;5;5 +0;5;5;0;0;5;5;0;0;5;5;5;5;5;0;0;0;5;0;0;5;0;5;5;5;0;5;5;0;0;0;0;0;5;5;5;0;5;0;5;0;5;5;5;5;5;5;0;0;5;5;5;5;0;0;0;5;5;5;0;0;0;0;5;0;0;0;5;5;5;0;5;0;5;5;5;5;5;0;5;0;5;0;5;5;5;5;0;5;5;0;5;0;5;5;5;0;0;5;0 +5;0;0;0;0;5;0;5;5;0;5;0;5;5;0;5;5;0;0;0;5;0;0;5;5;0;5;5;0;0;5;5;5;0;5;5;5;5;0;5;5;0;0;0;0;0;5;0;5;5;0;0;0;0;0;5;5;5;0;5;0;5;5;5;5;5;5;0;5;0;0;0;5;0;5;5;0;5;5;0;0;5;0;5;0;0;5;5;5;0;5;5;5;5;5;5;0;5;0;5 +5;0;5;0;5;5;0;5;0;5;0;0;5;5;5;5;0;0;5;5;5;5;5;5;5;5;5;0;5;0;0;0;0;5;5;0;0;5;5;0;0;5;5;0;5;5;0;5;0;0;5;5;0;5;5;5;0;5;5;0;5;5;5;5;5;0;5;5;5;0;5;0;5;0;0;0;0;0;5;5;0;5;5;5;5;5;0;5;0;5;5;0;5;5;5;0;0;5;5;5 +0;0;0;0;5;5;0;0;0;5;0;5;0;5;5;0;0;0;5;0;0;0;5;5;5;5;5;0;5;0;0;5;5;5;5;5;5;5;5;5;0;0;0;5;5;0;5;5;5;0;5;0;0;0;5;0;0;0;0;0;0;0;5;5;0;5;5;0;0;5;5;5;0;0;5;5;5;0;5;5;0;0;0;5;5;5;0;0;5;0;0;0;5;0;0;0;5;5;5;0 +0;0;5;0;5;0;5;0;0;5;0;5;5;0;5;5;5;0;0;0;0;5;5;5;0;0;5;5;5;5;5;0;5;0;0;5;0;5;0;5;5;0;5;0;0;5;5;0;5;0;0;5;5;0;0;0;5;0;0;0;0;0;0;0;0;0;0;5;5;5;0;0;5;0;0;5;0;0;5;0;0;0;0;0;5;0;5;0;5;5;5;5;0;5;5;0;5;0;5;5 +0;5;5;0;0;0;0;5;0;5;5;5;5;5;5;5;0;5;5;0;5;5;0;5;5;5;0;0;0;5;5;0;0;5;0;0;5;5;5;5;0;0;0;5;0;5;5;0;0;0;0;5;5;0;0;5;0;0;5;0;0;5;0;5;5;0;5;0;0;0;5;5;5;5;5;5;0;0;0;5;5;5;0;0;5;0;0;0;5;0;0;0;5;0;5;0;5;5;0;5 +0;0;5;5;5;5;0;0;5;5;5;0;5;0;0;5;0;0;0;0;5;5;5;0;0;0;5;0;5;5;0;0;0;0;0;0;0;0;0;0;0;5;0;5;0;5;5;5;5;5;5;0;5;5;0;5;5;5;0;0;5;0;0;5;0;0;0;0;5;0;0;0;0;0;5;0;5;0;0;5;0;0;0;5;5;0;0;5;5;0;5;0;5;0;0;0;5;0;0;5 +5;5;5;0;0;0;0;5;0;5;0;5;0;5;0;5;5;5;0;0;5;0;5;0;0;0;0;0;0;5;0;0;0;5;5;0;0;0;0;5;0;5;5;5;0;0;5;0;5;0;5;0;5;0;0;5;0;5;5;5;0;0;5;5;5;0;0;0;5;5;5;5;0;5;5;5;5;5;5;5;5;0;5;0;0;5;5;5;5;0;5;0;5;0;5;5;5;5;0;0 +0;0;5;5;5;0;5;0;5;5;0;5;0;0;5;5;0;5;0;5;0;5;0;0;5;5;0;5;0;5;0;0;0;0;5;0;0;0;5;0;0;0;0;0;5;5;5;5;0;0;5;5;0;0;0;5;5;0;0;5;5;5;5;0;0;0;0;0;5;5;5;5;0;0;0;0;5;0;0;5;5;0;5;0;5;5;0;5;0;0;0;5;0;0;5;5;0;0;0;5 +5;0;0;0;5;0;5;5;0;0;0;5;5;0;5;5;0;0;0;5;0;5;5;0;5;0;5;5;0;0;0;0;5;0;0;0;0;0;0;0;0;0;5;0;0;0;5;5;0;5;0;0;0;0;0;5;5;0;0;5;5;0;0;5;5;5;0;0;0;5;0;0;0;0;5;0;0;5;5;5;5;0;0;5;5;5;0;0;0;5;0;0;5;5;5;5;0;5;5;0 +5;0;0;5;0;5;5;0;5;5;5;5;0;5;5;0;5;0;5;5;0;5;0;0;0;5;5;0;5;0;0;0;0;5;0;0;5;0;0;0;5;0;5;0;5;0;5;5;5;5;5;5;5;5;5;5;5;5;5;5;5;5;5;5;5;0;5;5;0;5;0;0;5;5;0;5;0;0;0;5;0;0;0;5;0;5;0;5;5;5;5;0;0;0;0;5;0;5;5;0 +0;5;5;5;0;5;5;5;0;5;0;5;0;0;0;5;5;5;0;5;0;0;5;0;0;5;5;0;0;5;0;5;0;5;0;5;0;0;5;5;5;0;5;0;0;5;0;0;0;0;5;0;5;0;5;0;5;5;5;0;5;0;5;5;0;0;5;5;0;5;0;0;0;0;0;0;5;0;0;5;5;0;5;0;0;5;0;0;5;0;0;5;0;0;5;0;0;5;0;0 +5;5;5;0;0;5;5;5;0;5;0;0;5;0;0;5;5;0;0;0;5;5;5;5;0;5;5;0;5;5;0;0;0;5;0;5;0;0;0;0;5;5;0;0;0;0;5;0;5;5;5;5;5;5;0;5;5;5;0;0;5;0;0;0;0;0;0;5;0;0;0;5;0;5;5;5;0;5;5;0;0;0;5;5;0;5;5;0;0;5;5;5;5;0;0;5;5;5;5;5 +5;0;5;5;0;0;5;0;5;0;0;0;0;0;5;5;0;0;5;0;0;5;5;0;5;5;5;5;5;5;0;0;5;0;0;0;0;0;5;5;5;5;5;5;5;0;5;0;0;5;0;0;5;0;5;5;5;5;0;5;5;5;0;0;0;0;0;5;0;0;5;5;5;0;5;0;5;5;0;0;0;5;5;0;0;0;0;5;0;0;5;5;5;5;5;0;5;5;0;5 +0;0;5;5;5;0;5;0;5;5;5;0;0;5;5;0;0;0;5;5;0;5;5;0;0;0;5;5;5;5;0;5;5;0;0;5;5;5;0;5;5;0;0;0;0;5;0;5;0;5;5;0;5;0;5;5;5;5;0;5;0;5;0;5;0;5;0;5;5;5;0;5;0;0;0;5;0;0;5;5;0;5;0;0;5;5;0;0;0;5;5;5;5;0;5;5;0;5;0;5 +0;0;5;5;0;5;0;5;5;5;0;5;0;0;0;0;0;5;5;0;5;5;5;0;0;5;5;0;0;0;0;0;5;5;5;0;5;0;0;0;5;5;5;0;5;5;5;0;0;5;0;5;5;5;5;5;5;5;5;5;0;0;5;0;0;5;5;0;0;0;0;5;0;5;5;5;5;0;5;5;5;0;0;5;5;5;5;0;5;0;0;0;5;0;0;0;5;0;5;5 +0;5;5;0;5;5;5;5;5;0;0;5;5;5;0;0;5;0;5;0;0;0;5;0;0;5;5;0;5;0;5;5;5;0;0;5;0;5;0;0;0;5;0;5;5;0;0;0;5;0;0;0;0;0;0;5;5;5;0;0;0;5;5;5;5;0;0;0;0;5;5;0;5;5;5;0;5;0;5;0;0;5;5;5;5;5;0;5;5;5;5;0;0;0;0;0;5;0;5;5 +0;5;5;0;0;5;0;0;5;5;5;5;0;5;5;0;5;5;5;0;5;5;5;5;0;5;5;0;5;0;0;5;5;0;5;5;0;5;5;0;0;5;5;5;5;5;0;0;0;0;0;0;0;5;0;0;5;5;5;5;0;5;0;0;0;0;0;5;5;5;5;0;5;5;5;5;5;5;0;0;5;0;5;0;0;5;5;0;5;0;0;0;0;5;5;5;0;0;5;0 +5;0;0;5;0;0;5;0;0;0;5;0;5;5;5;0;5;0;5;5;0;5;5;0;0;5;0;5;0;0;5;5;5;5;0;5;0;0;5;0;5;0;0;5;5;0;0;0;5;5;5;0;0;0;0;0;0;5;5;5;0;0;5;5;5;5;0;5;0;5;0;5;5;5;0;0;0;0;0;0;5;0;5;5;5;0;0;5;0;0;0;0;0;5;0;0;0;5;0;5 +5;5;5;0;5;0;5;5;0;5;0;5;5;5;0;5;0;5;5;0;5;0;5;0;0;5;0;0;0;5;5;0;5;5;0;5;5;0;5;5;0;5;0;5;0;0;5;5;5;0;5;0;5;5;5;5;0;5;5;0;5;0;0;5;0;5;5;0;5;5;5;0;5;5;5;5;5;5;0;5;5;0;0;5;5;5;5;5;5;0;5;5;5;0;5;0;5;5;0;0 +0;5;0;5;5;5;0;0;0;5;0;5;5;0;5;0;5;0;0;0;0;0;0;5;0;0;0;5;0;5;5;0;0;0;0;0;5;0;5;5;0;0;5;0;5;0;0;5;0;5;5;0;5;5;0;5;0;0;0;0;0;0;5;0;0;5;5;0;0;5;0;5;5;0;0;0;5;0;0;5;5;0;0;5;5;5;5;5;0;5;0;0;0;0;0;0;0;5;5;0 +0;5;0;0;5;0;0;5;0;5;5;0;5;0;5;0;5;0;0;5;0;0;5;0;0;0;0;5;0;5;0;5;5;0;0;0;0;0;5;0;0;5;5;5;0;0;5;5;0;0;5;5;0;0;0;5;5;5;5;0;0;5;5;0;5;5;5;0;0;5;0;0;5;5;5;5;5;5;5;5;0;5;0;5;5;5;0;5;5;5;0;5;0;0;0;5;5;5;0;0 +5;5;5;0;5;5;0;0;5;5;0;0;5;0;0;0;5;5;0;0;5;0;5;5;5;0;5;0;0;5;0;0;0;0;0;5;0;5;5;5;0;0;0;5;0;0;5;5;5;5;5;5;0;0;5;5;0;5;0;5;5;0;5;5;5;0;5;5;5;0;0;5;0;5;5;0;0;0;5;0;5;0;0;5;5;5;0;0;5;0;0;0;0;5;0;5;5;0;0;0 +5;5;0;5;5;5;5;5;0;0;5;5;5;0;0;0;0;0;5;0;5;5;5;0;5;0;0;5;0;0;5;5;0;5;5;0;0;0;5;0;0;5;0;0;0;5;5;5;5;5;5;0;5;5;5;0;5;5;5;5;0;5;0;0;5;5;0;0;5;0;5;5;5;0;0;5;5;5;5;0;0;5;0;5;0;5;5;5;0;0;5;5;5;5;0;5;0;0;5;5 +0;5;5;5;0;5;5;0;0;5;0;5;5;0;0;0;0;0;5;5;0;5;0;0;0;5;0;5;0;5;5;0;5;0;0;5;0;5;5;5;0;0;5;0;0;0;0;5;0;0;5;5;0;0;0;5;0;5;0;5;5;5;0;0;0;5;5;0;5;5;0;5;5;5;0;0;0;5;5;0;0;5;5;5;0;0;5;5;5;5;5;5;0;5;5;5;0;0;0;0 +5;5;5;5;5;5;5;5;0;0;5;0;5;0;0;0;0;5;5;5;5;0;0;0;0;0;5;0;0;5;5;0;5;5;0;5;0;5;0;5;5;0;5;0;0;5;5;5;0;5;0;5;5;0;5;5;5;0;5;0;5;0;5;5;5;0;0;5;5;0;0;5;0;0;5;0;5;5;5;5;0;5;5;5;0;0;0;5;0;0;0;0;0;5;5;0;5;0;5;5 +0;5;5;0;5;5;0;5;0;0;0;0;5;0;5;0;0;5;0;5;0;0;5;5;5;0;5;5;0;5;0;0;5;5;0;5;5;0;0;5;0;5;5;0;5;5;0;0;0;5;5;5;5;5;5;5;5;0;5;5;5;5;0;0;5;0;5;0;5;0;5;0;0;5;5;0;5;0;5;5;0;0;0;0;0;0;0;5;5;0;0;5;5;0;5;0;5;0;5;0 +0;0;0;5;5;0;5;0;5;5;0;5;5;0;5;5;0;5;5;5;5;5;0;5;0;5;0;0;5;0;0;5;0;5;5;0;0;0;0;0;0;5;0;5;5;5;0;0;0;0;5;0;0;0;0;5;5;5;5;0;5;5;0;0;5;0;0;5;5;0;5;0;0;0;0;5;0;0;0;0;0;5;0;0;0;5;5;5;5;5;0;5;0;0;0;0;0;5;5;0 +5;5;0;0;5;5;5;0;5;5;5;5;5;5;0;0;5;0;5;0;0;5;0;0;5;5;0;5;5;5;0;5;5;0;5;5;0;5;5;5;0;5;0;0;0;0;5;5;0;5;0;5;0;0;0;5;0;5;5;0;0;5;0;5;0;5;0;5;0;0;5;0;0;5;5;0;5;0;0;5;0;5;0;5;5;0;5;5;5;0;0;5;5;5;0;5;5;0;0;0 +5;5;0;0;5;5;5;5;0;5;5;0;0;0;5;5;5;5;5;5;5;0;0;0;0;0;0;5;5;5;5;0;0;0;5;0;5;0;5;5;5;0;0;5;0;0;5;0;5;5;0;5;0;0;0;0;0;5;5;5;0;5;5;0;5;0;5;0;0;0;5;0;5;0;5;0;0;0;0;5;0;0;0;0;5;0;5;0;5;0;5;5;5;0;0;0;0;0;0;5 +0;5;5;0;0;5;5;5;5;5;5;0;5;5;5;0;0;0;0;5;5;0;5;5;0;0;5;0;5;5;0;5;5;5;5;5;0;0;5;0;5;5;0;0;0;0;5;0;0;0;0;0;5;0;5;0;5;5;0;0;5;5;0;5;0;5;5;5;5;0;0;5;0;5;5;0;5;0;0;0;5;5;0;5;0;0;0;5;5;5;5;0;5;5;0;0;0;5;0;0 +5;5;5;5;5;0;0;5;5;5;0;0;0;5;0;0;5;5;0;0;0;0;5;0;5;5;0;0;0;0;5;0;5;5;5;0;5;0;5;0;5;5;0;5;0;0;5;0;5;5;0;0;5;0;5;5;0;0;5;5;0;5;5;5;0;5;5;0;0;5;0;0;0;5;5;5;0;5;0;5;0;5;0;5;0;0;0;5;5;0;0;5;0;5;0;5;0;5;0;0 +5;0;0;0;5;0;5;5;5;5;5;5;5;5;5;0;0;5;5;0;5;5;0;0;0;5;0;5;5;5;0;5;5;5;5;0;5;5;5;5;5;5;5;0;0;0;5;5;0;0;0;0;0;0;0;5;5;0;0;0;0;5;0;5;5;5;0;5;5;0;5;5;0;0;0;5;5;5;0;0;5;0;5;5;0;0;5;0;0;0;5;5;5;5;0;0;0;0;5;0 +5;0;5;5;0;0;0;0;5;5;0;5;5;5;0;5;0;5;0;0;0;5;0;0;5;5;5;0;5;0;5;5;5;5;5;5;5;0;0;0;5;0;5;5;5;5;5;5;5;5;0;0;5;0;0;0;0;0;5;5;0;5;0;0;0;5;0;0;0;0;0;0;5;0;5;5;5;0;0;5;5;0;0;0;5;0;5;5;5;0;0;0;5;0;5;0;0;0;5;0 +5;0;0;5;0;0;0;0;0;5;5;5;0;5;0;0;0;0;5;5;0;0;5;0;0;0;0;5;5;5;0;0;0;5;5;0;5;0;5;0;5;0;5;5;5;5;0;5;5;0;0;5;5;5;5;5;5;0;5;5;0;5;5;5;5;0;0;5;0;0;5;5;0;5;0;5;5;0;0;0;5;5;0;5;0;0;5;5;5;5;5;5;5;5;0;0;5;0;0;5 +5;0;0;5;5;0;5;5;5;5;5;5;5;5;5;0;5;0;0;5;0;0;5;5;0;0;5;5;0;5;5;5;0;5;5;0;0;5;0;5;5;0;5;0;0;0;5;0;5;0;0;0;0;0;5;0;0;0;0;5;0;5;5;0;0;0;5;5;0;0;0;0;5;5;0;5;0;0;5;0;0;5;0;0;0;0;5;5;5;5;0;0;0;5;5;5;5;0;5;0 +0;5;5;0;0;5;5;5;5;0;0;0;5;5;5;5;5;0;5;5;5;5;5;0;0;0;5;5;0;0;5;0;0;5;0;0;0;0;0;0;0;0;5;0;5;0;0;0;0;5;0;0;0;5;0;5;5;0;0;0;5;5;5;5;5;0;0;5;0;5;0;0;5;5;0;0;5;5;0;0;0;5;5;5;0;0;5;0;0;5;5;0;5;0;5;0;0;0;0;0 +5;5;0;5;0;5;5;5;0;0;0;5;0;5;0;0;0;5;5;0;5;0;5;5;5;5;0;0;5;0;5;0;5;5;5;0;5;0;5;0;0;5;5;5;0;0;5;5;5;0;5;5;5;0;0;0;5;0;0;0;5;5;5;5;5;0;0;5;5;0;5;5;0;0;0;5;0;5;0;5;0;0;5;5;5;5;0;0;0;5;5;5;5;5;0;0;5;5;0;0 +5;5;5;0;5;0;0;0;5;0;5;0;0;0;0;5;5;0;5;0;0;0;5;0;0;0;0;0;5;5;0;5;5;5;5;5;5;0;0;5;5;5;0;0;5;5;5;0;5;0;0;5;5;0;5;5;0;5;5;5;0;5;5;0;0;0;0;0;0;0;5;5;0;5;5;0;5;0;0;0;5;5;0;0;0;0;5;0;5;0;0;5;0;0;5;0;5;0;0;0 +5;5;0;0;0;5;5;0;0;0;0;0;5;0;5;0;5;5;0;0;5;5;0;0;5;0;0;5;0;5;5;5;5;5;0;0;5;0;0;0;5;5;0;0;0;0;0;0;5;5;5;0;5;0;0;5;0;0;0;5;5;0;0;0;5;5;0;0;5;5;0;5;5;5;0;0;0;5;0;5;5;0;0;5;0;0;5;0;5;0;5;5;5;5;5;0;0;5;0;5 +0;5;0;0;5;5;0;5;0;0;5;0;5;5;0;0;5;5;5;0;0;5;0;0;5;5;5;0;5;5;5;5;5;5;5;0;0;0;0;5;0;0;5;5;0;5;5;0;0;5;5;0;5;5;5;5;5;5;5;0;5;0;5;0;0;5;5;0;0;0;0;5;5;5;5;0;5;0;5;0;5;5;5;5;5;5;5;0;0;0;5;0;0;0;5;0;0;5;5;5 +5;5;0;5;0;0;0;0;0;0;5;0;0;0;0;0;0;5;5;5;5;0;0;5;5;5;0;5;0;0;0;0;5;5;0;0;5;0;0;0;0;5;0;0;5;0;5;5;0;0;5;0;0;5;0;5;5;5;5;0;0;5;0;5;5;0;0;5;5;5;5;5;5;0;0;5;5;0;5;5;0;0;0;5;0;0;0;0;0;0;5;5;5;0;0;0;5;0;0;0 +0;0;0;0;5;5;5;0;5;5;0;5;0;5;5;5;0;0;0;0;0;5;5;0;5;5;0;0;5;0;5;0;5;0;5;0;0;0;5;0;5;5;0;0;0;5;0;5;0;5;0;0;0;5;5;5;5;5;5;5;0;5;5;5;0;0;5;0;5;5;5;5;0;0;5;5;5;0;5;5;0;5;5;5;0;0;0;5;5;0;0;5;0;0;0;5;0;0;0;5 +0;5;5;0;0;5;5;0;0;5;0;5;5;0;0;5;0;0;5;5;0;0;5;0;0;5;5;0;5;0;0;0;5;0;5;5;5;5;5;5;5;0;5;5;5;0;5;5;0;0;5;5;5;5;0;5;0;5;5;0;0;0;5;5;5;5;0;5;0;0;5;5;0;5;0;5;5;5;5;0;0;0;0;5;5;5;0;5;0;0;5;5;0;5;5;5;0;0;5;5 +5;0;5;0;5;5;0;0;0;0;0;5;0;0;0;0;5;0;0;0;5;5;0;0;0;0;5;5;0;0;0;0;5;5;0;0;5;5;5;5;0;0;5;5;0;0;5;5;0;0;5;5;0;0;0;0;5;0;0;5;0;5;5;0;5;0;5;5;5;0;0;0;5;0;0;5;5;0;5;0;5;5;5;5;5;0;0;5;5;5;5;5;5;5;5;5;0;0;0;0 +0;5;5;0;5;5;5;5;0;5;0;0;0;5;5;0;0;0;0;5;0;0;0;5;0;5;0;0;0;5;0;0;0;5;5;0;0;5;5;0;5;0;0;5;5;0;5;5;5;0;5;0;0;5;0;0;5;5;0;5;5;5;0;0;5;5;5;0;0;5;0;5;5;5;0;5;5;0;5;5;0;5;0;0;0;0;0;0;5;5;0;0;5;5;5;5;0;5;0;5 +0;5;5;0;5;0;0;0;5;0;0;0;0;5;5;0;0;5;0;0;5;0;0;5;0;5;0;5;0;5;0;5;0;5;5;0;0;0;0;5;0;5;5;5;5;5;0;0;0;5;5;0;5;0;0;0;5;0;0;5;0;5;5;0;5;0;5;5;0;5;5;0;0;0;0;0;5;0;5;0;0;0;0;0;5;5;0;0;5;5;5;0;0;0;0;0;5;5;5;5 +0;0;0;5;0;0;0;0;0;0;0;5;5;0;0;0;5;5;0;0;5;5;0;0;0;5;0;0;0;0;0;5;5;5;5;5;5;0;0;5;0;5;0;5;5;0;0;0;5;5;0;0;5;5;5;5;5;0;5;5;5;0;5;5;5;5;5;0;5;0;5;5;5;0;5;5;0;5;5;5;0;0;0;5;0;0;0;0;0;0;5;5;5;5;0;0;0;0;5;0 +0;0;0;0;0;0;5;5;5;0;5;5;0;5;5;5;5;0;5;0;0;5;0;0;5;5;5;0;0;5;5;5;0;0;5;0;5;5;5;5;0;5;0;0;5;5;0;0;5;5;5;5;0;0;5;0;0;0;0;0;5;0;5;5;5;0;0;5;5;0;0;0;5;5;0;5;0;0;5;5;0;5;5;0;5;5;5;5;5;5;0;0;0;0;0;0;5;5;5;0 +0;5;5;5;5;0;0;5;0;0;0;0;5;0;0;0;0;0;5;5;0;5;5;0;0;5;5;0;5;0;0;0;0;5;5;5;0;0;0;0;0;0;5;5;5;5;0;0;0;0;5;5;5;5;5;5;5;0;0;5;5;0;0;5;5;0;0;5;0;0;0;0;5;5;0;5;0;0;0;0;5;5;0;0;5;5;5;0;5;0;0;5;5;5;0;5;5;5;5;5 +0;0;0;5;0;0;5;0;5;0;0;5;5;5;0;5;5;5;5;0;0;0;5;5;0;5;0;0;0;5;0;5;5;0;5;5;5;0;0;5;5;5;5;0;5;5;5;0;5;0;0;5;5;0;0;0;5;0;5;5;0;0;5;0;0;0;5;0;0;5;5;0;5;0;0;5;5;5;0;5;0;0;0;5;5;5;0;0;0;5;0;0;5;5;5;0;0;5;0;5 diff --git a/src/backend/Rule.java b/src/backend/Rule.java new file mode 100644 index 0000000..1b6bf12 --- /dev/null +++ b/src/backend/Rule.java @@ -0,0 +1,67 @@ +package backend; + +import java.util.ArrayList; + +public class Rule { + + private int value; + private ArrayList color; + private ArrayList conditionCountNear; + private ArrayList conditionHighestNear; + private int ifValue; + private int elseValue; + + public Rule(int value , ArrayList color, ArrayList conditionCountNear, ArrayList conditionHighestNear, int ifValue, int elseValue) { + this.value = value; + this.color = color; + this.conditionCountNear = conditionCountNear; + this.conditionHighestNear = conditionHighestNear; + this.ifValue = ifValue; + this.elseValue = elseValue; + } + + public int getValue() { + return value; + } + + public ArrayList getColor() { + return color; + } + + public void setColor(ArrayList color) { + this.color = color; + } + + public ArrayList getConditionCountNear() { + return conditionCountNear; + } + + public void setConditionCountNear(ArrayList conditionCountNear) { + this.conditionCountNear = conditionCountNear; + } + + public ArrayList getConditionHighestNear() { + return conditionHighestNear; + } + + public void setConditionHighestNear(ArrayList conditionHighestNear) { + this.conditionHighestNear = conditionHighestNear; + } + + public int getIfValue() { + return ifValue; + } + + public void setIfValue(int ifValue) { + this.ifValue = ifValue; + } + + public int getElseValue() { + return elseValue; + } + + public void setElseValue(int elseValue) { + this.elseValue = elseValue; + } + +} diff --git a/src/backend/Simulator.java b/src/backend/Simulator.java index 7b4ff54..c36f1be 100644 --- a/src/backend/Simulator.java +++ b/src/backend/Simulator.java @@ -1,5 +1,16 @@ package backend; +import java.io.FileNotFoundException; +import java.io.FileReader; +import java.io.IOException; import java.util.ArrayList; +import java.util.List; +import java.util.Scanner; + +//import for json +import org.json.simple.JSONArray; +import org.json.simple.JSONObject; +import org.json.simple.parser.JSONParser; +import org.json.simple.parser.ParseException; import windowInterface.MyInterface; @@ -33,6 +44,11 @@ public class Simulator extends Thread { private Table table; private boolean cellDensityToggle; + //Rules Arraylists + private ArrayList ruleArrayList = new ArrayList(); + private ArrayList> colorArrayList = new ArrayList>(); + + public Simulator(MyInterface mjfParam) { mjf = mjfParam; stopFlag=false; @@ -50,14 +66,12 @@ public class Simulator extends Thread { this.height=LINE_NUM; enableLogs = true; // for debugging purposes table = new Table(height, width, this); - cellDensityToggle=false; + cellDensityToggle=true; //Default rule : Survive always, birth never - for(int i =0; i<9; i++) { - fieldSurviveValues.add(i); - } + loadRule("OOP_F1_Project\\conwayRule.json"); } @@ -70,6 +84,9 @@ public class Simulator extends Thread { //TODO-COMPLETE : replace with proper return return this.height; } + public ArrayList> getColorArrayList() { + return colorArrayList; + } //Should probably stay as is public void run() { @@ -117,7 +134,7 @@ public class Simulator extends Thread { } } //then evolution of the field - // TODO-INPROGRESS : apply game rule to all cells of the field + //TODO-INPROGRESS : apply game rule to all cells of the field this.applyRule(); @@ -170,20 +187,10 @@ public class Simulator extends Thread { int currentCellValue = getCell(x, y); int newCellValue = 0; if(cellDensityToggle) { - if (currentCellValue == -1) { - newCellValue = 0; - } - if (currentCellValue == 0) { - newCellValue = 1; - } - if (currentCellValue == 1) { - newCellValue = 2; - } - if (currentCellValue == 2) { - newCellValue = 3; - } - if (currentCellValue == 3) { - newCellValue = -1; + if (currentCellValue <6) { + newCellValue = currentCellValue +1; + } else { + newCellValue=-1; } } else { if (currentCellValue == 0) { @@ -374,62 +381,119 @@ public class Simulator extends Thread { return null; } - public void loadRule(ArrayList lines) { - if(lines.size()<=0) { - System.out.println("empty rule file"); - return; - } - //TODO-INPROGRESS : remove previous rule (=emptying lists) - fieldSurviveValues = new ArrayList(); - fieldBirthValues = new ArrayList(); - - String surviveLine = lines.get(0); - String birthLine = lines.get(1); - - String[] surviveElements = surviveLine.split(";"); - for(int x=0; x parseCellObject( (JSONObject) cell ) ); + + + } catch (FileNotFoundException e) { + e.printStackTrace(); + } catch (IOException e) { + e.printStackTrace(); + } catch (ParseException e) { + e.printStackTrace(); } + //DEBUG + //printRules(ruleArrayList); + } + + @SuppressWarnings("unchecked") + private void parseCellObject(JSONObject cell) { + // Get cell object within list + JSONObject cellObject = (JSONObject) cell.get("cell"); + + // Get value + int cellValue = ((Long) cellObject.get("value")).intValue(); + System.out.println("cell value rule loaded: " + cellValue); + + // Get color + JSONArray colorValueJsonArray = (JSONArray) cellObject.get("color"); + ArrayList rgbList = new ArrayList<>(); + colorValueJsonArray.forEach(value -> rgbList.add(((Long) value).intValue())); + + // Get Condition Count Near + JSONArray countNearJsonArray = (JSONArray) cellObject.get("conditionCountNear"); + ArrayList conditionCountNearList = new ArrayList<>(); + countNearJsonArray.forEach(value -> conditionCountNearList.add(((Long) value).intValue())); + + // Get Condition Highest Near + JSONArray conditionHighestNearJsonArray = (JSONArray) cellObject.get("conditionHighestNear"); + ArrayList conditionHighestNearList = new ArrayList<>(); + conditionHighestNearJsonArray.forEach(value -> conditionHighestNearList.add(((Long) value).intValue())); + + // Get ifValue + int ifValue = ((Long) cellObject.get("ifValue")).intValue(); + + // Get elseValue + int elseValue = ((Long) cellObject.get("elseValue")).intValue(); + + // Ensure the colorArrayList is large enough + while (colorArrayList.size() <= cellValue) { + colorArrayList.add(new ArrayList<>()); + } + colorArrayList.set(cellValue, rgbList); + + // Ensure the ruleArrayList is large enough + while (ruleArrayList.size() <= cellValue) { + ruleArrayList.add(null); + } + ruleArrayList.set(cellValue, new Rule(cellValue, rgbList, conditionCountNearList, conditionHighestNearList, ifValue, elseValue)); } public void applyRule(){ Table tempTable = new Table(this.height, this.width, this); - for(int x=0; x= width || y < 0 || y >= height) { + // Border cell is outside the grid + continue; + } + } + + int cellValue = this.getCell(x, y).getValue(); + if (cellValue > highest) { + highest = cellValue; + } + } + + return highest; + } //TODO : set agent (x y agent) load an agent to coordinates x,y diff --git a/src/windowInterface/JPanelDraw.java b/src/windowInterface/JPanelDraw.java index 8ea1c24..e1bf255 100644 --- a/src/windowInterface/JPanelDraw.java +++ b/src/windowInterface/JPanelDraw.java @@ -16,6 +16,7 @@ public class JPanelDraw extends JPanel { private static final long serialVersionUID = 1L; private Simulator mySimu; private MyInterface interfaceGlobal; + ArrayList> colorArrayList; public JPanelDraw(MyInterface itf) { super(); @@ -37,6 +38,7 @@ public class JPanelDraw extends JPanel { public void setSimu(Simulator simu) { mySimu = simu; + colorArrayList = mySimu.getColorArrayList(); } @Override @@ -61,20 +63,14 @@ public class JPanelDraw extends JPanel { int cellContent = mySimu.getCell(x,y); if(cellContent == -1) { g.setColor(Color.gray); - } - if(cellContent == 0) { - continue; - } - if(cellContent == 1) { + } else if(cellContent=0) { + int red = colorArrayList.get(cellContent).get(0); + int green = colorArrayList.get(cellContent).get(1); + int blue = colorArrayList.get(cellContent).get(2); + g.setColor(new Color(red,green,blue)); + } else { g.setColor(Color.white); } - if(cellContent == 2) { - g.setColor(Color.yellow); //set collor with rgb value (255,255,0) - //g.setColor(new Color(255,255,0)); - } - if(cellContent == 3) { - g.setColor(Color.red); - } g.fillRect( (int) Math.round(x*cellWidth), (int) Math.round(y*cellHeight), diff --git a/src/windowInterface/MyInterface.java b/src/windowInterface/MyInterface.java index 34c46c0..d58cc85 100644 --- a/src/windowInterface/MyInterface.java +++ b/src/windowInterface/MyInterface.java @@ -19,12 +19,22 @@ import javax.swing.JLabel; import java.awt.event.ActionListener; import java.io.BufferedReader; +import java.io.FileNotFoundException; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.util.ArrayList; import java.awt.event.ActionEvent; +//added imports for loading jsons +import java.io.FileReader; +import java.util.Iterator; +import java.util.Map; +import org.json.simple.JSONArray; +import org.json.simple.JSONObject; +import org.json.simple.parser.*; + + public class MyInterface extends JFrame { private static final long serialVersionUID = -6840815447618468846L; @@ -300,17 +310,13 @@ public class MyInterface extends JFrame { ArrayList stringArray = new ArrayList(); if (fileName.length()>0) { try { - BufferedReader fileContent = new BufferedReader(new FileReader(fileName)); - String line = fileContent.readLine(); - while (line != null) { - stringArray.add(line); - line = fileContent.readLine(); - } - fileContent.close(); + mySimu.loadRule(fileName); + + } catch (Exception e) { e.printStackTrace(); } - mySimu.loadRule(stringArray); + this.repaint(); } }