241 lines
14 KiB
Text
241 lines
14 KiB
Text
Ce document, récemment découvert, est en cours d'investigation.
|
|
Dans l'état actuel des recherches, il apparait déjà qu'il pourrait s'agir d'une écriture jusqu'ici inconnue.
|
|
Le fragment qui nous est parvenu comporte plus de 10000 caractères distincts et semble organisé en lignes dont le sens de lecture reste incertain.
|
|
L'hypothèse d'un texte sacré s'appuie sur la répétition de certains caractères (ex: ';') qui pourraient indiquer le début ou la fin d'incantations répétées (?)
|
|
L'hypothèse (fragile) d'un texte informatique a été émise après identification de quelques éléments 'for' ( ref: ) qui pourraient être des formes d'itérations primitives mais aucune structuration de l'ensemble n'a, jusqu'ici, pu être décelée.
|
|
La datation est en cours.
|
|
|
|
|
|
|
|
package state;
|
|
|
|
import static java.lang.System.out;
|
|
|
|
import org.w3c.dom.Node;
|
|
import org.w3c.dom.NodeList;
|
|
|
|
import init_close.XML_Model_Reader;
|
|
import objects.ObjectsManagerAccess;
|
|
import session.AutomatonType;
|
|
|
|
public class StateManager {
|
|
public static DIMENSION space_dimension; // {ONE, TWO, THREE, ANY} < assigned by XML_Header_RW
|
|
public static PAVAGE pavage; // {SEGMENTS, SQUARES, HEXAGONS, CUBES, TETRAHEDRONS, ERROR}
|
|
// In this constructor, X, Y and Z, the space_dimension, number_of_sites_in_a_cell, the size of the array quiver and other parameters are assigned by XML_Header_RW.
|
|
public StateManager (final Node parameters, final Node initial_state, final Node final_state, final Node space_view_presentation) {
|
|
// The parameters describing the space size and borders are treated here and only here @see also Memory Manager
|
|
StateManager.setSpaceDimensionAndSize (
|
|
Integer.parseInt (parameters.getAttributes().getNamedItem("X").getNodeValue()),
|
|
Integer.parseInt (parameters.getAttributes().getNamedItem("Y").getNodeValue()),
|
|
Integer.parseInt (parameters.getAttributes().getNamedItem("Z").getNodeValue()),
|
|
AutomatonType.getNumberOfsitesPerCell()
|
|
);
|
|
|
|
StateManager.setSpacePavage (parameters.getAttributes().getNamedItem("pavage").getNodeValue());
|
|
|
|
StateManager.setSpaceBorders (
|
|
Boolean.parseBoolean(parameters.getAttributes().getNamedItem("XO").getNodeValue()),
|
|
Boolean.parseBoolean(parameters.getAttributes().getNamedItem("OX").getNodeValue()),
|
|
Boolean.parseBoolean(parameters.getAttributes().getNamedItem("YO").getNodeValue()),
|
|
Boolean.parseBoolean(parameters.getAttributes().getNamedItem("OY").getNodeValue()),
|
|
Boolean.parseBoolean(parameters.getAttributes().getNamedItem("ZO").getNodeValue()),
|
|
Boolean.parseBoolean(parameters.getAttributes().getNamedItem("OZ").getNodeValue())
|
|
);
|
|
|
|
final NodeList particlesList = initial_state.getChildNodes();
|
|
StateManager.particles_nb = particlesList.getLength() / 2; // The number of nodes in the XML tree is twice the number of data as each end of line is a node _ out.println("StateManager particles_nb="+particles_nb);
|
|
|
|
cells_ref = new int [particles_nb];
|
|
level_II = new OneObjectInSpace [particles_nb];
|
|
// The size of the array [occupied] is equal to the particles number.
|
|
// It is impossible to know the position of a "particle" in [sites] knowing its position in [occupied]. This is why there is an array [cells]
|
|
// ! WARNING ! ObjectsManager must have been created before the next instruction
|
|
// ! WARNING ! If several particles occupy the same location, the previous ones will be totally or partially overwritten
|
|
for (int k = 0; k < particlesList.getLength(); k++)
|
|
if (particlesList.item(k).getNodeType() == Node.ELEMENT_NODE && particlesList.item(k).getNodeName().equals("particle")) {
|
|
final Node particle = particlesList.item(k);
|
|
switch(StateManager.space_dimension) {
|
|
case ONE :StateManager.setParticle1DSg(
|
|
k / 2,
|
|
particle.getAttributes().getNamedItem("arrows").getNodeValue(),
|
|
particle.getAttributes().getNamedItem("name") .getNodeValue().trim(),
|
|
Integer.parseInt(particle.getAttributes().getNamedItem("x") .getNodeValue())); break;
|
|
case TWO :StateManager.setParticle2DHx(
|
|
k / 2,
|
|
particle.getAttributes().getNamedItem("arrows").getNodeValue(),
|
|
particle.getAttributes().getNamedItem("name") .getNodeValue().trim(),
|
|
Integer.parseInt(particle.getAttributes().getNamedItem("x") .getNodeValue()),
|
|
Integer.parseInt(particle.getAttributes().getNamedItem("y") .getNodeValue())); break;
|
|
case THREE :StateManager.setParticle3DCu(
|
|
k / 2,
|
|
particle.getAttributes().getNamedItem("arrows").getNodeValue(),
|
|
particle.getAttributes().getNamedItem("name") .getNodeValue().trim(),
|
|
Integer.parseInt(particle.getAttributes().getNamedItem("x") .getNodeValue()),
|
|
Integer.parseInt(particle.getAttributes().getNamedItem("y") .getNodeValue()),
|
|
Integer.parseInt(particle.getAttributes().getNamedItem("z") .getNodeValue())); break;
|
|
default:;
|
|
} // end switch(StateManager.space_dimension)
|
|
}
|
|
|
|
StateManagerLook.unit_space_size = Integer.parseInt (space_view_presentation.getAttributes().getNamedItem("space_unit_size").getNodeValue());
|
|
StateManagerLook.scaleFactor = Integer.parseInt (space_view_presentation.getAttributes().getNamedItem("scale_factor") .getNodeValue());
|
|
StateManagerLook.appearance = SPACE_LOOK.valueOf(space_view_presentation.getAttributes().getNamedItem("appearance") .getNodeValue());
|
|
if (XML_Model_Reader.comment_IdentityManager_init_model) out.println("from XML_Header_RW to ViewsManager.setPresentation size = " + StateManagerLook.unit_space_size +" APPEARANCE."+ StateManagerLook.appearance);
|
|
|
|
|
|
if (comment_on_sites_state) switch(StateManager.space_dimension) {
|
|
case ONE : StateManagerTest_V0.quiver_D1Sg(); break;
|
|
case TWO: StateManagerTest_V0.quiver_D2Hx(); break;
|
|
case THREE: StateManagerTest_V0.quiver_D3Cu(0); break;
|
|
default:;}
|
|
}
|
|
public StateManager () {} // Needed by LocalStateManager which extends StateManager
|
|
private static final void setSpaceDimensionAndSize (final int X, final int Y, final int Z, final int number_of_sites_in_a_cell) {
|
|
// TODO out.println("StateManager.setDimensionsSizeAndQiversArray coherence constraints : space must be big enough to allow particles to get their place");
|
|
|
|
StateManager.X = X;
|
|
StateManager.Y = Y;
|
|
StateManager.Z = Z;
|
|
StateManager.number_of_sites_in_a_cell = number_of_sites_in_a_cell; // number_of_sites != number_of_arrows
|
|
|
|
if (Z > 0 & Y > 0 & X > 0 & number_of_sites_in_a_cell > 0) {
|
|
space_dimension = DIMENSION.THREE;
|
|
sites = new int [X * Y * Z * number_of_sites_in_a_cell]; for (int i=0; i < X * Y * Z * number_of_sites_in_a_cell; i++) sites[i] = 0;
|
|
cells = new int [X * Y * Z]; for (int i=0; i < X * Y * Z; i++) cells[i] = -1;
|
|
} else if (Z == 0 & Y > 0 & X > 0 & number_of_sites_in_a_cell > 0) {
|
|
space_dimension = DIMENSION.TWO; // independent of the pavement
|
|
sites = new int [X * Y * number_of_sites_in_a_cell]; for (int i=0; i < X * Y * number_of_sites_in_a_cell; i++) sites[i] = 0;
|
|
cells = new int [X * Y]; for (int i=0; i < X * Y; i++) cells[i] = -1;
|
|
} else if (Z == 0 & Y == 0 & X > 0 & number_of_sites_in_a_cell > 0) {
|
|
space_dimension = DIMENSION.ONE;
|
|
sites = new int [X * number_of_sites_in_a_cell]; for (int i=0; i < X * number_of_sites_in_a_cell; i++) sites[i] = 0;
|
|
cells = new int [X]; for (int i=0; i < X; i++) cells[i] = -1;
|
|
} else {
|
|
out.println("StateManager.space_dimension = Parameters.DIMENSION.ANY ! WARNING !");
|
|
}
|
|
}
|
|
private static final void setSpaceBorders (final boolean XO, final boolean OX, final boolean YO, final boolean OY, final boolean ZO, final boolean OZ) {
|
|
StateManager.XO = XO;
|
|
StateManager.OX = OX;
|
|
StateManager.YO = YO;
|
|
StateManager.OY = OY;
|
|
StateManager.ZO = ZO;
|
|
StateManager.OZ = OZ;
|
|
StateManager.borders = (XO | OX | YO | OY | ZO | OZ); // TODO Each border (X, Y, Z) can be true or false > 2³ = 8 possibilities As a first approximation : [borders = false]
|
|
|
|
if (XML_Model_Reader.comment_IdentityManager_init_model)
|
|
out.println("from XML_Model_RW to StateManager.setParameters(...) X = " + X + " Y = " + Y + " Z = " + Z + " borders = [" + (XO ? "+" : "-") + (YO ? "+" : "-") + (ZO ? "+" : "-") + "] "+ borders);
|
|
}
|
|
private static final void setSpacePavage (final String name) {
|
|
switch (name) {
|
|
case "SEGMENTS" : pavage = PAVAGE.SEGMENTS; break;
|
|
case "SQUARES" : pavage = PAVAGE.SQUARES; break;
|
|
case "HEXAGONS" : pavage = PAVAGE.HEXAGONS; break;
|
|
case "CUBES" : pavage = PAVAGE.CUBES; break;
|
|
case "TETRAHEDRONS" : pavage = PAVAGE.TETRAHEDRONS; break;
|
|
default: pavage = PAVAGE.ERROR;
|
|
}
|
|
}
|
|
protected static final int get1D (final int x) {return ( x) * number_of_sites_in_a_cell;}
|
|
protected static final int get2D (final int x, final int y) {return ( X * y + x) * number_of_sites_in_a_cell;}
|
|
protected static final int get3D (final int x, final int y, final int z) {return (Y * X * z + X * y + x) * number_of_sites_in_a_cell;}
|
|
|
|
private static final void setParticle1DSg (final int key, final String arrows, final String name, int x) {
|
|
// TODO assert x * 2 + code % 2 < state_size_1D * 2
|
|
x = (x + X) % X;
|
|
|
|
int E = Integer.parseInt(arrows.substring(1, 2)); sites [get1D (x) + 0] = E;
|
|
int W = Integer.parseInt(arrows.substring(3, 4)); sites [get1D (x) + 1] = W;
|
|
|
|
cells_ref [ key ] = x; // x = get1D (x) / number_of_sites_in_a_cell;
|
|
cells [ x ] = key;
|
|
level_II [ key ] = new OneObjectInSpace(ObjectsManagerAccess.getOneObjectFromName(name), x, -1, -1);
|
|
|
|
if (XML_Model_Reader.comment_IdentityManager_init_model) StateManagerTest_V0.particle_1DSg(key, E, W, name, x);
|
|
}
|
|
public static final String get_EW_from_01 (final int d) { // 2020 This method should stay here in order to compare easily the association Integer / String with its inverse
|
|
switch (d){
|
|
case 0: return "E";
|
|
case 1: return "W";
|
|
default: return "Err="+ Integer.toString(d);
|
|
}
|
|
}
|
|
private static final void setParticle2DHx (final int key, final String arrows, final String name, int x, int y) {
|
|
|
|
x = (x + X) % X;
|
|
y = (y + Y) % Y;
|
|
|
|
int E = Integer.parseInt(arrows.substring( 1, 2)); sites [get2D (x,y) + 0] = E;
|
|
int SE = Integer.parseInt(arrows.substring( 3, 4)); sites [get2D (x,y) + 1] = SE;
|
|
int SW = Integer.parseInt(arrows.substring( 5, 6)); sites [get2D (x,y) + 2] = SW;
|
|
int W = Integer.parseInt(arrows.substring( 7, 8)); sites [get2D (x,y) + 3] = W;
|
|
int NW = Integer.parseInt(arrows.substring( 9,10)); sites [get2D (x,y) + 4] = NW;
|
|
int NE = Integer.parseInt(arrows.substring(11,12)); sites [get2D (x,y) + 5] = NE;
|
|
|
|
cells_ref [ key ] = get2D (x,y) / number_of_sites_in_a_cell;
|
|
cells [ get2D (x,y) / number_of_sites_in_a_cell ] = key;
|
|
level_II [ key ] = new OneObjectInSpace(ObjectsManagerAccess.getOneObjectFromName(name), x, y, -1);
|
|
|
|
if (XML_Model_Reader.comment_IdentityManager_init_model) if (key < 20) StateManagerTest_V0.particle_2DHx (key, E, SE, SW, W, NW, NE, name, x, y );
|
|
}
|
|
public static final String get_NSEW_from_012345(final int d) { // 2020 This method should stay here in order to compare easily the association Integer / String with its inverse
|
|
switch (d){
|
|
case 0: return "E";
|
|
case 1: return "SE";
|
|
case 2: return "SW"; // if (language.equals("francais")) return "SO";
|
|
case 3: return "W"; //
|
|
case 4: return "NW"; //
|
|
case 5: return "NE";
|
|
default: return "Err="+ Integer.toString(d);
|
|
}
|
|
}
|
|
public static final String get_NSEW_from_0123 (final int d) { // 2020 This method should stay here in order to compare easily the association Integer / String with its inverse
|
|
switch (d){
|
|
case 0: return "E";
|
|
case 1: return "S";
|
|
case 2: return "W"; // TODO if (language.equals("francais")) return "O" ? not sure ...
|
|
case 3: return "N"; //
|
|
default: return "Err="+ Integer.toString(d);
|
|
}
|
|
}
|
|
private static final void setParticle3DCu (final int key, final String arrows, final String name, int x, int y, int z) {
|
|
|
|
x = (x + X) % X;
|
|
y = (y + Y) % Y;
|
|
z = (z + Z) % Z;
|
|
|
|
int E = Integer.parseInt(arrows.substring( 1, 2)); sites [get3D (x,y,z) + 0] = E;
|
|
int W = Integer.parseInt(arrows.substring( 3, 4)); sites [get3D (x,y,z) + 1] = W;
|
|
int N = Integer.parseInt(arrows.substring( 5, 6)); sites [get3D (x,y,z) + 2] = N;
|
|
int S = Integer.parseInt(arrows.substring( 7, 8)); sites [get3D (x,y,z) + 3] = S;
|
|
int Z = Integer.parseInt(arrows.substring( 9,10)); sites [get3D (x,y,z) + 4] = Z;
|
|
int A = Integer.parseInt(arrows.substring(11,12)); sites [get3D (x,y,z) + 5] = A;
|
|
|
|
cells_ref [ key ] = get3D (x,y,z) / number_of_sites_in_a_cell;
|
|
cells [ get3D(x,y,z) / number_of_sites_in_a_cell ] = key;
|
|
level_II [ key ] = new OneObjectInSpace(ObjectsManagerAccess.getOneObjectFromName(name), x, y, z);
|
|
|
|
if (XML_Model_Reader.comment_IdentityManager_init_model) StateManagerTest_V0.particle_3DCu (key, E, W, N, S, Z, A, name, x, y, z);
|
|
}
|
|
public static final String get_NSEWZA_from_012345 (final int d) { // 2020 This method should stay here in order to compare easily the association Integer / String with its inverse
|
|
switch (d){
|
|
case 0: return "E";
|
|
case 1: return "W"; // TODO if (language.equals("francais")) return "O" ? not sure ...
|
|
case 2: return "N";
|
|
case 3: return "S"; //
|
|
case 4: return "Z"; // Zenith
|
|
case 5: return "A"; // nAdir and also A is at the opposite of Z in the alphabet
|
|
default: return "Err="+ Integer.toString(d);
|
|
}
|
|
}
|
|
|
|
public static int X, Y, Z, particles_nb;
|
|
public static boolean borders, XO, OX, YO, OY, ZO, OZ;
|
|
public static int number_of_sites_in_a_cell;
|
|
public static int[] sites; // [ 0.0 0.0 1.0 0.1 0.0 1.0 0.0 ] [ 0.0 1.0 0.0 0.1 0.0 1.0 0.0 ] if 2 x 3
|
|
public static int[] cells; // [ - - 0 1 - 2 - ] [ - 0 - 1 - 2 - ] | - - |
|
|
public static int[] cells_ref; // [ 2 3 5 ] [ 1 3 5 ] | 0 1 |
|
|
public static OneObjectInSpace[] level_II; // [ 2 3 5 ] [ 1 3 5 ] | 2 - |
|
|
|
|
private static boolean comment_on_sites_state = false;
|
|
}
|