Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge changes of maxmin_selective_update branch into the trunk.
authordonassbr <donassbr@48e7efb5-ca39-0410-a469-dd3cf9ba447f>
Wed, 26 Aug 2009 15:05:59 +0000 (15:05 +0000)
committerdonassbr <donassbr@48e7efb5-ca39-0410-a469-dd3cf9ba447f>
Wed, 26 Aug 2009 15:05:59 +0000 (15:05 +0000)
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/simgrid/simgrid/trunk@6640 48e7efb5-ca39-0410-a469-dd3cf9ba447f

50 files changed:
examples/msg/Makefile.am
examples/msg/trace/file.trace [new file with mode: 0644]
examples/msg/trace/test1.xml [new file with mode: 0644]
examples/msg/trace/test10.xml [new file with mode: 0644]
examples/msg/trace/test11.xml [new file with mode: 0644]
examples/msg/trace/test2.xml [new file with mode: 0644]
examples/msg/trace/test3.xml [new file with mode: 0644]
examples/msg/trace/test4.xml [new file with mode: 0644]
examples/msg/trace/test5.xml [new file with mode: 0644]
examples/msg/trace/test6.xml [new file with mode: 0644]
examples/msg/trace/test7.xml [new file with mode: 0644]
examples/msg/trace/test8.xml [new file with mode: 0644]
examples/msg/trace/test9.xml [new file with mode: 0644]
examples/msg/trace/test_trace_integration.c [new file with mode: 0644]
examples/msg/trace/test_trace_integration.xml [new file with mode: 0644]
examples/msg/trace/trace.tesh [new file with mode: 0644]
include/surf/simgrid_dtd.h
include/xbt/heap.h
src/Makefile.am
src/include/surf/maxmin.h
src/include/surf/surf.h
src/include/surf/trace_mgr.h
src/simdag/sd_task.c
src/simix/smx_action.c
src/simix/smx_deployment.c
src/simix/smx_global.c
src/surf/cpu.c
src/surf/cpu_im.c [new file with mode: 0644]
src/surf/cpu_ti.c [new file with mode: 0644]
src/surf/cpu_ti_private.h [new file with mode: 0644]
src/surf/maxmin.c
src/surf/maxmin_private.h
src/surf/network.c
src/surf/network_constant.c
src/surf/network_gtnets.c
src/surf/simgrid.dtd
src/surf/simgrid_dtd.c
src/surf/simgrid_dtd.l
src/surf/surf.c
src/surf/surf_action.c
src/surf/surf_config.c
src/surf/surf_model_timer.c
src/surf/surf_private.h
src/surf/surfxml_parse.c
src/surf/trace_mgr.c
src/surf/trace_mgr_private.h
src/surf/workstation.c
src/surf/workstation_ptask_L07.c
src/xbt/heap.c
src/xbt/heap_private.h

index 74bddc2..3215f56 100644 (file)
@@ -27,7 +27,20 @@ EXTRA_DIST = msg_platform.xml \
              parallel_task/test_ptask_deployment.xml \
              parallel_task/test_ptask_platform.xml \
              priority/deployment_priority.xml \
-             properties/deployment_properties.xml
+             properties/deployment_properties.xml \
+             trace/test_trace_integration.xml \
+             trace/file.trace \
+             trace/test1.xml \
+             trace/test2.xml \
+             trace/test3.xml \
+             trace/test4.xml \
+             trace/test5.xml \
+             trace/test6.xml \
+             trace/test7.xml \
+             trace/test8.xml \
+             trace/test9.xml \
+             trace/test10.xml \
+             trace/test11.xml
 
 
 TESTS_ENVIRONMENT = $(top_builddir)/tools/tesh/tesh
@@ -44,7 +57,8 @@ TESTS = sendrecv/sendrecv_CLM03.tesh \
         migration/migration.tesh \
         parallel_task/parallel_task.tesh \
         priority/priority.tesh \
-       properties/msg_prop.tesh
+       properties/msg_prop.tesh \
+       trace/trace.tesh
 
 if HAVE_GTNETS
   TESTS += gtnets/gtnets.tesh
@@ -61,7 +75,8 @@ CLEANFILES = sendrecv/*~ \
              parallel_task/parallel_task \
              parallel_task/test_ptask \
              priority/priority \
-             properties/msg_prop
+             properties/msg_prop \
+             trace/test_trace_integration
 
 if HAVE_GTNETS
              CLEANFILES += gtnets/gtnets gtnets/gtnets_kayo
@@ -80,7 +95,8 @@ noinst_PROGRAMS = sendrecv/sendrecv \
                   parallel_task/test_ptask \
                   priority/priority \
                   properties/msg_prop \
-                  actions/actions
+                  actions/actions \
+                  trace/test_trace_integration
 
 if HAVE_GTNETS
   noinst_PROGRAMS += gtnets/gtnets gtnets/gtnets_kayo
@@ -130,6 +146,10 @@ masterslave_masterslave_failure_LDADD   = $(top_builddir)/src/libsimgrid.la
 masterslave_masterslave_bypass_SOURCES = masterslave/masterslave_bypass.c
 masterslave_masterslave_bypass_LDADD   = $(top_builddir)/src/libsimgrid.la
 
+# bypass the surf xml parser
+trace_test_trace_integration_SOURCES = trace/test_trace_integration.c
+trace_test_trace_integration_LDADD   = $(top_builddir)/src/libsimgrid.la
+
 # verify if the GTNETS feature is working
 if HAVE_GTNETS
 gtnets_gtnets_SOURCES  = gtnets/gtnets.c
diff --git a/examples/msg/trace/file.trace b/examples/msg/trace/file.trace
new file mode 100644 (file)
index 0000000..e605be9
--- /dev/null
@@ -0,0 +1,9 @@
+PERIODICITY 10
+TIMESTEP 10
+ 0  0.5
+10  0.5
+20  1.00
+30  0.5
+40  0.5
+50  0.5
+60  0.5
diff --git a/examples/msg/trace/test1.xml b/examples/msg/trace/test1.xml
new file mode 100644 (file)
index 0000000..5cf9a15
--- /dev/null
@@ -0,0 +1,9 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+<platform version="2">
+  <host id="CPU1" power="20" availability_file="trace/file.trace"/>
+  <process host="CPU1" function="test_trace" start_time="10">
+       <argument value="400"/>
+       <argument value="1.0"/>
+  </process>
+</platform>
\ No newline at end of file
diff --git a/examples/msg/trace/test10.xml b/examples/msg/trace/test10.xml
new file mode 100644 (file)
index 0000000..3308cff
--- /dev/null
@@ -0,0 +1,17 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+<platform version="2">
+  <host id="CPU1" power="20" availability_file="trace/file.trace"/>
+  <process host="CPU1" function="test_trace">
+       <argument value="420"/>
+       <argument value="2.0"/>
+  </process>
+  <process host="CPU1" function="test_trace">
+       <argument value="310"/>
+       <argument value="1.0"/>
+  </process>
+  <process host="CPU1" function="test_trace" start_time="50">
+       <argument value="990"/>
+       <argument value="9.0"/>
+  </process>
+</platform>
diff --git a/examples/msg/trace/test11.xml b/examples/msg/trace/test11.xml
new file mode 100644 (file)
index 0000000..79e7af9
--- /dev/null
@@ -0,0 +1,31 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+
+<platform version="2">
+
+<trace id="1" periodicity="10" timestep="0.1">
+0  0.5
+10  0.5
+20  1.00
+30  0.5
+40  0.5
+50  0.5
+60  0.5
+</trace>
+
+<host id="CPU1" power="20"/>
+<trace:connect kind="POWER" trace="1" element="CPU1"/>
+<process host="CPU1" function="test_trace">
+<argument value="420"/>
+<argument value="2.0"/>
+</process>
+<process host="CPU1" function="test_trace">
+<argument value="310"/>
+<argument value="1.0"/>
+</process>
+<process host="CPU1" function="test_trace" start_time="50">
+<argument value="990"/>
+<argument value="9.0"/>
+</process>
+
+</platform>
diff --git a/examples/msg/trace/test2.xml b/examples/msg/trace/test2.xml
new file mode 100644 (file)
index 0000000..c9b02a7
--- /dev/null
@@ -0,0 +1,9 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+<platform version="2">
+  <host id="CPU1" power="20" availability_file="trace/file.trace"/>
+  <process host="CPU1" function="test_trace" start_time="10">
+       <argument value="850"/>
+       <argument value="1.0"/>
+  </process>
+</platform>
\ No newline at end of file
diff --git a/examples/msg/trace/test3.xml b/examples/msg/trace/test3.xml
new file mode 100644 (file)
index 0000000..94164ea
--- /dev/null
@@ -0,0 +1,9 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+<platform version="2">
+  <host id="CPU1" power="20" availability_file="trace/file.trace"/>
+  <process host="CPU1" function="test_trace" start_time="10">
+       <argument value="1980"/>
+       <argument value="1.0"/>
+  </process>
+</platform>
\ No newline at end of file
diff --git a/examples/msg/trace/test4.xml b/examples/msg/trace/test4.xml
new file mode 100644 (file)
index 0000000..793710b
--- /dev/null
@@ -0,0 +1,9 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+<platform version="2">
+  <host id="CPU1" power="20" availability_file="trace/file.trace"/>
+  <process host="CPU1" function="test_trace" start_time="80">
+       <argument value="400"/>
+       <argument value="1.0"/>
+  </process>
+</platform>
\ No newline at end of file
diff --git a/examples/msg/trace/test5.xml b/examples/msg/trace/test5.xml
new file mode 100644 (file)
index 0000000..99c8bf6
--- /dev/null
@@ -0,0 +1,9 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+<platform version="2">
+  <host id="CPU1" power="20" availability_file="trace/file.trace"/>
+  <process host="CPU1" function="test_trace" start_time="90">
+       <argument value="850"/>
+       <argument value="1.0"/>
+  </process>
+</platform>
\ No newline at end of file
diff --git a/examples/msg/trace/test6.xml b/examples/msg/trace/test6.xml
new file mode 100644 (file)
index 0000000..a595dba
--- /dev/null
@@ -0,0 +1,9 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+<platform version="2">
+  <host id="CPU1" power="20" availability_file="trace/file.trace"/>
+  <process host="CPU1" function="test_trace" start_time="80">
+       <argument value="1980"/>
+       <argument value="1.0"/>
+  </process>
+</platform>
\ No newline at end of file
diff --git a/examples/msg/trace/test7.xml b/examples/msg/trace/test7.xml
new file mode 100644 (file)
index 0000000..450fbfc
--- /dev/null
@@ -0,0 +1,13 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+<platform version="2">
+  <host id="CPU1" power="20" availability_file="trace/file.trace"/>
+  <process host="CPU1" function="test_trace" start_time="10">
+       <argument value="400"/>
+       <argument value="1.5"/>
+  </process>
+  <process host="CPU1" function="test_trace" start_time="20">
+       <argument value="300"/>
+       <argument value="1.5"/>
+  </process>
+</platform>
diff --git a/examples/msg/trace/test8.xml b/examples/msg/trace/test8.xml
new file mode 100644 (file)
index 0000000..0d925a4
--- /dev/null
@@ -0,0 +1,13 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+<platform version="2">
+  <host id="CPU1" power="20" availability_file="trace/file.trace"/>
+  <process host="CPU1" function="test_trace" start_time="10">
+       <argument value="400"/>
+       <argument value="2.5"/>
+  </process>
+  <process host="CPU1" function="test_trace" start_time="10">
+       <argument value="400"/>
+       <argument value="1.0"/>
+  </process>
+</platform>
diff --git a/examples/msg/trace/test9.xml b/examples/msg/trace/test9.xml
new file mode 100644 (file)
index 0000000..a3aba24
--- /dev/null
@@ -0,0 +1,17 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+<platform version="2">
+  <host id="CPU1" power="20" availability_file="trace/file.trace"/>
+  <process host="CPU1" function="test_trace">
+       <argument value="400"/>
+       <argument value="1.0"/>
+  </process>
+  <process host="CPU1" function="test_trace">
+       <argument value="400"/>
+       <argument value="1.0"/>
+  </process>
+  <process host="CPU1" function="test_trace" start_time="30">
+       <argument value="2000"/>
+       <argument value="1.0"/>
+  </process>
+</platform>
diff --git a/examples/msg/trace/test_trace_integration.c b/examples/msg/trace/test_trace_integration.c
new file mode 100644 (file)
index 0000000..067cd73
--- /dev/null
@@ -0,0 +1,68 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include "msg/msg.h"
+#include "xbt/log.h"
+#include "xbt/asserts.h"
+
+XBT_LOG_NEW_DEFAULT_CATEGORY(test_trace_integration,
+                             "Messages specific for this msg example");
+
+int test_trace(int argc, char *argv[]);
+
+/** test the trace integration cpu model */
+int test_trace(int argc, char *argv[])
+{
+       m_task_t task;
+       double task_comp_size = 2800;
+       double task_prio = 1.0;
+
+       if (argc != 3) {
+               printf("Wrong number of arguments!\nUsage:\n\t1) task computational size in FLOPS\n\t2 task priority\n");
+           exit(1);
+       }
+
+       task_comp_size = atof(argv[1]);
+       task_prio = atof(argv[2]);
+
+       INFO0("Testing the trace integration cpu model: CpuTI");
+       INFO1("Task size: %lf", task_comp_size);
+       INFO1("Task prio: %lf", task_prio);
+
+       /* Create and execute a single task. */
+       task = MSG_task_create("proc 0", task_comp_size, 0, NULL);
+       MSG_task_set_priority(task, task_prio);
+       MSG_task_execute(task);
+
+       INFO0("Test finished");
+
+
+       return 0;
+}
+
+/** Main function */
+int main(int argc, char *argv[])
+{
+  MSG_error_t res = MSG_OK;
+
+  /* Verify if the platform xml file was passed by command line. */
+  MSG_global_init(&argc, argv);
+  if (argc < 2) {
+    printf("Usage: %s test_trace_integration_model.xml\n", argv[0]);
+    exit(1);
+  }
+
+  /* Register SimGrid process function. */
+  MSG_function_register("test_trace", test_trace);
+  /* Use the same file for platform and deployment. */
+  MSG_create_environment(argv[1]);
+  MSG_launch_application(argv[1]);
+  /* Run the example. */
+  res = MSG_main();
+
+  MSG_clean();
+
+  if (res == MSG_OK)
+    return 0;
+  else
+    return 1;
+}
diff --git a/examples/msg/trace/test_trace_integration.xml b/examples/msg/trace/test_trace_integration.xml
new file mode 100644 (file)
index 0000000..456bdb6
--- /dev/null
@@ -0,0 +1,6 @@
+<?xml version='1.0'?>
+<!DOCTYPE platform SYSTEM "simgrid.dtd">
+<platform version="2">
+  <host id="CPU1" power="20"/>
+  <process host="CPU1" function="test_trace"/>
+</platform>
\ No newline at end of file
diff --git a/examples/msg/trace/trace.tesh b/examples/msg/trace/trace.tesh
new file mode 100644 (file)
index 0000000..548f627
--- /dev/null
@@ -0,0 +1,155 @@
+#! ./tesh
+
+p Testing trace integration using file.trace and test1.xml, a < max(time), b < max(time)
+
+$ $SG_TEST_EXENV trace/test_trace_integration$EXEEXT ${srcdir:=.}/trace/test1.xml --cfg=workstation_model:compound --cfg=network_model:CM02 --cfg=cpu_model:CpuTI
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'workstation_model' to 'compound'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'network_model' to 'CM02'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'cpu_model' to 'CpuTI'
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Task size: 400.000000
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(1) 40.000000] [test_trace_integration/INFO] Test finished
+
+p Testing trace integration using file.trace and test2.xml, a < max(time), max(time) < b < 2 max(time) 
+
+$ $SG_TEST_EXENV trace/test_trace_integration$EXEEXT ${srcdir:=.}/trace/test2.xml --cfg=workstation_model:compound --cfg=network_model:CM02 --cfg=cpu_model:CpuTI
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'workstation_model' to 'compound'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'network_model' to 'CM02'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'cpu_model' to 'CpuTI'
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Task size: 850.000000
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(1) 85.000000] [test_trace_integration/INFO] Test finished
+
+
+p Testing trace integration using file.trace and test3.xml, a < max(time), b > 2 max(time) 
+
+$ $SG_TEST_EXENV trace/test_trace_integration$EXEEXT ${srcdir:=.}/trace/test3.xml --cfg=workstation_model:compound --cfg=network_model:CM02 --cfg=cpu_model:CpuTI
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'workstation_model' to 'compound'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'network_model' to 'CM02'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'cpu_model' to 'CpuTI'
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Task size: 1980.000000
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(1) 178.000000] [test_trace_integration/INFO] Test finished
+
+p Testing trace integration using file.trace and test4.xml, max(time) < a < 2max(time), max(time) < b < 2max(time)
+
+$ $SG_TEST_EXENV trace/test_trace_integration$EXEEXT ${srcdir:=.}/trace/test4.xml --cfg=workstation_model:compound --cfg=network_model:CM02 --cfg=cpu_model:CpuTI
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'workstation_model' to 'compound'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'network_model' to 'CM02'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'cpu_model' to 'CpuTI'
+> [CPU1:test_trace:(1) 80.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(1) 80.000000] [test_trace_integration/INFO] Task size: 400.000000
+> [CPU1:test_trace:(1) 80.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(1) 110.000000] [test_trace_integration/INFO] Test finished
+
+p Testing trace integration using file.trace and test5.xml, max(time) < a < 2max(time), 2max(time) < b < 3max(time)
+
+$ $SG_TEST_EXENV trace/test_trace_integration$EXEEXT ${srcdir:=.}/trace/test5.xml --cfg=workstation_model:compound --cfg=network_model:CM02 --cfg=cpu_model:CpuTI
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'workstation_model' to 'compound'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'network_model' to 'CM02'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'cpu_model' to 'CpuTI'
+> [CPU1:test_trace:(1) 90.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(1) 90.000000] [test_trace_integration/INFO] Task size: 850.000000
+> [CPU1:test_trace:(1) 90.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(1) 162.500000] [test_trace_integration/INFO] Test finished
+
+p Testing trace integration using file.trace and test6.xml, max(time) < a < 2max(time), b > 3max(time)
+
+$ $SG_TEST_EXENV trace/test_trace_integration$EXEEXT ${srcdir:=.}/trace/test6.xml --cfg=workstation_model:compound --cfg=network_model:CM02 --cfg=cpu_model:CpuTI
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'workstation_model' to 'compound'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'network_model' to 'CM02'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'cpu_model' to 'CpuTI'
+> [CPU1:test_trace:(1) 80.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(1) 80.000000] [test_trace_integration/INFO] Task size: 1980.000000
+> [CPU1:test_trace:(1) 80.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(1) 248.000000] [test_trace_integration/INFO] Test finished
+
+p Testing trace integration using file.trace and test7.xml, two process with same priority
+
+$ $SG_TEST_EXENV trace/test_trace_integration$EXEEXT ${srcdir:=.}/trace/test7.xml --cfg=workstation_model:compound --cfg=network_model:CM02 --cfg=cpu_model:CpuTI
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'workstation_model' to 'compound'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'network_model' to 'CM02'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'cpu_model' to 'CpuTI'
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Task size: 400.000000
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Task prio: 1.500000
+> [CPU1:test_trace:(2) 20.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(2) 20.000000] [test_trace_integration/INFO] Task size: 300.000000
+> [CPU1:test_trace:(2) 20.000000] [test_trace_integration/INFO] Task prio: 1.500000
+> [CPU1:test_trace:(1) 70.000000] [test_trace_integration/INFO] Test finished
+> [CPU1:test_trace:(2) 70.000000] [test_trace_integration/INFO] Test finished
+
+p Testing trace integration using file.trace and test8.xml, two process with different priority
+
+$ $SG_TEST_EXENV trace/test_trace_integration$EXEEXT ${srcdir:=.}/trace/test8.xml --cfg=workstation_model:compound --cfg=network_model:CM02 --cfg=cpu_model:CpuTI
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'workstation_model' to 'compound'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'network_model' to 'CM02'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'cpu_model' to 'CpuTI'
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Task size: 400.000000
+> [CPU1:test_trace:(1) 10.000000] [test_trace_integration/INFO] Task prio: 2.500000
+> [CPU1:test_trace:(2) 10.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(2) 10.000000] [test_trace_integration/INFO] Task size: 400.000000
+> [CPU1:test_trace:(2) 10.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(1) 56.000000] [test_trace_integration/INFO] Test finished
+> [CPU1:test_trace:(2) 80.000000] [test_trace_integration/INFO] Test finished
+
+p Testing trace integration using file.trace and test9.xml, three process with same priority
+
+$ $SG_TEST_EXENV trace/test_trace_integration$EXEEXT ${srcdir:=.}/trace/test9.xml --cfg=workstation_model:compound --cfg=network_model:CM02 --cfg=cpu_model:CpuTI
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'workstation_model' to 'compound'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'network_model' to 'CM02'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'cpu_model' to 'CpuTI'
+> [CPU1:test_trace:(1) 0.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(1) 0.000000] [test_trace_integration/INFO] Task size: 400.000000
+> [CPU1:test_trace:(1) 0.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(2) 0.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(2) 0.000000] [test_trace_integration/INFO] Task size: 400.000000
+> [CPU1:test_trace:(2) 0.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(3) 30.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(3) 30.000000] [test_trace_integration/INFO] Task size: 2000.000000
+> [CPU1:test_trace:(3) 30.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(1) 90.000000] [test_trace_integration/INFO] Test finished
+> [CPU1:test_trace:(2) 90.000000] [test_trace_integration/INFO] Test finished
+> [CPU1:test_trace:(3) 240.000000] [test_trace_integration/INFO] Test finished
+
+p Testing trace integration using file.trace and test10.xml, three process with different priority
+
+$ $SG_TEST_EXENV trace/test_trace_integration$EXEEXT ${srcdir:=.}/trace/test10.xml --cfg=workstation_model:compound --cfg=network_model:CM02 --cfg=cpu_model:CpuTI
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'workstation_model' to 'compound'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'network_model' to 'CM02'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'cpu_model' to 'CpuTI'
+> [CPU1:test_trace:(1) 0.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(1) 0.000000] [test_trace_integration/INFO] Task size: 420.000000
+> [CPU1:test_trace:(1) 0.000000] [test_trace_integration/INFO] Task prio: 2.000000
+> [CPU1:test_trace:(2) 0.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(2) 0.000000] [test_trace_integration/INFO] Task size: 310.000000
+> [CPU1:test_trace:(2) 0.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(3) 50.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(3) 50.000000] [test_trace_integration/INFO] Task size: 990.000000
+> [CPU1:test_trace:(3) 50.000000] [test_trace_integration/INFO] Task prio: 9.000000
+> [CPU1:test_trace:(1) 62.000000] [test_trace_integration/INFO] Test finished
+> [CPU1:test_trace:(2) 152.000000] [test_trace_integration/INFO] Test finished
+> [CPU1:test_trace:(3) 152.000000] [test_trace_integration/INFO] Test finished
+
+p Testing trace integration using file.trace and test11.xml, three process with different priority. Changed timestep to 0.1.
+
+$ $SG_TEST_EXENV trace/test_trace_integration$EXEEXT ${srcdir:=.}/trace/test11.xml --cfg=workstation_model:compound --cfg=network_model:CM02 --cfg=cpu_model:CpuTI
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'workstation_model' to 'compound'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'network_model' to 'CM02'
+> [0.000000] [xbt_cfg/INFO] Configuration change: Set 'cpu_model' to 'CpuTI'
+> [CPU1:test_trace:(1) 0.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(1) 0.000000] [test_trace_integration/INFO] Task size: 420.000000
+> [CPU1:test_trace:(1) 0.000000] [test_trace_integration/INFO] Task prio: 2.000000
+> [CPU1:test_trace:(2) 0.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(2) 0.000000] [test_trace_integration/INFO] Task size: 310.000000
+> [CPU1:test_trace:(2) 0.000000] [test_trace_integration/INFO] Task prio: 1.000000
+> [CPU1:test_trace:(3) 50.000000] [test_trace_integration/INFO] Testing the trace integration cpu model: CpuTI
+> [CPU1:test_trace:(3) 50.000000] [test_trace_integration/INFO] Task size: 990.000000
+> [CPU1:test_trace:(3) 50.000000] [test_trace_integration/INFO] Task prio: 9.000000
+> [CPU1:test_trace:(1) 62.000000] [test_trace_integration/INFO] Test finished
+> [CPU1:test_trace:(2) 152.000000] [test_trace_integration/INFO] Test finished
+> [CPU1:test_trace:(3) 152.000000] [test_trace_integration/INFO] Test finished
index f003aee..43b0e1f 100644 (file)
@@ -1,10 +1,10 @@
 /* XML processor/application API for surf/simgrid.dtd.
- * Generated 2008/03/06 08:58:39.
+ * Generated 2009/08/14 11:23:44.
  *
  * This program was generated with the FleXML XML processor generator.
  * FleXML is Copyright (C) 1999-2005 Kristoffer Rose.  All rights reserved.
  * FleXML is Copyright (C) 2003-2006 Martin Quinson.  All rights reserved.
- * (Id: flexml.pl,v 1.63 2007/10/11 14:46:08 mquinson Exp).
+ * (Id: flexml.pl,v 1.62 2007/10/11 10:00:14 mquinson Exp).
  * 
  * There are two, intertwined parts to this program, part A and part B.
  *
@@ -48,8 +48,6 @@
 #ifndef _FLEXML_simgrid_H
 #define _FLEXML_simgrid_H
 
-\r SG_BEGIN_DECL()
-
 /* XML application entry points. */
 XBT_PUBLIC(void) STag_surfxml_platform(void);
 XBT_PUBLIC(void) ETag_surfxml_platform(void);
@@ -187,6 +185,8 @@ XBT_PUBLIC(void) ETag_surfxml_argument(void);
 #define AU_surfxml_prop_value NULL
      typedef int AT_surfxml_route_impact_on_src_with_other_recv;
 #define AU_surfxml_route_impact_on_src_with_other_recv NULL
+     typedef int AT_surfxml_trace_timestep;
+#define AU_surfxml_trace_timestep NULL
      typedef int AT_surfxml_link_state_file;
 #define AU_surfxml_link_state_file NULL
      typedef int AT_surfxml_set_prefix;
@@ -351,6 +351,8 @@ XBT_PUBLIC_DATA(AT_surfxml_prop_value) AX_surfxml_prop_value;
 XBT_PUBLIC_DATA(AT_surfxml_route_impact_on_src_with_other_recv)
   AX_surfxml_route_impact_on_src_with_other_recv;
 #define A_surfxml_route_impact_on_src_with_other_recv (surfxml_bufferstack + AX_surfxml_route_impact_on_src_with_other_recv)
+XBT_PUBLIC_DATA(AT_surfxml_trace_timestep) AX_surfxml_trace_timestep;
+#define A_surfxml_trace_timestep (surfxml_bufferstack + AX_surfxml_trace_timestep)
 XBT_PUBLIC_DATA(AT_surfxml_link_state_file) AX_surfxml_link_state_file;
 #define A_surfxml_link_state_file (surfxml_bufferstack + AX_surfxml_link_state_file)
 XBT_PUBLIC_DATA(AT_surfxml_set_prefix) AX_surfxml_set_prefix;
@@ -410,6 +412,4 @@ XBT_PUBLIC(int) yylex(void);
 
 /* Flexml error handling function (useful only when -q flag passed to flexml) */
      const char *surfxml_parse_err_msg(void);
-
-\rSG_END_DECL()
 #endif
index eb0a285..16f5126 100644 (file)
@@ -28,6 +28,8 @@ XBT_PUBLIC(void *) xbt_heap_pop(xbt_heap_t H);
 
 XBT_PUBLIC(double) xbt_heap_maxkey(xbt_heap_t H);
 XBT_PUBLIC(void *) xbt_heap_maxcontent(xbt_heap_t H);
+XBT_PUBLIC(void) xbt_heap_set_update_callback(xbt_heap_t H, void (*update_callback)(void*, int));
+XBT_PUBLIC(void*) xbt_heap_remove(xbt_heap_t H, int i);
 
 /* @} */
 #endif /* _XBT_HEAP_H */
index d93e86d..3a8081a 100644 (file)
@@ -46,6 +46,7 @@ EXTRA_DIST= \
        surf/gtnets/gtnets_interface.h \
        surf/gtnets/gtnets_simulator.h \
        surf/gtnets/gtnets_topology.h  \
+       surf/cpu_ti_private.h \
        \
         include/surf/surf_resource.h  \
        include/surf/datatypes.h \
@@ -183,6 +184,8 @@ SURF_SRC= \
   surf/cpu.c   surf/network.c surf/network_constant.c surf/workstation.c     \
   surf/surf_model_timer.c                                                    \
   surf/workstation_ptask_L07.c                                               \
+  surf/cpu_ti.c                                               \
+  surf/cpu_im.c                                               \
   xbt/xbt_sg_stubs.c
 
 if CONTEXT_THREADS
index c8580a0..fe7f3c5 100644 (file)
@@ -86,6 +86,8 @@ XBT_PUBLIC(void) lmm_update_constraint_bound(lmm_system_t sys,
 
 XBT_PUBLIC(void) lmm_solve(lmm_system_t sys);
 
+XBT_PUBLIC(void *) lmm_extract_modified_variable(lmm_system_t sys);
+
 XBT_PUBLIC(void) lagrange_solve(lmm_system_t sys);
 XBT_PUBLIC(void) bottleneck_solve(lmm_system_t sys);
 
index 5f6edf5..54a195c 100644 (file)
 
 SG_BEGIN_DECL()
 /* Actions and models are highly connected structures... */
-
-
-typedef enum {
-  SURF_RESOURCE_ON = 1,                   /**< Up & ready        */
-  SURF_RESOURCE_OFF = 0                   /**< Down & broken     */
-} e_surf_resource_state_t;
+     typedef enum {
+       SURF_RESOURCE_ON = 1,              /**< Up & ready        */
+       SURF_RESOURCE_OFF = 0              /**< Down & broken     */
+     } e_surf_resource_state_t;
 
 /** @Brief Specify that we use that action */
 XBT_PUBLIC(void) surf_action_ref(surf_action_t action);
@@ -34,7 +32,8 @@ XBT_PUBLIC(void) surf_action_ref(surf_action_t action);
  * @param model to which model we should attach this action
  * @param failed whether we should start this action in failed mode
  */
-XBT_PUBLIC(void*) surf_action_new(size_t size,double cost,surf_model_t model, int failed);
+XBT_PUBLIC(void *) surf_action_new(size_t size, double cost,
+                                   surf_model_t model, int failed);
 
 
 
@@ -82,7 +81,8 @@ XBT_PUBLIC(int) find_model_description(s_surf_model_description_t * table,
        s_surf_action_t generic_action;
        lmm_variable_t variable;
        int suspended;
-     } s_surf_action_lmm_t,*surf_action_lmm_t;
+     } s_surf_action_lmm_t, *surf_action_lmm_t;
+
 /** \brief Action states
  *  \ingroup SURF_actions
  *
@@ -123,7 +123,7 @@ XBT_PUBLIC(int) find_model_description(s_surf_model_description_t * table,
 /* Generic model object */
 /***************************/
      typedef struct s_routing s_routing_t, *routing_t;
-     XBT_PUBLIC_DATA(routing_t) used_routing;
+XBT_PUBLIC_DATA(routing_t) used_routing;
 
 /** \brief Private data available on all models
  *  \ingroup SURF_models
@@ -150,7 +150,7 @@ XBT_PUBLIC(int) find_model_description(s_surf_model_description_t * table,
      typedef struct surf_cpu_model_extension_public {
        surf_action_t(*execute) (void *cpu, double size);
        surf_action_t(*sleep) (void *cpu, double duration);
-       e_surf_resource_state_t (*get_state) (void *cpu);
+       e_surf_resource_state_t(*get_state) (void *cpu);
        double (*get_speed) (void *cpu, double load);
        double (*get_available_speed) (void *cpu);
      } s_surf_model_extension_cpu_t;
@@ -163,9 +163,10 @@ XBT_PUBLIC(int) find_model_description(s_surf_model_description_t * table,
       *  Public functions specific to the network model
       */
      typedef struct surf_network_model_extension_public {
-       surf_action_t(*communicate) (const char *src_name,const char *dst_name,int src, int dst, double size,
-           double rate);
-       xbt_dynar_t (*get_route) (int src, int dst);
+       surf_action_t(*communicate) (const char *src_name,
+                                    const char *dst_name, int src, int dst,
+                                    double size, double rate);
+       xbt_dynar_t(*get_route) (int src, int dst);
        double (*get_link_bandwidth) (const void *link);
        double (*get_link_latency) (const void *link);
        int (*link_shared) (const void *link);
@@ -183,20 +184,20 @@ XBT_PUBLIC(int) find_model_description(s_surf_model_description_t * table,
        e_surf_resource_state_t(*get_state) (void *workstation);                                 /**< Return the CPU state of a workstation */
        double (*get_speed) (void *workstation, double load);                               /**< Return the speed of a workstation */
        double (*get_available_speed) (void *workstation);                                  /**< Return tha available speed of a workstation */
-       surf_action_t(*communicate) (void *workstation_src,                                 /**< Execute a communication amount between two workstations */
-                                    void *workstation_dst, double size,
-                                    double max_rate);
-       xbt_dynar_t(*get_route)(void *workstation_src,void *workstation_dst);               /**< Get the list of links between two ws */
-
-       surf_action_t(*execute_parallel_task) (int workstation_nb,                          /**< Execute a parallel task on several workstations */
-                                              void **workstation_list,
-                                              double *computation_amount,
-                                              double *communication_amount,
-                                              double amount, double rate);
+         surf_action_t(*communicate) (void *workstation_src,                               /**< Execute a communication amount between two workstations */
+                                      void *workstation_dst, double size,
+                                      double max_rate);
+         xbt_dynar_t(*get_route) (void *workstation_src, void *workstation_dst);           /**< Get the list of links between two ws */
+
+         surf_action_t(*execute_parallel_task) (int workstation_nb,                        /**< Execute a parallel task on several workstations */
+                                                void **workstation_list,
+                                                double *computation_amount,
+                                                double *communication_amount,
+                                                double amount, double rate);
        double (*get_link_bandwidth) (const void *link);                                    /**< Return the current bandwidth of a network link */
        double (*get_link_latency) (const void *link);                                      /**< Return the current latency of a network link */
        int (*link_shared) (const void *link);
-       xbt_dict_t (*get_properties)(const void*resource);
+         xbt_dict_t(*get_properties) (const void *resource);
      } s_surf_model_extension_workstation_t;
 
 /** \brief Model datatype
@@ -209,9 +210,11 @@ XBT_PUBLIC(int) find_model_description(s_surf_model_description_t * table,
        const char *name;/**< Name of this model */
        s_surf_action_state_t states; /**< Any living action on this model */
 
-       e_surf_action_state_t(*action_state_get) (surf_action_t action);/**< Return the state of an action */
+         e_surf_action_state_t(*action_state_get) (surf_action_t action);
+                                                                       /**< Return the state of an action */
        void (*action_state_set) (surf_action_t action,
-                                    e_surf_action_state_t state); /**< Change an action state*/
+                                 e_surf_action_state_t state);
+                                                                  /**< Change an action state*/
 
        double (*action_get_start_time) (surf_action_t action);/**< Return the start time of an action */
        double (*action_get_finish_time) (surf_action_t action);/**< Return the finish time of an action */
@@ -224,6 +227,7 @@ XBT_PUBLIC(int) find_model_description(s_surf_model_description_t * table,
        int (*is_suspended) (surf_action_t action);/**< Return whether an action is suspended */
        void (*set_max_duration) (surf_action_t action, double duration);/**< Set the max duration of an action*/
        void (*set_priority) (surf_action_t action, double priority);/**< Set the priority of an action */
+       double (*get_remains) (surf_action_t action);/**< Get the remains of an action */
 
        xbt_dict_t resource_set;
 
@@ -258,19 +262,19 @@ XBT_PUBLIC(int) find_model_description(s_surf_model_description_t * table,
 /**
  * Resource which have a metric handled by a maxmin system
  */
-typedef struct {
-  double scale;
-  double peak;
-  tmgr_trace_event_t event;
-} s_surf_metric_t;
+     typedef struct {
+       double scale;
+       double peak;
+       tmgr_trace_event_t event;
+     } s_surf_metric_t;
 
-typedef struct surf_resource_lmm {
-  s_surf_resource_t generic_resource;
-  lmm_constraint_t constraint;
-  e_surf_resource_state_t state_current;
-  tmgr_trace_event_t state_event;
-  s_surf_metric_t power;
-}s_surf_resource_lmm_t, *surf_resource_lmm_t;
+     typedef struct surf_resource_lmm {
+       s_surf_resource_t generic_resource;
+       lmm_constraint_t constraint;
+       e_surf_resource_state_t state_current;
+       tmgr_trace_event_t state_event;
+       s_surf_metric_t power;
+     } s_surf_resource_lmm_t, *surf_resource_lmm_t;
 
 /**************************************/
 /* Implementations of model object */
@@ -302,6 +306,22 @@ XBT_PUBLIC_DATA(surf_model_t) surf_cpu_model;
  */
 XBT_PUBLIC(void) surf_cpu_model_init_Cas01(const char *filename);
 
+/** \brief Initializes the CPU model with trace integration
+ *  \ingroup SURF_models
+ *
+ */
+XBT_PUBLIC(void) surf_cpu_model_init_ti(const char *filename);
+
+/** \brief Initializes the CPU model with the model Cas01 Improved. This model uses a heap to order the events, decreasing the time complexity to get the minimum next event.
+ *  \ingroup SURF_models
+ *
+ *  This function is called by surf_workstation_model_init_CLM03
+ *  so you shouldn't have to call it by yourself.
+ *
+ *  \see surf_workstation_model_init_CLM03()
+ */
+XBT_PUBLIC(void) surf_cpu_model_init_Cas01_im(const char *filename);
+
 /** \brief The list of all available cpu model models
  *  \ingroup SURF_models
  */
index 693e06a..8c4a15e 100644 (file)
@@ -20,9 +20,18 @@ XBT_PUBLIC(void) tmgr_history_free(tmgr_history_t history);
 XBT_PUBLIC(tmgr_trace_t) tmgr_trace_new(const char *filename);
 XBT_PUBLIC(tmgr_trace_t) tmgr_trace_new_from_string(const char *id,
                                                     const char *input,
-                                                    double periodicity);
+                                                    double periodicity,
+                                                    double timestep);
 XBT_PUBLIC(tmgr_trace_t) tmgr_empty_trace_new(void);
 XBT_PUBLIC(void) tmgr_trace_free(tmgr_trace_t trace);
+/**
+ * \brief Free a trace event structure
+ *
+ * This function frees a trace_event if it can be freed, ie, if it has the free_me flag set to 1. This flag indicates whether the structure is still used somewhere or not.
+ * \param      trace_event             Trace event structure
+ * \return 1 if the structure was freed, 0 otherwise
+*/
+XBT_PUBLIC(int) tmgr_trace_event_free(tmgr_trace_event_t trace_event);
 
 XBT_PUBLIC(tmgr_trace_event_t) tmgr_history_add_trace(tmgr_history_t history,
                                                       tmgr_trace_t trace,
index 3ce7e5b..0c87b5c 100644 (file)
@@ -193,7 +193,7 @@ double SD_task_get_remaining_amount(SD_task_t task)
   xbt_assert0(task != NULL, "Invalid parameter");
 
   if (task->surf_action)
-    return task->surf_action->remains;
+    return surf_workstation_model->get_remains(task->surf_action);
   else
     return task->remains;
 }
@@ -711,14 +711,14 @@ void __SD_task_really_run(SD_task_t task)
   task->surf_action = NULL;
   if ((task->workstation_nb == 1) && (task->communication_amount[0] == 0.0)) {
     task->surf_action =
-      surf_workstation_model->extension.workstation.
-      execute(surf_workstations[0], task->computation_amount[0]);
+      surf_workstation_model->extension.
+      workstation.execute(surf_workstations[0], task->computation_amount[0]);
   } else if ((task->workstation_nb == 1)
              && (task->computation_amount[0] == 0.0)) {
     task->surf_action =
-      surf_workstation_model->extension.workstation.
-      communicate(surf_workstations[0], surf_workstations[0],
-                  task->communication_amount[0], task->rate);
+      surf_workstation_model->extension.
+      workstation.communicate(surf_workstations[0], surf_workstations[0],
+                              task->communication_amount[0], task->rate);
   } else if ((task->workstation_nb == 2)
              && (task->computation_amount[0] == 0.0)
              && (task->computation_amount[1] == 0.0)) {
@@ -733,9 +733,9 @@ void __SD_task_really_run(SD_task_t task)
     }
     if (nb == 1) {
       task->surf_action =
-        surf_workstation_model->extension.workstation.
-        communicate(surf_workstations[0], surf_workstations[1], value,
-                    task->rate);
+        surf_workstation_model->extension.
+        workstation.communicate(surf_workstations[0], surf_workstations[1],
+                                value, task->rate);
     }
   }
   if (!task->surf_action) {
@@ -749,10 +749,11 @@ void __SD_task_really_run(SD_task_t task)
            sizeof(double) * task->workstation_nb * task->workstation_nb);
 
     task->surf_action =
-      surf_workstation_model->extension.workstation.
-      execute_parallel_task(task->workstation_nb, surf_workstations,
-                            computation_amount, communication_amount,
-                            task->amount, task->rate);
+      surf_workstation_model->extension.
+      workstation.execute_parallel_task(task->workstation_nb,
+                                        surf_workstations, computation_amount,
+                                        communication_amount, task->amount,
+                                        task->rate);
   } else {
     xbt_free(surf_workstations);
   }
index 8866181..bbe3a04 100644 (file)
@@ -31,13 +31,13 @@ smx_action_t SIMIX_action_communicate(smx_host_t sender,
   smx_action_t act;
 
   /* check if the host is active */
-  if (surf_workstation_model->extension.
-      workstation.get_state(sender->host) != SURF_RESOURCE_ON) {
+  if (surf_workstation_model->extension.workstation.get_state(sender->host) !=
+      SURF_RESOURCE_ON) {
     THROW1(network_error, 0, "Host %s failed, you cannot call this function",
            sender->name);
   }
-  if (surf_workstation_model->extension.
-      workstation.get_state(receiver->host) != SURF_RESOURCE_ON) {
+  if (surf_workstation_model->extension.workstation.
+      get_state(receiver->host) != SURF_RESOURCE_ON) {
     THROW1(network_error, 0, "Host %s failed, you cannot call this function",
            receiver->name);
   }
@@ -52,8 +52,9 @@ smx_action_t SIMIX_action_communicate(smx_host_t sender,
 
 
   act->surf_action =
-    surf_workstation_model->extension.workstation.
-    communicate(sender->host, receiver->host, size, rate);
+    surf_workstation_model->extension.workstation.communicate(sender->host,
+                                                              receiver->host,
+                                                              size, rate);
   surf_workstation_model->action_data_set(act->surf_action, act);
 
   DEBUG1("Create communicate action %p", act);
@@ -74,8 +75,8 @@ smx_action_t SIMIX_action_execute(smx_host_t host, const char *name,
   smx_action_t act;
 
   /* check if the host is active */
-  if (surf_workstation_model->extension.
-      workstation.get_state(host->host) != SURF_RESOURCE_ON) {
+  if (surf_workstation_model->extension.workstation.get_state(host->host) !=
+      SURF_RESOURCE_ON) {
     THROW1(host_error, 0, "Host %s failed, you cannot call this function",
            host->name);
   }
@@ -90,8 +91,7 @@ smx_action_t SIMIX_action_execute(smx_host_t host, const char *name,
 
   /* set communication */
   act->surf_action =
-    surf_workstation_model->extension.workstation.execute(host->host,
-                                                          amount);
+    surf_workstation_model->extension.workstation.execute(host->host, amount);
 
   surf_workstation_model->action_data_set(act->surf_action, act);
 
@@ -112,8 +112,8 @@ smx_action_t SIMIX_action_sleep(smx_host_t host, double duration)
   smx_action_t act;
 
   /* check if the host is active */
-  if (surf_workstation_model->extension.
-      workstation.get_state(host->host) != SURF_RESOURCE_ON) {
+  if (surf_workstation_model->extension.workstation.get_state(host->host) !=
+      SURF_RESOURCE_ON) {
     THROW1(host_error, 0, "Host %s failed, you cannot call this function",
            host->name);
   }
@@ -127,8 +127,7 @@ smx_action_t SIMIX_action_sleep(smx_host_t host, double duration)
   act->name = xbt_strdup(name);
 
   act->surf_action =
-    surf_workstation_model->extension.workstation.sleep(host->host,
-                                                        duration);
+    surf_workstation_model->extension.workstation.sleep(host->host, duration);
 
   surf_workstation_model->action_data_set(act->surf_action, act);
 
@@ -164,8 +163,7 @@ void SIMIX_action_set_priority(smx_action_t action, double priority)
 {
   xbt_assert0((action != NULL), "Invalid parameter");
 
-  surf_workstation_model->set_priority(action->surf_action,
-                                       priority);
+  surf_workstation_model->set_priority(action->surf_action, priority);
   return;
 }
 
@@ -268,7 +266,8 @@ void SIMIX_register_action_to_condition(smx_action_t action, smx_cond_t cond)
  *     \param action SIMIX action
  *     \param cond SIMIX cond
  */
-void SIMIX_unregister_action_to_condition(smx_action_t action, smx_cond_t cond)
+void SIMIX_unregister_action_to_condition(smx_action_t action,
+                                          smx_cond_t cond)
 {
   xbt_assert0((action != NULL) && (cond != NULL), "Invalid parameters");
 
@@ -298,7 +297,7 @@ void SIMIX_unregister_action_to_condition(smx_action_t action, smx_cond_t cond)
 double SIMIX_action_get_remains(smx_action_t action)
 {
   xbt_assert0((action != NULL), "Invalid parameter");
-  return action->surf_action->remains;
+  return surf_workstation_model->get_remains(action->surf_action);
 }
 
 smx_action_t SIMIX_action_parallel_execute(char *name, int host_nb,
@@ -325,10 +324,9 @@ smx_action_t SIMIX_action_parallel_execute(char *name, int host_nb,
     workstation_list[i] = host_list[i]->host;
 
   act->surf_action =
-    surf_workstation_model->extension.
-    workstation.execute_parallel_task(host_nb, workstation_list,
-                                      computation_amount,
-                                      communication_amount, amount, rate);
+    surf_workstation_model->extension.workstation.
+    execute_parallel_task(host_nb, workstation_list, computation_amount,
+                          communication_amount, amount, rate);
 
   surf_workstation_model->action_data_set(act->surf_action, act);
 
@@ -338,8 +336,7 @@ smx_action_t SIMIX_action_parallel_execute(char *name, int host_nb,
 e_surf_action_state_t SIMIX_action_get_state(smx_action_t action)
 {
   xbt_assert0((action != NULL), "Invalid parameter");
-  return surf_workstation_model->action_state_get(action->
-                                                  surf_action);
+  return surf_workstation_model->action_state_get(action->surf_action);
 }
 
 void __SIMIX_cond_display_actions(smx_cond_t cond)
@@ -362,7 +359,7 @@ void __SIMIX_action_display_conditions(smx_action_t action)
     DEBUG1("\t %p", cond);
 }
 
-char * SIMIX_action_get_name(smx_action_t action)
+char *SIMIX_action_get_name(smx_action_t action)
 {
   xbt_assert0((action != NULL), "Invalid parameter");
   return action->name;
@@ -372,7 +369,7 @@ void SIMIX_action_signal_all(smx_action_t action)
 {
   smx_cond_t cond;
 
-  while((cond = xbt_fifo_pop(action->cond_list)))
+  while ((cond = xbt_fifo_pop(action->cond_list)))
     SIMIX_cond_broadcast(cond);
 
   return;
index 622aeb8..cd3d2af 100644 (file)
@@ -87,14 +87,18 @@ static void parse_process_finalize(void)
     else
       process = SIMIX_process_create(parse_argv[0], parse_code, NULL, parse_host, parse_argc, parse_argv,       /*the props */
                                      current_property_set);
-
-    if (process && kill_time > SIMIX_get_clock()) {
-      if (simix_global->kill_process_function)
-        surf_timer_model->extension.timer.set(start_time, (void *)
+    /* verify if process has been created */
+    if (!process) {
+       xbt_free(parse_host);
+       return;
+    }
+    if (kill_time > SIMIX_get_clock()) {
+       if (simix_global->kill_process_function)
+               surf_timer_model->extension.timer.set(start_time, (void *)
                                               simix_global->kill_process_function,
                                               process);
-      else
-        surf_timer_model->extension.timer.set(kill_time, (void *)
+       else
+               surf_timer_model->extension.timer.set(kill_time, (void *)
                                               &SIMIX_process_kill,
                                               (void *) process);
     }
index 2adc9cb..4ae0157 100644 (file)
@@ -230,7 +230,7 @@ void SIMIX_clean(void)
   /* Kill everyone (except maestro) */
   SIMIX_process_killall();
 
-  /* Free the remaining data structures*/
+  /* Free the remaining data structures */
   xbt_swag_free(simix_global->process_to_run);
   xbt_swag_free(simix_global->process_to_destroy);
   xbt_swag_free(simix_global->process_list);
@@ -338,8 +338,40 @@ double SIMIX_solve(xbt_fifo_t actions_done, xbt_fifo_t actions_failed)
                                        args->data, args->hostname,
                                        args->argc, args->argv,
                                        args->properties);
-        if (process && args->kill_time > SIMIX_get_clock()) {
-          surf_timer_model->extension.timer.set(args->kill_time, (void *)
+        /* verify if process has been created */
+               if (!process) {
+                       xbt_free(args);
+                       continue;
+               }
+               if (args->kill_time > SIMIX_get_clock()) {
+                       surf_timer_model->extension.timer.set(args->kill_time, (void *)
+                                                                                               &SIMIX_process_kill,
+                                                                                               (void *) process);
+               }
+        xbt_free(args);
+      }
+      if (fun == simix_global->create_process_function) {
+        smx_process_arg_t args = arg;
+        DEBUG2("Launching %s on %s", args->name, args->hostname);
+        process =
+          (*simix_global->create_process_function) (args->name, args->code,
+                                                    args->data,
+                                                    args->hostname,
+                                                    args->argc, args->argv,
+                                                    args->properties);
+        /* verify if process has been created */
+        if (!process) {
+               xbt_free(args);
+               continue;
+        }
+        if (args->kill_time > SIMIX_get_clock()) {
+               if (simix_global->kill_process_function)
+                       surf_timer_model->extension.timer.set(args->kill_time, (void *)
+                                                simix_global->
+                                                kill_process_function,
+                                                process);
+               else
+                       surf_timer_model->extension.timer.set(args->kill_time, (void *)
                                                 &SIMIX_process_kill,
                                                 (void *) process);
         }
@@ -347,10 +379,13 @@ double SIMIX_solve(xbt_fifo_t actions_done, xbt_fifo_t actions_failed)
       }
       if (fun == SIMIX_process_kill) {
         process = arg;
-        DEBUG2("Killing %s on %s", process->name,
-               process->smx_host->name);
+        DEBUG2("Killing %s on %s", process->name, process->smx_host->name);
         SIMIX_process_kill(process);
       }
+      if (fun == simix_global->kill_process_function) {
+        process = arg;
+        (*simix_global->kill_process_function) (process);
+      }
     }
 
     /* Wake up all process waiting for the action finish */
index d8580f8..6a9f6e5 100644 (file)
@@ -7,7 +7,8 @@
 
 #include "surf_private.h"
 
-typedef s_surf_action_lmm_t s_surf_action_cpu_Cas01_t, *surf_action_cpu_Cas01_t;
+typedef s_surf_action_lmm_t s_surf_action_cpu_Cas01_t,
+  *surf_action_cpu_Cas01_t;
 
 typedef struct cpu_Cas01 {
   s_surf_resource_t generic_resource;
@@ -59,7 +60,8 @@ static cpu_Cas01_t cpu_new(char *name, double power_peak,
     lmm_constraint_new(cpu_maxmin_system, cpu,
                        cpu->power_scale * cpu->power_peak);
 
-  xbt_dict_set(surf_model_resource_set(surf_cpu_model), name, cpu, surf_resource_free);
+  xbt_dict_set(surf_model_resource_set(surf_cpu_model), name, cpu,
+               surf_resource_free);
 
   return cpu;
 }
@@ -130,6 +132,7 @@ static void define_callbacks(const char *file)
 {
   surf_parse_reset_parser();
   surfxml_add_callback(STag_surfxml_host_cb_list, parse_cpu_init);
+  surfxml_add_callback(ETag_surfxml_platform_cb_list, &add_traces_cpu);
 }
 
 static int resource_used(void *resource_id)
@@ -159,7 +162,7 @@ static void action_cancel(surf_action_t action)
 }
 
 static void cpu_action_state_set(surf_action_t action,
-                                e_surf_action_state_t state)
+                                 e_surf_action_state_t state)
 {
 /*   if((state==SURF_ACTION_DONE) || (state==SURF_ACTION_FAILED)) */
 /*     if(((surf_action_cpu_Cas01_t)action)->variable) { */
@@ -174,8 +177,8 @@ static void cpu_action_state_set(surf_action_t action,
 static double share_resources(double now)
 {
   s_surf_action_cpu_Cas01_t action;
-  return generic_maxmin_share_resources(surf_cpu_model->states.
-                                        running_action_set,
+  return generic_maxmin_share_resources(surf_cpu_model->
+                                        states.running_action_set,
                                         xbt_swag_offset(action, variable),
                                         cpu_maxmin_system, lmm_solve);
 }
@@ -215,6 +218,8 @@ static void update_resource_state(void *id,
     cpu->power_scale = value;
     lmm_update_constraint_bound(cpu_maxmin_system, cpu->constraint,
                                 cpu->power_scale * cpu->power_peak);
+    if (tmgr_trace_event_free(event_type))
+      cpu->power_event = NULL;
   } else if (event_type == cpu->state_event) {
     if (value > 0)
       cpu->state_current = SURF_RESOURCE_ON;
@@ -236,6 +241,8 @@ static void update_resource_state(void *id,
         }
       }
     }
+    if (tmgr_trace_event_free(event_type))
+      cpu->state_event = NULL;
   } else {
     CRITICAL0("Unknown event ! \n");
     xbt_abort();
@@ -250,8 +257,9 @@ static surf_action_t execute(void *cpu, double size)
   cpu_Cas01_t CPU = cpu;
 
   XBT_IN2("(%s,%g)", surf_resource_name(CPU), size);
-  action = surf_action_new(sizeof(s_surf_action_cpu_Cas01_t),size,surf_cpu_model,
-      CPU->state_current != SURF_RESOURCE_ON);
+  action =
+    surf_action_new(sizeof(s_surf_action_cpu_Cas01_t), size, surf_cpu_model,
+                    CPU->state_current != SURF_RESOURCE_ON);
 
   action->suspended = 0;        /* Should be useless because of the
                                    calloc but it seems to help valgrind... */
@@ -336,6 +344,13 @@ static void action_set_priority(surf_action_t action, double priority)
   XBT_OUT;
 }
 
+static double action_get_remains(surf_action_t action)
+{
+  XBT_IN1("(%p)", action);
+  return action->remains;
+  XBT_OUT;
+}
+
 static e_surf_resource_state_t get_state(void *cpu)
 {
   return ((cpu_Cas01_t) cpu)->state_current;
@@ -391,6 +406,8 @@ static void surf_cpu_model_init_internal(void)
   surf_cpu_model->is_suspended = action_is_suspended;
   surf_cpu_model->set_max_duration = action_set_max_duration;
   surf_cpu_model->set_priority = action_set_priority;
+  surf_cpu_model->get_remains = action_get_remains;
+
   surf_cpu_model->extension.cpu.execute = execute;
   surf_cpu_model->extension.cpu.sleep = action_sleep;
 
diff --git a/src/surf/cpu_im.c b/src/surf/cpu_im.c
new file mode 100644 (file)
index 0000000..730d969
--- /dev/null
@@ -0,0 +1,572 @@
+/*     $Id$     */
+
+/* Copyright (c) 2004 Arnaud Legrand. All rights reserved.                  */
+
+/* This program is free software; you can redistribute it and/or modify it
+ * under the terms of the license (GNU LGPL) which comes with this package. */
+
+#include "surf_private.h"
+
+#define GENERIC_LMM_ACTION(action) action->generic_lmm_action
+#define GENERIC_ACTION(action) GENERIC_LMM_ACTION(action).generic_action
+#define ACTION_GET_CPU(action) ((surf_action_cpu_Cas01_im_t) action)->cpu
+
+typedef struct surf_action_cpu_cas01_im {
+  s_surf_action_lmm_t generic_lmm_action;
+  s_xbt_swag_hookup_t cpu_list_hookup;
+  int index_heap;
+  void *cpu;
+} s_surf_action_cpu_Cas01_im_t, *surf_action_cpu_Cas01_im_t;
+
+typedef struct cpu_Cas01_im {
+  s_surf_resource_t generic_resource;
+  s_xbt_swag_hookup_t modified_cpu_hookup;
+  double power_peak;
+  double power_scale;
+  tmgr_trace_event_t power_event;
+  e_surf_resource_state_t state_current;
+  tmgr_trace_event_t state_event;
+  lmm_constraint_t constraint;
+  xbt_swag_t action_set;
+  double last_update;
+} s_cpu_Cas01_im_t, *cpu_Cas01_im_t;
+
+XBT_LOG_NEW_DEFAULT_SUBCATEGORY(surf_cpu_im, surf,
+                                "Logging specific to the SURF CPU IMPROVED module");
+
+
+lmm_system_t cpu_im_maxmin_system = NULL;
+static xbt_swag_t modified_cpu = NULL;
+static xbt_heap_t action_heap = NULL;
+extern int sg_maxmin_selective_update;
+
+
+static xbt_swag_t running_action_set_that_does_not_need_being_checked = NULL;
+
+static cpu_Cas01_im_t cpu_new(char *name, double power_peak,
+                              double power_scale,
+                              tmgr_trace_t power_trace,
+                              e_surf_resource_state_t state_initial,
+                              tmgr_trace_t state_trace,
+                              xbt_dict_t cpu_properties)
+{
+  cpu_Cas01_im_t cpu = xbt_new0(s_cpu_Cas01_im_t, 1);
+  s_surf_action_cpu_Cas01_im_t action;
+  xbt_assert1(!surf_model_resource_by_name(surf_cpu_model, name),
+              "Host '%s' declared several times in the platform file", name);
+  cpu->generic_resource.model = surf_cpu_model;
+  cpu->generic_resource.name = name;
+  cpu->generic_resource.properties = cpu_properties;
+  cpu->power_peak = power_peak;
+  xbt_assert0(cpu->power_peak > 0, "Power has to be >0");
+  cpu->power_scale = power_scale;
+  if (power_trace)
+    cpu->power_event =
+      tmgr_history_add_trace(history, power_trace, 0.0, 0, cpu);
+
+  cpu->state_current = state_initial;
+  if (state_trace)
+    cpu->state_event =
+      tmgr_history_add_trace(history, state_trace, 0.0, 0, cpu);
+
+  cpu->constraint =
+    lmm_constraint_new(cpu_im_maxmin_system, cpu,
+                       cpu->power_scale * cpu->power_peak);
+
+  xbt_dict_set(surf_model_resource_set(surf_cpu_model), name, cpu,
+               surf_resource_free);
+  cpu->action_set = xbt_swag_new(xbt_swag_offset(action, cpu_list_hookup));
+
+  return cpu;
+}
+
+
+static void parse_cpu_init(void)
+{
+  double power_peak = 0.0;
+  double power_scale = 0.0;
+  tmgr_trace_t power_trace = NULL;
+  e_surf_resource_state_t state_initial = SURF_RESOURCE_OFF;
+  tmgr_trace_t state_trace = NULL;
+
+  power_peak = get_cpu_power(A_surfxml_host_power);
+  surf_parse_get_double(&power_scale, A_surfxml_host_availability);
+  power_trace = tmgr_trace_new(A_surfxml_host_availability_file);
+
+  xbt_assert0((A_surfxml_host_state == A_surfxml_host_state_ON) ||
+              (A_surfxml_host_state == A_surfxml_host_state_OFF),
+              "Invalid state");
+  if (A_surfxml_host_state == A_surfxml_host_state_ON)
+    state_initial = SURF_RESOURCE_ON;
+  if (A_surfxml_host_state == A_surfxml_host_state_OFF)
+    state_initial = SURF_RESOURCE_OFF;
+  state_trace = tmgr_trace_new(A_surfxml_host_state_file);
+
+  current_property_set = xbt_dict_new();
+  cpu_new(xbt_strdup(A_surfxml_host_id), power_peak, power_scale,
+          power_trace, state_initial, state_trace, current_property_set);
+
+}
+
+static void add_traces_cpu(void)
+{
+  xbt_dict_cursor_t cursor = NULL;
+  char *trace_name, *elm;
+
+  static int called = 0;
+
+  if (called)
+    return;
+  called = 1;
+
+
+  /* connect all traces relative to hosts */
+  xbt_dict_foreach(trace_connect_list_host_avail, cursor, trace_name, elm) {
+    tmgr_trace_t trace = xbt_dict_get_or_null(traces_set_list, trace_name);
+    cpu_Cas01_im_t host = surf_model_resource_by_name(surf_cpu_model, elm);
+
+    xbt_assert1(host, "Host %s undefined", elm);
+    xbt_assert1(trace, "Trace %s undefined", trace_name);
+
+    host->state_event = tmgr_history_add_trace(history, trace, 0.0, 0, host);
+  }
+
+  xbt_dict_foreach(trace_connect_list_power, cursor, trace_name, elm) {
+    tmgr_trace_t trace = xbt_dict_get_or_null(traces_set_list, trace_name);
+    cpu_Cas01_im_t host = surf_model_resource_by_name(surf_cpu_model, elm);
+
+    xbt_assert1(host, "Host %s undefined", elm);
+    xbt_assert1(trace, "Trace %s undefined", trace_name);
+
+    host->power_event = tmgr_history_add_trace(history, trace, 0.0, 0, host);
+  }
+}
+
+static void define_callbacks(const char *file)
+{
+  surf_parse_reset_parser();
+  surfxml_add_callback(STag_surfxml_host_cb_list, parse_cpu_init);
+  surfxml_add_callback(ETag_surfxml_platform_cb_list, &add_traces_cpu);
+}
+
+static int resource_used(void *resource_id)
+{
+  return lmm_constraint_used(cpu_im_maxmin_system,
+                             ((cpu_Cas01_im_t) resource_id)->constraint);
+}
+
+static int action_unref(surf_action_t action)
+{
+  action->refcount--;
+  if (!action->refcount) {
+    xbt_swag_remove(action, action->state_set);
+    if (((surf_action_lmm_t) action)->variable)
+      lmm_variable_free(cpu_im_maxmin_system,
+                        ((surf_action_lmm_t) action)->variable);
+    /* remove from heap */
+    xbt_heap_remove(action_heap,
+                    ((surf_action_cpu_Cas01_im_t) action)->index_heap);
+    xbt_swag_remove(action,
+                    ((cpu_Cas01_im_t) ACTION_GET_CPU(action))->action_set);
+    xbt_swag_insert(ACTION_GET_CPU(action), modified_cpu);
+    free(action);
+    return 1;
+  }
+  return 0;
+}
+
+static void action_cancel(surf_action_t action)
+{
+  surf_action_state_set(action, SURF_ACTION_FAILED);
+  xbt_heap_remove(action_heap,
+                  ((surf_action_cpu_Cas01_im_t) action)->index_heap);
+  return;
+}
+
+static void cpu_action_state_set(surf_action_t action,
+                                 e_surf_action_state_t state)
+{
+/*   if((state==SURF_ACTION_DONE) || (state==SURF_ACTION_FAILED)) */
+/*     if(((surf_action_lmm_t)action)->variable) { */
+/*       lmm_variable_disable(cpu_im_maxmin_system, ((surf_action_lmm_t)action)->variable); */
+/*       ((surf_action_lmm_t)action)->variable = NULL; */
+/*     } */
+
+  surf_action_state_set(action, state);
+  return;
+}
+
+static void cpu_update_remains(cpu_Cas01_im_t cpu, double now)
+{
+  surf_action_cpu_Cas01_im_t action;
+
+  xbt_swag_foreach(action, cpu->action_set) {
+    if (GENERIC_ACTION(action).remains > 0) {
+      double_update(&(GENERIC_ACTION(action).remains),
+                    lmm_variable_getvalue(GENERIC_LMM_ACTION
+                                          (action).variable) * (now -
+                                                                cpu->
+                                                                last_update));
+      DEBUG2("Update action(%p) remains %lf", action,
+             GENERIC_ACTION(action).remains);
+    }
+  }
+  cpu->last_update = now;
+}
+
+static double share_resources(double now)
+{
+  surf_action_cpu_Cas01_im_t action;
+  double min;
+  double value;
+  cpu_Cas01_im_t cpu, cpu_next;
+
+  xbt_swag_foreach_safe(cpu, cpu_next, modified_cpu) {
+    cpu_update_remains(cpu, now);
+    xbt_swag_remove(cpu, modified_cpu);
+  }
+
+  lmm_solve(cpu_im_maxmin_system);
+
+  while ((action = lmm_extract_modified_variable(cpu_im_maxmin_system))) {
+    min = -1;
+    value = lmm_variable_getvalue(GENERIC_LMM_ACTION(action).variable);
+    if (value > 0) {
+      if (GENERIC_ACTION(action).remains > 0)
+        value = GENERIC_ACTION(action).remains / value;
+      else
+        value = 0.0;
+    }
+    if (value > 0)
+      min = now + value;
+
+    if ((GENERIC_ACTION(action).max_duration != NO_MAX_DURATION)
+        && (min == -1
+            || GENERIC_ACTION(action).start +
+            GENERIC_ACTION(action).max_duration < min))
+      min =
+        GENERIC_ACTION(action).start + GENERIC_ACTION(action).max_duration;
+
+    DEBUG4("Action(%p) Start %lf Finish %lf Max_duration %lf", action,
+           GENERIC_ACTION(action).start, now + value,
+           GENERIC_ACTION(action).max_duration);
+
+    if (action->index_heap >= 0) {
+      surf_action_cpu_Cas01_im_t heap_act =
+        xbt_heap_remove(action_heap, action->index_heap);
+      if (heap_act != action)
+        DIE_IMPOSSIBLE;
+    }
+    if (min != -1) {
+      xbt_heap_push(action_heap, action, min);
+      DEBUG2("Insert at heap action(%p) min %lf", action, min);
+    }
+  }
+  return xbt_heap_size(action_heap) >
+    0 ? xbt_heap_maxkey(action_heap) - now : -1;
+}
+
+static void update_actions_state(double now, double delta)
+{
+  surf_action_cpu_Cas01_im_t action;
+
+  while ((xbt_heap_size(action_heap) > 0)
+         && (xbt_heap_maxkey(action_heap) <= now)) {
+    action = xbt_heap_pop(action_heap);
+    DEBUG1("Action %p: finish", action);
+    GENERIC_ACTION(action).finish = surf_get_clock();
+    /* set the remains to 0 due to precision problems when updating the remaining amount */
+    GENERIC_ACTION(action).remains = 0;
+    cpu_action_state_set((surf_action_t) action, SURF_ACTION_DONE);
+    xbt_swag_insert(action->cpu, modified_cpu);
+  }
+  return;
+}
+
+static void update_resource_state(void *id,
+                                  tmgr_trace_event_t event_type,
+                                  double value, double date)
+{
+  cpu_Cas01_im_t cpu = id;
+
+  if (event_type == cpu->power_event) {
+    cpu->power_scale = value;
+    lmm_update_constraint_bound(cpu_im_maxmin_system, cpu->constraint,
+                                cpu->power_scale * cpu->power_peak);
+    xbt_swag_insert(cpu, modified_cpu);
+    if (tmgr_trace_event_free(event_type))
+      cpu->power_event = NULL;
+  } else if (event_type == cpu->state_event) {
+    if (value > 0)
+      cpu->state_current = SURF_RESOURCE_ON;
+    else {
+      lmm_constraint_t cnst = cpu->constraint;
+      lmm_variable_t var = NULL;
+      lmm_element_t elem = NULL;
+
+      cpu->state_current = SURF_RESOURCE_OFF;
+
+      while ((var = lmm_get_var_from_cnst(cpu_im_maxmin_system, cnst, &elem))) {
+        surf_action_t action = lmm_variable_id(var);
+
+        if (surf_action_state_get(action) == SURF_ACTION_RUNNING ||
+            surf_action_state_get(action) == SURF_ACTION_READY ||
+            surf_action_state_get(action) == SURF_ACTION_NOT_IN_THE_SYSTEM) {
+          action->finish = date;
+          cpu_action_state_set(action, SURF_ACTION_FAILED);
+        }
+      }
+    }
+    if (tmgr_trace_event_free(event_type))
+      cpu->state_event = NULL;
+  } else {
+    CRITICAL0("Unknown event ! \n");
+    xbt_abort();
+  }
+
+  return;
+}
+
+static surf_action_t execute(void *cpu, double size)
+{
+  surf_action_cpu_Cas01_im_t action = NULL;
+  cpu_Cas01_im_t CPU = cpu;
+
+  XBT_IN2("(%s,%g)", surf_resource_name(CPU), size);
+  action =
+    surf_action_new(sizeof(s_surf_action_cpu_Cas01_im_t), size,
+                    surf_cpu_model, CPU->state_current != SURF_RESOURCE_ON);
+
+  GENERIC_LMM_ACTION(action).suspended = 0;     /* Should be useless because of the
+                                                   calloc but it seems to help valgrind... */
+
+  GENERIC_LMM_ACTION(action).variable =
+    lmm_variable_new(cpu_im_maxmin_system, action,
+                     GENERIC_ACTION(action).priority, -1.0, 1);
+  action->index_heap = -1;
+  action->cpu = CPU;
+  xbt_swag_insert(CPU, modified_cpu);
+  xbt_swag_insert(action, CPU->action_set);
+  lmm_expand(cpu_im_maxmin_system, CPU->constraint,
+             GENERIC_LMM_ACTION(action).variable, 1.0);
+  XBT_OUT;
+  return (surf_action_t) action;
+}
+
+static surf_action_t action_sleep(void *cpu, double duration)
+{
+  surf_action_cpu_Cas01_im_t action = NULL;
+
+  if (duration > 0)
+    duration = MAX(duration, MAXMIN_PRECISION);
+
+  XBT_IN2("(%s,%g)", surf_resource_name(cpu), duration);
+  action = (surf_action_cpu_Cas01_im_t) execute(cpu, 1.0);
+  GENERIC_ACTION(action).max_duration = duration;
+  GENERIC_LMM_ACTION(action).suspended = 2;
+  if (duration == NO_MAX_DURATION) {
+    /* Move to the *end* of the corresponding action set. This convention
+       is used to speed up update_resource_state  */
+    xbt_swag_remove(action, ((surf_action_t) action)->state_set);
+    ((surf_action_t) action)->state_set =
+      running_action_set_that_does_not_need_being_checked;
+    xbt_swag_insert(action, ((surf_action_t) action)->state_set);
+  }
+
+  lmm_update_variable_weight(cpu_im_maxmin_system,
+                             GENERIC_LMM_ACTION(action).variable, 0.0);
+  xbt_swag_insert(cpu, modified_cpu);
+  XBT_OUT;
+  return (surf_action_t) action;
+}
+
+static void action_suspend(surf_action_t action)
+{
+  XBT_IN1("(%p)", action);
+  if (((surf_action_lmm_t) action)->suspended != 2) {
+    lmm_update_variable_weight(cpu_im_maxmin_system,
+                               ((surf_action_lmm_t) action)->variable, 0.0);
+    ((surf_action_lmm_t) action)->suspended = 1;
+    xbt_swag_insert(ACTION_GET_CPU(action), modified_cpu);
+  }
+  XBT_OUT;
+}
+
+static void action_resume(surf_action_t action)
+{
+  XBT_IN1("(%p)", action);
+  if (((surf_action_lmm_t) action)->suspended != 2) {
+    lmm_update_variable_weight(cpu_im_maxmin_system,
+                               ((surf_action_lmm_t) action)->variable,
+                               action->priority);
+    ((surf_action_lmm_t) action)->suspended = 0;
+    xbt_swag_insert(ACTION_GET_CPU(action), modified_cpu);
+  }
+  XBT_OUT;
+}
+
+static int action_is_suspended(surf_action_t action)
+{
+  return (((surf_action_lmm_t) action)->suspended == 1);
+}
+
+static void action_set_max_duration(surf_action_t action, double duration)
+{
+  surf_action_cpu_Cas01_im_t ACT = (surf_action_cpu_Cas01_im_t) action;
+  double min_finish;
+
+  XBT_IN2("(%p,%g)", action, duration);
+
+  action->max_duration = duration;
+
+  if (duration >= 0)
+    min_finish =
+      (action->start + action->max_duration) <
+      action->finish ? (action->start +
+                        action->max_duration) : action->finish;
+  else
+    min_finish = action->finish;
+
+  /* add in action heap */
+  if (ACT->index_heap >= 0) {
+    surf_action_cpu_Cas01_im_t heap_act =
+      xbt_heap_remove(action_heap, ACT->index_heap);
+    if (heap_act != ACT)
+      DIE_IMPOSSIBLE;
+  }
+  xbt_heap_push(action_heap, ACT, min_finish);
+  XBT_OUT;
+}
+
+static void action_set_priority(surf_action_t action, double priority)
+{
+  XBT_IN2("(%p,%g)", action, priority);
+  action->priority = priority;
+  lmm_update_variable_weight(cpu_im_maxmin_system,
+                             ((surf_action_lmm_t) action)->variable,
+                             priority);
+
+  xbt_swag_insert(ACTION_GET_CPU(action), modified_cpu);
+  XBT_OUT;
+}
+
+static double action_get_remains(surf_action_t action)
+{
+  XBT_IN1("(%p)", action);
+  cpu_update_remains(ACTION_GET_CPU(action), surf_get_clock());
+  return action->remains;
+  XBT_OUT;
+}
+
+static e_surf_resource_state_t get_state(void *cpu)
+{
+  return ((cpu_Cas01_im_t) cpu)->state_current;
+}
+
+static double get_speed(void *cpu, double load)
+{
+  return load * (((cpu_Cas01_im_t) cpu)->power_peak);
+}
+
+static double get_available_speed(void *cpu)
+{
+  /* number between 0 and 1 */
+  return ((cpu_Cas01_im_t) cpu)->power_scale;
+}
+
+static void action_update_index_heap(void *action, int i)
+{
+  ((surf_action_cpu_Cas01_im_t) action)->index_heap = i;
+}
+
+static void finalize(void)
+{
+  void *cpu;
+  xbt_dict_cursor_t cursor;
+  char *key;
+  xbt_dict_foreach(surf_model_resource_set(surf_cpu_model), cursor, key, cpu) {
+    cpu_Cas01_im_t CPU = cpu;
+    xbt_swag_free(CPU->action_set);
+  }
+
+  lmm_system_free(cpu_im_maxmin_system);
+  cpu_im_maxmin_system = NULL;
+
+  surf_model_exit(surf_cpu_model);
+  surf_cpu_model = NULL;
+
+  xbt_swag_free(running_action_set_that_does_not_need_being_checked);
+  running_action_set_that_does_not_need_being_checked = NULL;
+  xbt_heap_free(action_heap);
+  xbt_swag_free(modified_cpu);
+}
+
+static void surf_cpu_model_init_internal(void)
+{
+  s_surf_action_t action;
+  s_cpu_Cas01_im_t cpu;
+
+  surf_cpu_model = surf_model_init();
+
+  running_action_set_that_does_not_need_being_checked =
+    xbt_swag_new(xbt_swag_offset(action, state_hookup));
+
+  surf_cpu_model->name = "CPU_IM";
+
+  surf_cpu_model->action_unref = action_unref;
+  surf_cpu_model->action_cancel = action_cancel;
+  surf_cpu_model->action_state_set = cpu_action_state_set;
+
+  surf_cpu_model->model_private->resource_used = resource_used;
+  surf_cpu_model->model_private->share_resources = share_resources;
+  surf_cpu_model->model_private->update_actions_state = update_actions_state;
+  surf_cpu_model->model_private->update_resource_state =
+    update_resource_state;
+  surf_cpu_model->model_private->finalize = finalize;
+
+  surf_cpu_model->suspend = action_suspend;
+  surf_cpu_model->resume = action_resume;
+  surf_cpu_model->is_suspended = action_is_suspended;
+  surf_cpu_model->set_max_duration = action_set_max_duration;
+  surf_cpu_model->set_priority = action_set_priority;
+  surf_cpu_model->get_remains = action_get_remains;
+
+  surf_cpu_model->extension.cpu.execute = execute;
+  surf_cpu_model->extension.cpu.sleep = action_sleep;
+
+  surf_cpu_model->extension.cpu.get_state = get_state;
+  surf_cpu_model->extension.cpu.get_speed = get_speed;
+  surf_cpu_model->extension.cpu.get_available_speed = get_available_speed;
+
+  if (!cpu_im_maxmin_system) {
+    sg_maxmin_selective_update = 1;
+    cpu_im_maxmin_system = lmm_system_new();
+  }
+  action_heap = xbt_heap_new(8, NULL);
+  xbt_heap_set_update_callback(action_heap, action_update_index_heap);
+  modified_cpu = xbt_swag_new(xbt_swag_offset(cpu, modified_cpu_hookup));
+}
+
+/*********************************************************************/
+/* Basic sharing model for CPU: that is where all this started... ;) */
+/*********************************************************************/
+/* @InProceedings{casanova01simgrid, */
+/*   author =       "H. Casanova", */
+/*   booktitle =    "Proceedings of the IEEE Symposium on Cluster Computing */
+/*                  and the Grid (CCGrid'01)", */
+/*   publisher =    "IEEE Computer Society", */
+/*   title =        "Simgrid: {A} Toolkit for the Simulation of Application */
+/*                  Scheduling", */
+/*   year =         "2001", */
+/*   month =        may, */
+/*   note =         "Available at */
+/*                  \url{http://grail.sdsc.edu/papers/simgrid_ccgrid01.ps.gz}." */
+/* } */
+void surf_cpu_model_init_Cas01_im(const char *filename)
+{
+  if (surf_cpu_model)
+    return;
+  surf_cpu_model_init_internal();
+  define_callbacks(filename);
+  xbt_dynar_push(model_list, &surf_cpu_model);
+}
diff --git a/src/surf/cpu_ti.c b/src/surf/cpu_ti.c
new file mode 100644 (file)
index 0000000..63b4b38
--- /dev/null
@@ -0,0 +1,1265 @@
+
+/*     $Id$     */
+
+/* Copyright (c) 2004 Arnaud Legrand. All rights reserved.                  */
+
+/* This program is free software; you can redistribute it and/or modify it
+ * under the terms of the license (GNU LGPL) which comes with this package. */
+
+#include "surf_private.h"
+#include "trace_mgr_private.h"
+#include "cpu_ti_private.h"
+#include "xbt/heap.h"
+
+
+XBT_LOG_NEW_DEFAULT_SUBCATEGORY(surf_cpu_ti, surf,
+                                "Logging specific to the SURF CPU TRACE INTEGRATION module");
+
+
+static xbt_swag_t running_action_set_that_does_not_need_being_checked = NULL;
+static xbt_swag_t modified_cpu = NULL;
+static xbt_heap_t action_heap;
+
+/* prototypes of new trace functions */
+static double surf_cpu_integrate_trace(surf_cpu_ti_tgmr_t trace, double a,
+                                       double b);
+static double surf_cpu_integrate_trace_simple(surf_cpu_ti_tgmr_t trace,
+                                              double a, double b);
+
+
+static double surf_cpu_solve_trace(surf_cpu_ti_tgmr_t trace, double a,
+                                   double amount);
+static double surf_cpu_solve_trace_somewhat_simple(surf_cpu_ti_tgmr_t trace,
+                                                   double a, double amount);
+static double surf_cpu_solve_trace_simple(surf_cpu_ti_tgmr_t trace, double a,
+                                          double amount);
+
+static void surf_cpu_free_trace(surf_cpu_ti_tgmr_t trace);
+static void surf_cpu_free_time_series(surf_cpu_ti_timeSeries_t timeSeries);
+/* end prototypes */
+
+static void surf_cpu_free_time_series(surf_cpu_ti_timeSeries_t timeSeries)
+{
+  xbt_free(timeSeries->values);
+  xbt_free(timeSeries);
+}
+
+static void surf_cpu_free_trace(surf_cpu_ti_tgmr_t trace)
+{
+  int i;
+
+  for (i = 0; i < trace->nb_levels; i++)
+    surf_cpu_free_time_series(trace->levels[i]);
+
+  xbt_free(trace->levels);
+  xbt_free(trace);
+}
+
+static surf_cpu_ti_timeSeries_t surf_cpu_ti_time_series_new(tmgr_trace_t
+                                                            power_trace,
+                                                            double spacing)
+{
+  surf_cpu_ti_timeSeries_t series;
+  double time, value;
+  double previous_time = 0.0;
+  unsigned int cpt;
+  s_tmgr_event_t val;
+  series = xbt_new0(s_surf_cpu_ti_timeSeries_t, 1);
+  series->spacing = spacing;
+
+  time = 0.0;
+  xbt_dynar_foreach(power_trace->event_list, cpt, val) {
+    /* delta = the next trace event
+     * value = state until next event */
+    time += val.delta;
+    value = val.value;
+
+    /* ignore events if time is less than spacing */
+    if (time < (series->nb_points) * spacing) {
+      continue;
+    }
+
+    while (previous_time < time) {
+      series->values = xbt_realloc(series->values,
+                                   (series->nb_points + 1) * sizeof(double));
+      series->values[(series->nb_points)++] = value;
+      previous_time += spacing;
+    }
+  }
+
+  return series;
+}
+
+/**
+ * \brief Create new levels of points.
+ *
+ * This function assumes that the input series is
+ * evenly spaces, starting at time 0. That is the sort
+ * of series produced by surf_cpu_ti_time_series_new()
+ *
+ * \param      original        Original timeSeries structure
+ * \param      factor          New factor to spacing
+ * \return                                     New timeSeries structure with spacing*factor
+ */
+static surf_cpu_ti_timeSeries_t
+surf_cpu_ti_time_series_coarsen(surf_cpu_ti_timeSeries_t original, int factor)
+{
+  surf_cpu_ti_timeSeries_t series;
+  int j, i = 0;
+  double dfactor = (double) (factor);
+  double ave;
+
+  if (original->nb_points <= factor) {
+    DEBUG0("Warning: Not enough data points to coarsen time series");
+    return NULL;
+  }
+
+  series = xbt_new0(s_surf_cpu_ti_timeSeries_t, 1);
+  series->spacing = (original->spacing) * dfactor;
+
+  while (i + factor <= original->nb_points) {
+    /* Averaging */
+    ave = 0.0;
+    for (j = i; j < i + factor; j++) {
+      ave += original->values[j];
+    }
+    ave /= dfactor;
+    /* Updating */
+    series->values = xbt_realloc(series->values,
+                                 (series->nb_points + 1) * sizeof(double));
+    series->values[(series->nb_points)++] = ave;
+    i += factor;
+  }
+
+  return series;
+}
+
+/**
+ * \brief Create a new integration trace from a tmgr_trace_t
+ *
+ * \param      power_trace             CPU availability trace
+ * \param      value                                   Percentage of CPU power disponible (usefull to fixed tracing)
+ * \param      spacing                         Initial spacing
+ * \return     Integration trace structure
+ */
+static surf_cpu_ti_tgmr_t cpu_ti_parse_trace(tmgr_trace_t power_trace,
+                                             double value)
+{
+  surf_cpu_ti_tgmr_t trace;
+  surf_cpu_ti_timeSeries_t series;
+  int i;
+  trace = xbt_new0(s_surf_cpu_ti_tgmr_t, 1);
+
+  /* no availability file, fixed trace */
+  if (!power_trace) {
+    trace->type = TRACE_FIXED;
+    trace->value = value;
+    DEBUG1("No availabily trace. Constant value = %lf", value);
+    return trace;
+  }
+
+  DEBUG2("Value %lf, Spacing %lf", value, power_trace->timestep);
+  series = surf_cpu_ti_time_series_new(power_trace, power_trace->timestep);
+  if (!series)
+    return NULL;
+
+  trace->type = TRACE_DYNAMIC;
+
+  trace->levels = xbt_new0(surf_cpu_ti_timeSeries_t, 1);
+  trace->levels[(trace->nb_levels)++] = series;
+
+  /* Do the coarsening with some arbitrary factors */
+  for (i = 1; i < TRACE_NB_LEVELS; i++) {
+    series = surf_cpu_ti_time_series_coarsen(trace->levels[i - 1], 4 * i);
+
+    if (series) {               /* If coarsening was possible, add it */
+      trace->levels = xbt_realloc(trace->levels,
+                                  (trace->nb_levels +
+                                   1) * sizeof(s_surf_cpu_ti_timeSeries_t));
+      trace->levels[(trace->nb_levels)++] = series;
+    } else {                    /* otherwise stop */
+      break;
+    }
+  }
+
+  /* calcul of initial integrate */
+  trace->last_time =
+    power_trace->timestep * ((double) (trace->levels[0]->nb_points));
+  trace->total = surf_cpu_integrate_trace(trace, 0.0, trace->last_time);
+
+  return trace;
+}
+
+
+static cpu_ti_t cpu_new(char *name, double power_peak,
+                        double power_scale,
+                        tmgr_trace_t power_trace,
+                        e_surf_resource_state_t state_initial,
+                        tmgr_trace_t state_trace, xbt_dict_t cpu_properties)
+{
+  cpu_ti_t cpu = xbt_new0(s_cpu_ti_t, 1);
+  s_surf_action_cpu_ti_t ti_action;
+  xbt_assert1(!surf_model_resource_by_name(surf_cpu_model, name),
+              "Host '%s' declared several times in the platform file", name);
+  cpu->action_set = xbt_swag_new(xbt_swag_offset(ti_action, cpu_list_hookup));
+  cpu->generic_resource.model = surf_cpu_model;
+  cpu->generic_resource.name = name;
+  cpu->generic_resource.properties = cpu_properties;
+  cpu->power_peak = power_peak;
+  xbt_assert0(cpu->power_peak > 0, "Power has to be >0");
+  DEBUG1("power scale %lf", power_scale);
+  cpu->power_scale = power_scale;
+  cpu->avail_trace = cpu_ti_parse_trace(power_trace, power_scale);
+  cpu->state_current = state_initial;
+  if (state_trace)
+    cpu->state_event =
+      tmgr_history_add_trace(history, state_trace, 0.0, 0, cpu);
+
+  xbt_dict_set(surf_model_resource_set(surf_cpu_model), name, cpu,
+               surf_resource_free);
+
+  return cpu;
+}
+
+
+static void parse_cpu_init(void)
+{
+  double power_peak = 0.0;
+  double power_scale = 0.0;
+  tmgr_trace_t power_trace = NULL;
+  e_surf_resource_state_t state_initial = SURF_RESOURCE_OFF;
+  tmgr_trace_t state_trace = NULL;
+
+  power_peak = get_cpu_power(A_surfxml_host_power);
+  surf_parse_get_double(&power_scale, A_surfxml_host_availability);
+  power_trace = tmgr_trace_new(A_surfxml_host_availability_file);
+
+  xbt_assert0((A_surfxml_host_state == A_surfxml_host_state_ON) ||
+              (A_surfxml_host_state == A_surfxml_host_state_OFF),
+              "Invalid state");
+  if (A_surfxml_host_state == A_surfxml_host_state_ON)
+    state_initial = SURF_RESOURCE_ON;
+  if (A_surfxml_host_state == A_surfxml_host_state_OFF)
+    state_initial = SURF_RESOURCE_OFF;
+  state_trace = tmgr_trace_new(A_surfxml_host_state_file);
+
+  current_property_set = xbt_dict_new();
+  cpu_new(xbt_strdup(A_surfxml_host_id), power_peak, power_scale,
+          power_trace, state_initial, state_trace, current_property_set);
+
+}
+
+static void add_traces_cpu(void)
+{
+  xbt_dict_cursor_t cursor = NULL;
+  char *trace_name, *elm;
+
+  static int called = 0;
+
+  if (called)
+    return;
+  called = 1;
+
+  /* connect all traces relative to hosts */
+  xbt_dict_foreach(trace_connect_list_host_avail, cursor, trace_name, elm) {
+    tmgr_trace_t trace = xbt_dict_get_or_null(traces_set_list, trace_name);
+    cpu_ti_t cpu = surf_model_resource_by_name(surf_cpu_model, elm);
+
+    xbt_assert1(cpu, "Host %s undefined", elm);
+    xbt_assert1(trace, "Trace %s undefined", trace_name);
+
+    if (cpu->state_event) {
+      DEBUG1("Trace already configured for this CPU(%s), ignoring it", elm);
+      continue;
+    }
+    DEBUG2("Add state trace: %s to CPU(%s)", trace_name, elm);
+    cpu->state_event = tmgr_history_add_trace(history, trace, 0.0, 0, cpu);
+  }
+
+  xbt_dict_foreach(trace_connect_list_power, cursor, trace_name, elm) {
+    tmgr_trace_t trace = xbt_dict_get_or_null(traces_set_list, trace_name);
+    cpu_ti_t cpu = surf_model_resource_by_name(surf_cpu_model, elm);
+
+    xbt_assert1(cpu, "Host %s undefined", elm);
+    xbt_assert1(trace, "Trace %s undefined", trace_name);
+
+    DEBUG2("Add power trace: %s to CPU(%s)", trace_name, elm);
+    if (cpu->avail_trace)
+      surf_cpu_free_trace(cpu->avail_trace);
+
+    cpu->avail_trace = cpu_ti_parse_trace(trace, cpu->power_scale);
+  }
+}
+
+static void define_callbacks(const char *file)
+{
+  surf_parse_reset_parser();
+  surfxml_add_callback(STag_surfxml_host_cb_list, parse_cpu_init);
+  surfxml_add_callback(ETag_surfxml_platform_cb_list, &add_traces_cpu);
+}
+
+static int resource_used(void *resource_id)
+{
+  cpu_ti_t cpu = resource_id;
+  return xbt_swag_size(cpu->action_set);
+}
+
+static int action_unref(surf_action_t action)
+{
+  action->refcount--;
+  if (!action->refcount) {
+    xbt_swag_remove(action, action->state_set);
+    /* remove from action_set */
+    xbt_swag_remove(action, ACTION_GET_CPU(action)->action_set);
+    /* remove from heap */
+    xbt_heap_remove(action_heap, ((surf_action_cpu_ti_t) action)->index_heap);
+    xbt_swag_insert(ACTION_GET_CPU(action), modified_cpu);
+    free(action);
+    return 1;
+  }
+  return 0;
+}
+
+static void action_cancel(surf_action_t action)
+{
+  surf_action_state_set(action, SURF_ACTION_FAILED);
+  xbt_heap_remove(action_heap, ((surf_action_cpu_ti_t) action)->index_heap);
+  xbt_swag_insert(ACTION_GET_CPU(action), modified_cpu);
+  return;
+}
+
+static void cpu_action_state_set(surf_action_t action,
+                                 e_surf_action_state_t state)
+{
+  surf_action_state_set(action, state);
+  xbt_swag_insert(ACTION_GET_CPU(action), modified_cpu);
+  return;
+}
+
+/**
+ * \brief Update the remaning amount of actions
+ *
+ * \param      cpu             Cpu on which the actions are running
+ * \param      now             Current time
+ */
+static void cpu_update_remaining_amount(cpu_ti_t cpu, double now)
+{
+#define GENERIC_ACTION(action) action->generic_action
+  double area_total;
+  surf_action_cpu_ti_t action;
+
+  /* alrealdy updated */
+  if (cpu->last_update == now)
+    return;
+
+  /* calcule the surface */
+  area_total =
+    surf_cpu_integrate_trace(cpu->avail_trace, cpu->last_update,
+                             now) * cpu->power_peak;
+  DEBUG2("Flops total: %lf, Last update %lf", area_total, cpu->last_update);
+
+  xbt_swag_foreach(action, cpu->action_set) {
+    /* action not running, skip it */
+    if (GENERIC_ACTION(action).state_set !=
+        surf_cpu_model->states.running_action_set)
+      continue;
+
+    /* bogus priority, skip it */
+    if (GENERIC_ACTION(action).priority <= 0)
+      continue;
+
+    /* action suspended, skip it */
+    if (action->suspended != 0)
+      continue;
+
+    /* action don't need update */
+    if (GENERIC_ACTION(action).start >= now)
+      continue;
+
+    /* skip action that are finishing now */
+    if (GENERIC_ACTION(action).finish >= 0
+        && GENERIC_ACTION(action).finish <= now)
+      continue;
+
+    /* update remaining */
+    double_update(&(GENERIC_ACTION(action).remains),
+                  area_total / (cpu->sum_priority *
+                                GENERIC_ACTION(action).priority));
+    DEBUG2("Update remaining action(%p) remaining %lf", action,
+           GENERIC_ACTION(action).remains);
+  }
+  cpu->last_update = now;
+#undef GENERIC_ACTION
+}
+
+/**
+ * \brief Update the finish date of action if necessary
+ *
+ * \param      cpu             Cpu on which the actions are running
+ * \param      now             Current time
+ */
+static void cpu_update_action_finish_date(cpu_ti_t cpu, double now)
+{
+#define GENERIC_ACTION(action) action->generic_action
+  surf_action_cpu_ti_t action;
+  double sum_priority = 0.0, total_area, min_finish = -1;
+
+  /* update remaning amount of actions */
+  cpu_update_remaining_amount(cpu, now);
+
+  xbt_swag_foreach(action, cpu->action_set) {
+    /* action not running, skip it */
+    if (GENERIC_ACTION(action).state_set !=
+        surf_cpu_model->states.running_action_set)
+      continue;
+
+    /* bogus priority, skip it */
+    if (GENERIC_ACTION(action).priority <= 0)
+      continue;
+
+    /* action suspended, skip it */
+    if (action->suspended != 0)
+      continue;
+
+    sum_priority += 1.0 / GENERIC_ACTION(action).priority;
+  }
+  cpu->sum_priority = sum_priority;
+
+  xbt_swag_foreach(action, cpu->action_set) {
+    /* action not running, skip it */
+    if (GENERIC_ACTION(action).state_set !=
+        surf_cpu_model->states.running_action_set)
+      continue;
+
+    /* verify if the action is really running on cpu */
+    if (action->suspended == 0 && GENERIC_ACTION(action).priority > 0) {
+      /* total area needed to finish the action. Used in trace integration */
+      total_area =
+        (GENERIC_ACTION(action).remains) * sum_priority *
+        GENERIC_ACTION(action).priority;
+
+      total_area /= cpu->power_peak;
+
+      GENERIC_ACTION(action).finish =
+        surf_cpu_solve_trace(cpu->avail_trace, now, total_area);
+      /* verify which event will happen before (max_duration or finish time) */
+      if ((GENERIC_ACTION(action).max_duration != NO_MAX_DURATION) &&
+          (GENERIC_ACTION(action).start +
+           GENERIC_ACTION(action).max_duration <
+           GENERIC_ACTION(action).finish))
+        min_finish = GENERIC_ACTION(action).start +
+          GENERIC_ACTION(action).max_duration;
+      else
+        min_finish = GENERIC_ACTION(action).finish;
+    } else {
+      /* put the max duration time on heap */
+      if (GENERIC_ACTION(action).max_duration != NO_MAX_DURATION)
+        min_finish =
+          (GENERIC_ACTION(action).start +
+           GENERIC_ACTION(action).max_duration);
+    }
+    /* add in action heap */
+    DEBUG2("action(%p) index %d", action, action->index_heap);
+    if (action->index_heap >= 0) {
+      surf_action_cpu_ti_t heap_act =
+        xbt_heap_remove(action_heap, action->index_heap);
+      if (heap_act != action)
+        DIE_IMPOSSIBLE;
+    }
+    if (min_finish != NO_MAX_DURATION)
+      xbt_heap_push(action_heap, action, min_finish);
+
+    DEBUG4
+      ("Update finish time: Action: %p, Start Time: %lf Finish Time: %lf Max duration %lf",
+       action, GENERIC_ACTION(action).start, GENERIC_ACTION(action).finish,
+       GENERIC_ACTION(action).max_duration);
+  }
+  /* remove from modified cpu */
+  xbt_swag_remove(cpu, modified_cpu);
+#undef GENERIC_ACTION
+}
+
+static double share_resources(double now)
+{
+  cpu_ti_t cpu, cpu_next;
+  double min_action_duration = -1;
+
+  /* iterates over modified cpus to update share resources */
+  xbt_swag_foreach_safe(cpu, cpu_next, modified_cpu) {
+    cpu_update_action_finish_date(cpu, now);
+  }
+  /* get the min next event if heap not empty */
+  if (xbt_heap_size(action_heap) > 0)
+    min_action_duration = xbt_heap_maxkey(action_heap) - now;
+
+  DEBUG1("Share resources, min next event date: %lf", min_action_duration);
+
+  return min_action_duration;
+}
+
+static void update_actions_state(double now, double delta)
+{
+#define GENERIC_ACTION(action) action->generic_action
+  surf_action_cpu_ti_t action;
+  while ((xbt_heap_size(action_heap) > 0)
+         && (xbt_heap_maxkey(action_heap) <= now)) {
+    DEBUG1("Action %p: finish", action);
+    action = xbt_heap_pop(action_heap);
+    GENERIC_ACTION(action).finish = surf_get_clock();
+    /* set the remains to 0 due to precision problems when updating the remaining amount */
+    GENERIC_ACTION(action).remains = 0;
+    cpu_action_state_set((surf_action_t) action, SURF_ACTION_DONE);
+    /* update remaining amout of all actions */
+    cpu_update_remaining_amount(action->cpu, surf_get_clock());
+  }
+#undef GENERIC_ACTION
+}
+
+static void update_resource_state(void *id,
+                                  tmgr_trace_event_t event_type,
+                                  double value, double date)
+{
+  cpu_ti_t cpu = id;
+  surf_action_cpu_ti_t action;
+  if (event_type == cpu->state_event) {
+    if (value > 0)
+      cpu->state_current = SURF_RESOURCE_ON;
+    else {
+      cpu->state_current = SURF_RESOURCE_OFF;
+
+      /* put all action running on cpu to failed */
+      xbt_swag_foreach(action, cpu->action_set) {
+        if (surf_action_state_get((surf_action_t) action) ==
+            SURF_ACTION_RUNNING
+            || surf_action_state_get((surf_action_t) action) ==
+            SURF_ACTION_READY
+            || surf_action_state_get((surf_action_t) action) ==
+            SURF_ACTION_NOT_IN_THE_SYSTEM) {
+          action->generic_action.finish = date;
+          cpu_action_state_set((surf_action_t) action, SURF_ACTION_FAILED);
+          if (action->index_heap >= 0) {
+            surf_action_cpu_ti_t heap_act =
+              xbt_heap_remove(action_heap, action->index_heap);
+            if (heap_act != action)
+              DIE_IMPOSSIBLE;
+          }
+        }
+      }
+    }
+    if (tmgr_trace_event_free(event_type))
+      cpu->state_event = NULL;
+  } else {
+    CRITICAL0("Unknown event ! \n");
+    xbt_abort();
+  }
+
+  return;
+}
+
+static surf_action_t execute(void *cpu, double size)
+{
+  surf_action_cpu_ti_t action = NULL;
+  cpu_ti_t CPU = cpu;
+
+  XBT_IN2("(%s,%g)", surf_resource_name(CPU), size);
+  action =
+    surf_action_new(sizeof(s_surf_action_cpu_ti_t), size, surf_cpu_model,
+                    CPU->state_current != SURF_RESOURCE_ON);
+  action->cpu = cpu;
+  action->index_heap = -1;
+
+  xbt_swag_insert(CPU, modified_cpu);
+
+  xbt_swag_insert(action, CPU->action_set);
+
+  action->suspended = 0;        /* Should be useless because of the
+                                   calloc but it seems to help valgrind... */
+
+  XBT_OUT;
+  return (surf_action_t) action;
+}
+
+static void action_update_index_heap(void *action, int i)
+{
+  ((surf_action_cpu_ti_t) action)->index_heap = i;
+}
+
+static surf_action_t action_sleep(void *cpu, double duration)
+{
+  surf_action_cpu_ti_t action = NULL;
+
+  if (duration > 0)
+    duration = MAX(duration, MAXMIN_PRECISION);
+
+  XBT_IN2("(%s,%g)", surf_resource_name(cpu), duration);
+  action = (surf_action_cpu_ti_t) execute(cpu, 1.0);
+  action->generic_action.max_duration = duration;
+  action->suspended = 2;
+  if (duration == NO_MAX_DURATION) {
+    /* Move to the *end* of the corresponding action set. This convention
+       is used to speed up update_resource_state  */
+    xbt_swag_remove(action, ((surf_action_t) action)->state_set);
+    ((surf_action_t) action)->state_set =
+      running_action_set_that_does_not_need_being_checked;
+    xbt_swag_insert(action, ((surf_action_t) action)->state_set);
+  }
+  XBT_OUT;
+  return (surf_action_t) action;
+}
+
+static void action_suspend(surf_action_t action)
+{
+  XBT_IN1("(%p)", action);
+  if (((surf_action_cpu_ti_t) action)->suspended != 2) {
+    ((surf_action_cpu_ti_t) action)->suspended = 1;
+    xbt_swag_insert(ACTION_GET_CPU(action), modified_cpu);
+  }
+  XBT_OUT;
+}
+
+static void action_resume(surf_action_t action)
+{
+  XBT_IN1("(%p)", action);
+  if (((surf_action_cpu_ti_t) action)->suspended != 2) {
+    ((surf_action_cpu_ti_t) action)->suspended = 0;
+    xbt_swag_insert(ACTION_GET_CPU(action), modified_cpu);
+  }
+  XBT_OUT;
+}
+
+static int action_is_suspended(surf_action_t action)
+{
+  return (((surf_action_cpu_ti_t) action)->suspended == 1);
+}
+
+static void action_set_max_duration(surf_action_t action, double duration)
+{
+  surf_action_cpu_ti_t ACT = (surf_action_cpu_ti_t) action;
+  double min_finish;
+
+  XBT_IN2("(%p,%g)", action, duration);
+
+  action->max_duration = duration;
+
+  if (duration >= 0)
+    min_finish =
+      (action->start + action->max_duration) <
+      action->finish ? (action->start +
+                        action->max_duration) : action->finish;
+  else
+    min_finish = action->finish;
+
+  /* add in action heap */
+  if (ACT->index_heap >= 0) {
+    surf_action_cpu_ti_t heap_act =
+      xbt_heap_remove(action_heap, ACT->index_heap);
+    if (heap_act != ACT)
+      DIE_IMPOSSIBLE;
+  }
+  xbt_heap_push(action_heap, ACT, min_finish);
+
+  XBT_OUT;
+}
+
+static void action_set_priority(surf_action_t action, double priority)
+{
+  XBT_IN2("(%p,%g)", action, priority);
+  action->priority = priority;
+  xbt_swag_insert(ACTION_GET_CPU(action), modified_cpu);
+  XBT_OUT;
+}
+
+static double action_get_remains(surf_action_t action)
+{
+  XBT_IN1("(%p)", action);
+  cpu_update_remaining_amount((cpu_ti_t) ((surf_action_cpu_ti_t) action)->cpu,
+                              surf_get_clock());
+  return action->remains;
+  XBT_OUT;
+}
+
+static e_surf_resource_state_t get_state(void *cpu)
+{
+  return ((cpu_ti_t) cpu)->state_current;
+}
+
+static double get_speed(void *cpu, double load)
+{
+  return load * (((cpu_ti_t) cpu)->power_peak);
+}
+
+/**
+ * \brief Auxiliar function to update the cpu power scale.
+ *
+ *     This function uses the trace structure to return the power scale at the determined time a.
+ * \param trace                Trace structure to search the updated power scale
+ * \param a                            Time
+ * \return Cpu power scale
+*/
+static double surf_cpu_get_power_scale(surf_cpu_ti_tgmr_t trace, double a)
+{
+  double reduced_a;
+  int point;
+
+  reduced_a = a - floor(a / trace->last_time) * trace->last_time;
+  point = (int) (reduced_a / trace->levels[0]->spacing);
+  return trace->levels[0]->values[point];
+}
+
+static double get_available_speed(void *cpu)
+{
+  cpu_ti_t CPU = cpu;
+  CPU->power_scale =
+    surf_cpu_get_power_scale(CPU->avail_trace, surf_get_clock());
+  /* number between 0 and 1 */
+  return CPU->power_scale;
+}
+
+static void finalize(void)
+{
+  void *cpu;
+  xbt_dict_cursor_t cursor;
+  char *key;
+  xbt_dict_foreach(surf_model_resource_set(surf_cpu_model), cursor, key, cpu) {
+    cpu_ti_t CPU = cpu;
+    xbt_swag_free(CPU->action_set);
+    surf_cpu_free_trace(CPU->avail_trace);
+  }
+
+  surf_model_exit(surf_cpu_model);
+  surf_cpu_model = NULL;
+
+  xbt_swag_free(running_action_set_that_does_not_need_being_checked);
+  xbt_swag_free(modified_cpu);
+  running_action_set_that_does_not_need_being_checked = NULL;
+  xbt_heap_free(action_heap);
+}
+
+static void surf_cpu_model_init_internal(void)
+{
+  s_surf_action_t action;
+  s_cpu_ti_t cpu;
+
+  surf_cpu_model = surf_model_init();
+
+  running_action_set_that_does_not_need_being_checked =
+    xbt_swag_new(xbt_swag_offset(action, state_hookup));
+
+  modified_cpu = xbt_swag_new(xbt_swag_offset(cpu, modified_cpu_hookup));
+
+  surf_cpu_model->name = "CPU_TI";
+
+  surf_cpu_model->action_unref = action_unref;
+  surf_cpu_model->action_cancel = action_cancel;
+  surf_cpu_model->action_state_set = cpu_action_state_set;
+
+  surf_cpu_model->model_private->resource_used = resource_used;
+  surf_cpu_model->model_private->share_resources = share_resources;
+  surf_cpu_model->model_private->update_actions_state = update_actions_state;
+  surf_cpu_model->model_private->update_resource_state =
+    update_resource_state;
+  surf_cpu_model->model_private->finalize = finalize;
+
+  surf_cpu_model->suspend = action_suspend;
+  surf_cpu_model->resume = action_resume;
+  surf_cpu_model->is_suspended = action_is_suspended;
+  surf_cpu_model->set_max_duration = action_set_max_duration;
+  surf_cpu_model->set_priority = action_set_priority;
+  surf_cpu_model->get_remains = action_get_remains;
+
+  surf_cpu_model->extension.cpu.execute = execute;
+  surf_cpu_model->extension.cpu.sleep = action_sleep;
+
+  surf_cpu_model->extension.cpu.get_state = get_state;
+  surf_cpu_model->extension.cpu.get_speed = get_speed;
+  surf_cpu_model->extension.cpu.get_available_speed = get_available_speed;
+
+  action_heap = xbt_heap_new(8, NULL);
+  xbt_heap_set_update_callback(action_heap, action_update_index_heap);
+
+}
+
+void surf_cpu_model_init_ti(const char *filename)
+{
+  if (surf_cpu_model)
+    return;
+  surf_cpu_model_init_internal();
+  define_callbacks(filename);
+  xbt_dynar_push(model_list, &surf_cpu_model);
+}
+
+
+///////////////// BEGIN INTEGRAL //////////////
+
+/**
+ * \brief Integrate trace
+ *  
+ * Wrapper around surf_cpu_integrate_trace_simple() to get
+ * the cyclic effect.
+ *
+ * \param trace Trace structure.
+ * \param a                    Begin of interval
+ * \param b                    End of interval
+ * \return the integrate value. -1 if an error occurs.
+ */
+static double surf_cpu_integrate_trace(surf_cpu_ti_tgmr_t trace, double a,
+                                       double b)
+{
+  double first_chunk;
+  double middle_chunk;
+  double last_chunk;
+  int a_index, b_index;
+
+  if ((a < 0.0) || (a > b)) {
+    CRITICAL2
+      ("Error, invalid integration interval [%.2f,%.2f]. You probably have a task executing with negative computation amount. Check your code.",
+       a, b);
+    xbt_abort();
+  }
+  if (a == b)
+    return 0.0;
+
+  if (trace->type == TRACE_FIXED) {
+    return ((b - a) * trace->value);
+  }
+
+  if (ceil(a / trace->last_time) == a / trace->last_time)
+    a_index = 1 + (int) (ceil(a / trace->last_time));
+  else
+    a_index = (int) (ceil(a / trace->last_time));
+
+  b_index = (int) (floor(b / trace->last_time));
+
+  if (a_index > b_index) {      /* Same chunk */
+    return surf_cpu_integrate_trace_simple(trace,
+                                           a - (a_index -
+                                                1) * trace->last_time,
+                                           b - (b_index) * trace->last_time);
+  }
+
+  first_chunk = surf_cpu_integrate_trace_simple(trace,
+                                                a - (a_index -
+                                                     1) * trace->last_time,
+                                                trace->last_time);
+  middle_chunk = (b_index - a_index) * trace->total;
+  last_chunk = surf_cpu_integrate_trace_simple(trace,
+                                               0.0,
+                                               b -
+                                               (b_index) * trace->last_time);
+
+  DEBUG3("first_chunk=%.2f  middle_chunk=%.2f  last_chunk=%.2f\n",
+         first_chunk, middle_chunk, last_chunk);
+
+  return (first_chunk + middle_chunk + last_chunk);
+}
+
+/**
+ * \brief Integrate the trace between a and b.
+ *
+ *  integrates without taking cyclic-traces into account.
+ *  [a,b] \subset [0,last_time]
+ *
+ * \param trace Trace structure.
+ * \param a                    Begin of interval
+ * \param b                    End of interval
+ * \return the integrate value. -1 if an error occurs.
+ */
+static double surf_cpu_integrate_trace_simple(surf_cpu_ti_tgmr_t trace,
+                                              double a, double b)
+{
+  double integral = 0.0;
+  int i;
+  long index;
+  int top_level = 0;
+  long l_bounds[TRACE_NB_LEVELS];
+  long u_bounds[TRACE_NB_LEVELS];
+  double a_divided_by_spacing;
+  double current_spacing;
+  DEBUG2("Computing simple integral on [%.2f , %.2f]\n", a, b);
+
+  /* Sanity checks */
+  if ((a < 0.0) || (b < a) || (a > trace->last_time)
+      || (b > trace->last_time)) {
+    CRITICAL2
+      ("Error, invalid integration interval [%.2f,%.2f]. You probably have a task executing with negative computation amount. Check your code.",
+       a, b);
+    xbt_abort();
+  }
+  if (b == a) {
+    return 0.0;
+  }
+
+  for (i = 0; i < trace->nb_levels; i++) {
+    a_divided_by_spacing = a / trace->levels[i]->spacing;
+    if (ceil(a_divided_by_spacing) == a_divided_by_spacing)
+      l_bounds[i] = 1 + (long) ceil(a_divided_by_spacing);
+    else
+      l_bounds[i] = (long) (ceil(a_divided_by_spacing));
+    if (b == trace->last_time) {
+      u_bounds[i] = (long) (floor(b / trace->levels[i]->spacing)) - 1;
+    } else {
+      u_bounds[i] = (long) (floor(b / trace->levels[i]->spacing));
+    }
+    DEBUG3("level %d: l%ld  u%ld\n", i, l_bounds[i], u_bounds[i]);
+
+    if (l_bounds[i] <= u_bounds[i])
+      top_level = i;
+  }
+  DEBUG1("top_level=%d\n", top_level);
+
+  /* Are a and b BOTH in the same chunk of level 0 ? */
+  if (l_bounds[0] > u_bounds[0]) {
+    return (b - a) * (trace->levels[0]->values[u_bounds[0]]);
+  }
+
+  /* first sub-level amount */
+  integral += ((l_bounds[0]) * (trace->levels[0]->spacing) - a) *
+    (trace->levels[0]->values[l_bounds[0] - 1]);
+
+  DEBUG1("Initial level 0 amount is %.2f\n", integral);
+
+  /* first n-1 levels */
+  for (i = 0; i < top_level; i++) {
+
+    if (l_bounds[i] >= u_bounds[i])
+      break;
+
+    current_spacing = trace->levels[i]->spacing;
+    index = l_bounds[i];
+
+    DEBUG1("L%d:", i);
+
+    while (double_positive
+           (l_bounds[i + 1] * trace->levels[i + 1]->spacing -
+            index * current_spacing)) {
+      integral += current_spacing * trace->levels[i]->values[index];
+      DEBUG2("%.2f->%.2f|",
+             index * (trace->levels[i]->spacing),
+             (index + 1) * (trace->levels[i]->spacing));
+      index++;
+    }
+
+    DEBUG0("\n");
+  }
+
+  DEBUG1("After going up: %.2f\n", integral);
+
+  /* n-th level */
+  current_spacing = trace->levels[top_level]->spacing;
+  index = l_bounds[top_level];
+
+  DEBUG1("L%d:", top_level);
+
+  while (index < u_bounds[top_level]) {
+    integral += current_spacing * trace->levels[top_level]->values[index];
+
+    DEBUG2("%.2f->%.2f|",
+           index * (trace->levels[top_level]->spacing),
+           (index + 1) * (trace->levels[top_level]->spacing));
+
+    index++;
+  }
+
+  DEBUG0("\n");
+  DEBUG1("After steady : %.2f\n", integral);
+
+  /* And going back down */
+  for (i = top_level - 1; i >= 0; i--) {
+    if (l_bounds[i] > u_bounds[i])
+      break;
+
+    current_spacing = trace->levels[i]->spacing;
+    index = u_bounds[i + 1] * (trace->levels[i + 1]->spacing /
+                               current_spacing);
+    DEBUG1("L%d:", i);
+    while (double_positive
+           ((u_bounds[i]) * current_spacing - index * current_spacing)) {
+      integral += current_spacing * trace->levels[i]->values[index];
+      DEBUG2("%.2f->%.2f|",
+             index * (trace->levels[i]->spacing),
+             (index + 1) * (trace->levels[i]->spacing));
+      index++;
+    }
+  }
+
+  DEBUG1("After going down : %.2f", integral);
+
+
+  /* Little piece at the end */
+  integral += (b - u_bounds[0] * (trace->levels[0]->spacing)) *
+    (trace->levels[0]->values[u_bounds[0]]);
+
+  DEBUG1("After last bit : %.2f", integral);
+
+  return integral;
+}
+
+
+/**
+ * \brief Calcul the time needed to execute "amount" on cpu.
+ *
+ * Here, amount can span multiple trace periods
+ *
+ * \param trace        CPU trace structure
+ * \param a                            Initial time
+ * \param amount       Amount of calcul to be executed
+ * \return     End time
+ */
+static double surf_cpu_solve_trace(surf_cpu_ti_tgmr_t trace, double a,
+                                   double amount)
+{
+  int quotient;
+  double reduced_b;
+  double reduced_amount;
+  double reduced_a;
+  double b;
+
+  /* Fix very small negative numbers */
+  if ((a < 0.0) && (a > -EPSILON)) {
+    a = 0.0;
+  }
+  if ((amount < 0.0) && (amount > -EPSILON)) {
+    amount = 0.0;
+  }
+
+  /* Sanity checks */
+  if ((a < 0.0) || (amount < 0.0)) {
+    CRITICAL2
+      ("Error, invalid parameters [a = %.2f, amount = %.2f]. You probably have a task executing with negative computation amount. Check your code.",
+       a, amount);
+    xbt_abort();
+  }
+
+  /* At this point, a and amount are positive */
+
+  if (amount < EPSILON)
+    return a;
+
+  /* Is the trace fixed ? */
+  if (trace->type == TRACE_FIXED) {
+    return (a + (amount / trace->value));
+  }
+
+  /* Reduce the problem to one where amount <= trace_total */
+  quotient = (int) (floor(amount / trace->total));
+  reduced_amount = (trace->total) * ((amount / trace->total) -
+                                     floor(amount / trace->total));
+  reduced_a = a - (trace->last_time) * (int) (floor(a / trace->last_time));
+
+  DEBUG3("Quotient: %d reduced_amount: %lf reduced_a: %lf", quotient,
+         reduced_amount, reduced_a);
+
+  /* Now solve for new_amount which is <= trace_total */
+  /*
+     fprintf(stderr,"reduced_a = %.2f\n",reduced_a);
+     fprintf(stderr,"reduced_amount = %.2f\n",reduced_amount);
+   */
+  reduced_b =
+    surf_cpu_solve_trace_somewhat_simple(trace, reduced_a, reduced_amount);
+
+  /* Re-map to the original b and amount */
+  b = (trace->last_time) * (int) (floor(a / trace->last_time)) +
+    (quotient * trace->last_time) + reduced_b;
+  return b;
+}
+
+/**
+ * \brief Auxiliar function to solve integral
+ *
+ * Here, amount is <= trace->total
+ * and a <=trace->last_time
+ *
+ */
+static double surf_cpu_solve_trace_somewhat_simple(surf_cpu_ti_tgmr_t trace,
+                                                   double a, double amount)
+{
+  double amount_till_end;
+  double b;
+
+  DEBUG2("In solveTraceIntegralSomewhatSimple(): [%.2f, amount=%.2f]",
+         a, amount);
+
+  amount_till_end = surf_cpu_integrate_trace(trace, a, trace->last_time);
+  /*
+     fprintf(stderr,"amount_till_end=%.2f\n",amount_till_end);
+   */
+
+  if (amount_till_end > amount) {
+    b = surf_cpu_solve_trace_simple(trace, a, amount);
+  } else {
+    b = trace->last_time +
+      surf_cpu_solve_trace_simple(trace, 0.0, amount - amount_till_end);
+  }
+
+  return b;
+}
+
+/**
+ * \brief Auxiliar function to solve integral
+ * surf_cpu_solve_trace_simple()
+ *
+ *  solve for the upper bound without taking 
+ *  cyclic-traces into account.
+ *
+ *  [a,y] \subset [0,last_time]
+ *  
+ */
+static double surf_cpu_solve_trace_simple(surf_cpu_ti_tgmr_t trace, double a,
+                                          double amount)
+{
+  double next_chunk;
+  double remains;
+  int i;
+  long index;
+  int top_level;
+  double b;
+  int done;
+  long l_bounds[TRACE_NB_LEVELS];       /* May be too bgi for this trace */
+  double a_divided_by_spacing;
+  double current_spacing;
+
+  DEBUG2("Solving simple integral [x=%.2f,amount=%.2f]", a, amount);
+
+  /* Sanity checks */
+  if ((a < 0.0) || (amount < 0.0) || (a > trace->last_time)) {
+    CRITICAL2
+      ("Error, invalid parameters [a = %.2f, amount = %.2f]. You probably have a task executing with negative computation amount. Check your code.",
+       a, amount);
+    xbt_abort();
+  }
+  if (amount == 0.0) {
+    /* fprintf(stderr,"Warning: trivial integral solve\n"); */
+    return a;
+  }
+
+  for (i = 0; i < trace->nb_levels; i++) {
+    a_divided_by_spacing = a / trace->levels[i]->spacing;
+    if (ceil(a_divided_by_spacing) == a_divided_by_spacing)
+      l_bounds[i] = 1 + (long) ceil(a_divided_by_spacing);
+    else
+      l_bounds[i] = (long) (ceil(a_divided_by_spacing));
+
+    if ((l_bounds[i] + 1) * trace->levels[i]->spacing > trace->last_time)
+      break;
+
+    DEBUG2("level %d: l%ld", i, l_bounds[i]);
+  }
+  if (i == trace->nb_levels)
+    top_level = trace->nb_levels - 1;
+  else {
+    top_level = i;
+  }
+
+  remains = amount;
+  /* first sub-level amount */
+  next_chunk = ((l_bounds[0]) * (trace->levels[0]->spacing) - a) *
+    (trace->levels[0]->values[l_bounds[0] - 1]);
+
+  if (remains - next_chunk < 0.0) {
+    b = a + (amount / trace->levels[0]->values[l_bounds[0] - 1]);
+
+    DEBUG1("Returning sub-level[0] result %.2f", b);
+
+    return b;
+  } else {
+    b = (l_bounds[0]) * (trace->levels[0]->spacing);
+    remains -= next_chunk;
+  }
+  DEBUG2("After sub-0 stuff: remains %.2f (b=%.2f)", remains, b);
+
+  /* first n-1 levels */
+  DEBUG0("Going up levels");
+
+  done = 0;
+  for (i = 0; i < top_level; i++) {
+
+    current_spacing = trace->levels[i]->spacing;
+    index = l_bounds[i];
+
+    DEBUG1("L%d:", i);
+
+    while (double_positive
+           (l_bounds[i + 1] * trace->levels[i + 1]->spacing -
+            index * current_spacing)
+           && ((index + 1) * (current_spacing) < trace->last_time)) {
+
+      next_chunk = current_spacing * trace->levels[i]->values[index];
+
+      DEBUG3("%.2f next_chunk= %.2f remains=%.2f",
+             (index + 1) * (trace->levels[i]->spacing), next_chunk, remains);
+
+      if (remains - next_chunk < 0.0) { /* Too far */
+        done = 1;
+        break;
+      } else {                  /* Keep going */
+        DEBUG2("%.2f->%.2f|",
+               index * (trace->levels[i]->spacing),
+               (index + 1) * (trace->levels[i]->spacing));
+
+        remains -= next_chunk;
+        b = (index + 1) * (current_spacing);
+      }
+      index++;
+    }
+    if (done)
+      break;
+  }
+
+  DEBUG0("Steady");
+
+  /* n-th level */
+  current_spacing = trace->levels[top_level]->spacing;
+  index = l_bounds[top_level];
+
+  DEBUG1("L%d:", top_level);
+
+  while (index < trace->levels[top_level]->nb_points) {
+    next_chunk = current_spacing * trace->levels[top_level]->values[index];
+    if (remains - next_chunk <= 0.0) {  /* Too far */
+      break;
+    } else {
+      DEBUG2("%.2f->%.2f|",
+             index * (trace->levels[top_level]->spacing),
+             (index + 1) * (trace->levels[top_level]->spacing));
+
+      remains -= next_chunk;
+      b = (index + 1) * (current_spacing);
+    }
+    index++;
+  }
+  DEBUG2("remains = %.2f b=%.2f", remains, b);
+
+  /* And going back down */
+  DEBUG0("Going back down");
+  for (i = top_level - 1; i >= 0; i--) {
+
+    current_spacing = trace->levels[i]->spacing;
+    index = b / (trace->levels[i]->spacing);
+
+    DEBUG1("L%d:", i);
+
+    while (index < trace->levels[i]->nb_points) {
+      next_chunk = current_spacing * trace->levels[i]->values[index];
+      if (remains - next_chunk <= 0.0) {        /* Too far */
+        break;
+      } else {
+        DEBUG2("%.2f->%.2f|",
+               index * (current_spacing), (index + 1) * (current_spacing));
+
+        remains -= next_chunk;
+        b += current_spacing;
+      }
+      index++;
+    }
+  }
+
+  DEBUG2("remains = %.2f b=%.2f\n", remains, b);
+  DEBUG1("Last bit index=%ld\n", index);
+
+  /* Little piece at the end */
+  b += (remains) / (trace->levels[0]->values[index]);
+
+  return b;
+}
+
+//////////// END INTEGRAL /////////////////
diff --git a/src/surf/cpu_ti_private.h b/src/surf/cpu_ti_private.h
new file mode 100644 (file)
index 0000000..2c46ded
--- /dev/null
@@ -0,0 +1,70 @@
+
+/*     $Id$     */
+
+/* Copyright (c) 2004 Arnaud Legrand. All rights reserved.                  */
+
+/* This program is free software; you can redistribute it and/or modify it
+ * under the terms of the license (GNU LGPL) which comes with this package. */
+
+#ifndef _SURF_CPU_TI_PRIVATE_H
+#define _SURF_CPU_TI_PRIVATE_H
+
+/* TIMESERIES */
+typedef struct surf_cpu_ti_timeSeries {
+  long nb_points;               /*< Number of points in the series */
+  double spacing;               /*< Spacing between two points */
+  double *values;               /*< Array of size nb_points */
+} s_surf_cpu_ti_timeSeries_t, *surf_cpu_ti_timeSeries_t;
+
+/* TRACE */
+typedef struct surf_cpu_ti_tgmr {
+  enum trace_type {
+    TRACE_FIXED,                /*< Trace fixed, no availability file */
+    TRACE_DYNAMIC               /*< Dynamic, availability file disponible */
+  } type;
+
+  double value;                 /*< Percentage of cpu power disponible. Value fixed between 0 and 1 */
+
+  /* Dynamic */
+  double last_time;             /*< Integral interval last point */
+  double total;                 /*< Integral total between 0 and last_pointn */
+
+  surf_cpu_ti_timeSeries_t *levels;     /*< Availability information */
+  int nb_levels;                /*< Number of levels */
+} s_surf_cpu_ti_tgmr_t, *surf_cpu_ti_tgmr_t;
+
+
+/* CPU with trace integration feature */
+typedef struct cpu_ti {
+  s_surf_resource_t generic_resource;   /*< Structure with generic data. Needed at begin to interate with SURF */
+  double power_peak;            /*< CPU power peak */
+  double power_scale;           /*< Percentage of CPU disponible */
+  surf_cpu_ti_tgmr_t avail_trace;       /*< Structure with data needed to integrate trace file */
+  e_surf_resource_state_t state_current;        /*< CPU current state (ON or OFF) */
+  tmgr_trace_event_t state_event;       /*< trace file with states events (ON or OFF) */
+  tmgr_trace_event_t power_event;       /*< trace file with availabitly events */
+  xbt_swag_t action_set;        /*< set with all actions running on cpu */
+  s_xbt_swag_hookup_t modified_cpu_hookup;      /*< hookup to swag that indicacates whether share resources must be recalculated or not */
+  double sum_priority;          /*< the sum of actions' priority that are running on cpu */
+  double last_update;           /*< last update of actions' remaining amount done */
+} s_cpu_ti_t, *cpu_ti_t;
+
+typedef struct surf_action_ti {
+  s_surf_action_t generic_action;
+  s_xbt_swag_hookup_t cpu_list_hookup;
+  void *cpu;
+  int suspended;
+  int index_heap;
+} s_surf_action_cpu_ti_t, *surf_action_cpu_ti_t;
+
+/* Time-step for resource performance traces */
+#define TRACE_TIMESTEP 10.00
+/* Number of levels for resource performance traces */
+#define TRACE_NB_LEVELS 4
+/* Epsilon */
+#define EPSILON 0.000000001
+/* Usefull define to get the cpu where action is running on */
+#define ACTION_GET_CPU(action) ((cpu_ti_t)((surf_action_cpu_ti_t)action)->cpu)
+
+
+#endif /* _SURF_CPU_TI_PRIVATE_H */
index e275354..37d53c7 100644 (file)
@@ -19,7 +19,11 @@ XBT_LOG_NEW_DEFAULT_SUBCATEGORY(surf_maxmin, surf,
 static void *lmm_variable_mallocator_new_f(void);
 static void lmm_variable_mallocator_free_f(void *var);
 static void lmm_variable_mallocator_reset_f(void *var);
-
+static void lmm_update_modified_set(lmm_system_t sys, lmm_constraint_t cnst);
+static void lmm_remove_all_modified_set(lmm_system_t sys);
+int sg_maxmin_selective_update = 0;
+static int Global_debug_id = 1;
+static int Global_const_debug_id = 1;
 lmm_system_t lmm_system_new(void)
 {
   lmm_system_t l = NULL;
@@ -29,6 +33,11 @@ lmm_system_t lmm_system_new(void)
   l = xbt_new0(s_lmm_system_t, 1);
 
   l->modified = 0;
+  l->selective_update_active = sg_maxmin_selective_update;
+
+  DEBUG1("Setting selective_update_active flag to %d\n",
+         l->selective_update_active);
+
   xbt_swag_init(&(l->variable_set),
                 xbt_swag_offset(var, variable_set_hookup));
   xbt_swag_init(&(l->constraint_set),
@@ -37,11 +46,16 @@ lmm_system_t lmm_system_new(void)
   xbt_swag_init(&(l->active_constraint_set),
                 xbt_swag_offset(cnst, active_constraint_set_hookup));
 
+  xbt_swag_init(&(l->modified_constraint_set),
+                xbt_swag_offset(cnst, modified_constraint_set_hookup));
   xbt_swag_init(&(l->saturated_variable_set),
                 xbt_swag_offset(var, saturated_variable_set_hookup));
   xbt_swag_init(&(l->saturated_constraint_set),
                 xbt_swag_offset(cnst, saturated_constraint_set_hookup));
 
+  xbt_swag_init(&(l->modified_variable_set),
+                xbt_swag_offset(var, modified_variable_set_hookup));
+
   l->variable_mallocator = xbt_mallocator_new(64,
                                               lmm_variable_mallocator_new_f,
                                               lmm_variable_mallocator_free_f,
@@ -79,6 +93,8 @@ void lmm_variable_disable(lmm_system_t sys, lmm_variable_t var)
     xbt_swag_remove(elem, &(elem->constraint->active_element_set));
     if (!xbt_swag_size(&(elem->constraint->element_set)))
       make_constraint_inactive(sys, elem->constraint);
+    else
+      lmm_update_modified_set(sys, elem->constraint);
   }
   var->cnsts_number = 0;
   XBT_OUT;
@@ -108,6 +124,7 @@ lmm_constraint_t lmm_constraint_new(lmm_system_t sys, void *id,
 
   cnst = xbt_new0(s_lmm_constraint_t, 1);
   cnst->id = id;
+  cnst->id_int = Global_const_debug_id++;
   xbt_swag_init(&(cnst->element_set),
                 xbt_swag_offset(elem, element_set_hookup));
   xbt_swag_init(&(cnst->active_element_set),
@@ -165,6 +182,7 @@ lmm_variable_t lmm_variable_new(lmm_system_t sys, void *id,
 
   var = xbt_mallocator_get(sys->variable_mallocator);
   var->id = id;
+  var->id_int = Global_debug_id++;
   var->cnsts = xbt_new0(s_lmm_element_t, number_of_constraints);
   for (i = 0; i < number_of_constraints; i++) {
     /* Should be useless because of the 
@@ -234,6 +252,7 @@ void lmm_expand(lmm_system_t sys, lmm_constraint_t cnst,
     xbt_swag_insert_at_tail(elem, &(elem->constraint->element_set));
 
   make_constraint_active(sys, cnst);
+  lmm_update_modified_set(sys, cnst);
 }
 
 void lmm_expand_add(lmm_system_t sys, lmm_constraint_t cnst,
@@ -251,6 +270,7 @@ void lmm_expand_add(lmm_system_t sys, lmm_constraint_t cnst,
       var->cnsts[i].value += value;
     else
       var->cnsts[i].value = MAX(var->cnsts[i].value, value);
+    lmm_update_modified_set(sys, cnst);
   } else
     lmm_expand(sys, cnst, var, value);
 }
@@ -267,6 +287,7 @@ void lmm_elem_set_value(lmm_system_t sys, lmm_constraint_t cnst,
   if (i < var->cnsts_number) {
     var->cnsts[i].value = value;
     sys->modified = 1;
+    lmm_update_modified_set(sys, cnst);
   } else
     DIE_IMPOSSIBLE;
 }
@@ -379,7 +400,7 @@ void lmm_print(lmm_system_t sys)
     xbt_realloc(trace_buf, strlen(trace_buf) + strlen(print_buf) + 1);
   strcat(trace_buf, print_buf);
   xbt_swag_foreach(var, var_list) {
-    sprintf(print_buf, "'%p'(%f) ", var, var->weight);
+    sprintf(print_buf, "'%d'(%f) ", var->id_int, var->weight);
     trace_buf =
       xbt_realloc(trace_buf, strlen(trace_buf) + strlen(print_buf) + 1);
     strcat(trace_buf, print_buf);
@@ -388,7 +409,8 @@ void lmm_print(lmm_system_t sys)
   trace_buf =
     xbt_realloc(trace_buf, strlen(trace_buf) + strlen(print_buf) + 1);
   strcat(trace_buf, print_buf);
-  DEBUG1("%s", trace_buf);
+  fprintf(stderr, "%s", trace_buf);
+  //DEBUG1("%20s", trace_buf); FIXME
   trace_buf[0] = '\000';
 
   DEBUG0("Constraints");
@@ -402,14 +424,14 @@ void lmm_print(lmm_system_t sys)
       xbt_realloc(trace_buf, strlen(trace_buf) + strlen(print_buf) + 1);
     strcat(trace_buf, print_buf);
     xbt_swag_foreach(elem, elem_list) {
-      sprintf(print_buf, "%f.'%p'(%f) + ", elem->value,
-              elem->variable, elem->variable->value);
+      sprintf(print_buf, "%f.'%d'(%f) + ", elem->value,
+              elem->variable->id_int, elem->variable->value);
       trace_buf =
         xbt_realloc(trace_buf, strlen(trace_buf) + strlen(print_buf) + 1);
       strcat(trace_buf, print_buf);
       sum += elem->value * elem->variable->value;
     }
-    sprintf(print_buf, "0 <= %f ('%p')", cnst->bound, cnst);
+    sprintf(print_buf, "0 <= %f ('%d')", cnst->bound, cnst->id_int);
     trace_buf =
       xbt_realloc(trace_buf, strlen(trace_buf) + strlen(print_buf) + 1);
     strcat(trace_buf, print_buf);
@@ -420,7 +442,8 @@ void lmm_print(lmm_system_t sys)
         xbt_realloc(trace_buf, strlen(trace_buf) + strlen(print_buf) + 1);
       strcat(trace_buf, print_buf);
     }
-    DEBUG1("%s", trace_buf);
+    //   DEBUG1("%s", trace_buf);
+    fprintf(stderr, "%s", trace_buf);
     trace_buf[0] = '\000';
     xbt_assert3(!double_positive(sum - cnst->bound),
                 "Incorrect value (%f is not smaller than %f): %g",
@@ -431,13 +454,14 @@ void lmm_print(lmm_system_t sys)
   /* Printing Result */
   xbt_swag_foreach(var, var_list) {
     if (var->bound > 0) {
-      DEBUG4("'%p'(%f) : %f (<=%f)", var, var->weight, var->value,
+      DEBUG4("'%d'(%f) : %f (<=%f)", var->id_int, var->weight, var->value,
              var->bound);
       xbt_assert2(!double_positive(var->value - var->bound),
                   "Incorrect value (%f is not smaller than %f",
                   var->value, var->bound);
-    } else
-      DEBUG3("'%p'(%f) : %f", var, var->weight, var->value);
+    } else {
+      DEBUG3("'%d'(%f) : %f", var->id_int, var->weight, var->value);
+    }
   }
 
   free(trace_buf);
@@ -457,7 +481,29 @@ void lmm_solve(lmm_system_t sys)
   if (!(sys->modified))
     return;
 
-  /* Init */
+  /*
+   * Compute Usage and store the variables that reach the maximum.
+   */
+  cnst_list = sys->selective_update_active ? &(sys->modified_constraint_set) :
+    &(sys->active_constraint_set);
+
+  DEBUG1("Active constraints : %d", xbt_swag_size(cnst_list));
+  /* Init: Only modified code portions */
+  xbt_swag_foreach(cnst, cnst_list) {
+    elem_list = &(cnst->element_set);
+    //DEBUG1("Variable set : %d", xbt_swag_size(elem_list));
+    xbt_swag_foreach(elem, elem_list) {
+      var = elem->variable;
+      xbt_swag_insert(var, &(sys->modified_variable_set));
+      /* FIXME: modified this test because we need all actions in cpu_im */
+      if (var->weight <= 0.0)
+        //break;
+        continue;
+      var->value = 0.0;
+    }
+  }
+
+  /* Init: special case where all constraints are 0 */
   var_list = &(sys->variable_set);
   DEBUG1("Variable set : %d", xbt_swag_size(var_list));
   xbt_swag_foreach(var, var_list) {
@@ -465,7 +511,6 @@ void lmm_solve(lmm_system_t sys)
     int i;
     if (var->weight <= 0.0)
       break;
-    var->value = 0.0;
     for (i = 0; i < var->cnsts_number; i++) {
       if (var->cnsts[i].value == 0.0)
         nb++;
@@ -474,10 +519,6 @@ void lmm_solve(lmm_system_t sys)
       var->value = 1.0;
   }
 
-  /* 
-   * Compute Usage and store the variables that reach the maximum.
-   */
-  cnst_list = &(sys->active_constraint_set);
   DEBUG1("Active constraints : %d", xbt_swag_size(cnst_list));
   xbt_swag_foreach(cnst, cnst_list) {
     /* INIT */
@@ -494,10 +535,11 @@ void lmm_solve(lmm_system_t sys)
           cnst->usage += elem->value / elem->variable->weight;
         else if (cnst->usage < elem->value / elem->variable->weight)
           cnst->usage = elem->value / elem->variable->weight;
-        DEBUG2("Constraint Usage %p : %f", cnst, cnst->usage);
+
         make_elem_active(elem);
       }
     }
+    DEBUG2("Constraint Usage %d : %f", cnst->id_int, cnst->usage);
     /* Saturated constraints update */
     saturated_constraint_set_update(sys, cnst, &min_usage);
   }
@@ -515,8 +557,9 @@ void lmm_solve(lmm_system_t sys)
       /* First check if some of these variables have reach their upper
          bound and update min_usage accordingly. */
       DEBUG5
-        ("var=%p, var->bound=%f, var->weight=%f, min_usage=%f, var->bound*var->weight=%f",
-         var, var->bound, var->weight, min_usage, var->bound * var->weight);
+        ("var=%d, var->bound=%f, var->weight=%f, min_usage=%f, var->bound*var->weight=%f",
+         var->id_int, var->bound, var->weight, min_usage,
+         var->bound * var->weight);
       if ((var->bound > 0) && (var->bound * var->weight < min_usage)) {
         if (min_bound < 0)
           min_bound = var->bound;
@@ -529,6 +572,7 @@ void lmm_solve(lmm_system_t sys)
 
     while ((var = xbt_swag_getFirst(var_list))) {
       int i;
+      xbt_swag_insert(var, &(sys->modified_variable_set));
 
       if (min_bound < 0) {
         var->value = min_usage / var->weight;
@@ -540,8 +584,8 @@ void lmm_solve(lmm_system_t sys)
           continue;
         }
       }
-      DEBUG5("Min usage: %f, Var(%p)->weight: %f, Var(%p)->value: %f ",
-             min_usage, var, var->weight, var, var->value);
+      DEBUG5("Min usage: %f, Var(%d)->weight: %f, Var(%d)->value: %f ",
+             min_usage, var->id_int, var->weight, var->id_int, var->value);
 
 
       /* Update usage */
@@ -564,7 +608,7 @@ void lmm_solve(lmm_system_t sys)
             if ((elem->value > 0)) {
               if (cnst->usage < elem->value / elem->variable->weight)
                 cnst->usage = elem->value / elem->variable->weight;
-              DEBUG2("Constraint Usage %p : %f", cnst, cnst->usage);
+              DEBUG2("Constraint Usage %d : %f", cnst->id_int, cnst->usage);
               make_elem_active(elem);
             }
           }
@@ -574,7 +618,10 @@ void lmm_solve(lmm_system_t sys)
     }
 
     /* Find out which variables reach the maximum */
-    cnst_list = &(sys->active_constraint_set);
+    cnst_list =
+      sys->selective_update_active ? &(sys->
+                                       modified_constraint_set) :
+      &(sys->active_constraint_set);
     min_usage = -1;
     min_bound = -1;
     xbt_swag_foreach(cnst, cnst_list) {
@@ -585,6 +632,9 @@ void lmm_solve(lmm_system_t sys)
   } while (xbt_swag_size(&(sys->saturated_variable_set)));
 
   sys->modified = 0;
+  if (sys->selective_update_active)
+    lmm_remove_all_modified_set(sys);
+
   if (XBT_LOG_ISENABLED(surf_maxmin, xbt_log_priority_debug)) {
     lmm_print(sys);
   }
@@ -597,10 +647,11 @@ void lmm_update(lmm_system_t sys, lmm_constraint_t cnst,
 {
   int i;
 
-  sys->modified = 1;
   for (i = 0; i < var->cnsts_number; i++)
     if (var->cnsts[i].constraint == cnst) {
       var->cnsts[i].value = value;
+      sys->modified = 1;
+      lmm_update_modified_set(sys, cnst);
       return;
     }
 }
@@ -620,8 +671,14 @@ void lmm_update(lmm_system_t sys, lmm_constraint_t cnst,
 void lmm_update_variable_bound(lmm_system_t sys, lmm_variable_t var,
                                double bound)
 {
+  int i;
+
   sys->modified = 1;
   var->bound = bound;
+
+  for (i = 0; i < var->cnsts_number; i++)
+    lmm_update_modified_set(sys, var->cnsts[i].constraint);
+
 }
 
 
@@ -649,6 +706,8 @@ void lmm_update_variable_weight(lmm_system_t sys, lmm_variable_t var,
       xbt_swag_insert_at_head(elem, &(elem->constraint->element_set));
     else
       xbt_swag_insert_at_tail(elem, &(elem->constraint->element_set));
+
+    lmm_update_modified_set(sys, elem->constraint);
   }
   if (!weight)
     var->value = 0.0;
@@ -665,6 +724,7 @@ void lmm_update_constraint_bound(lmm_system_t sys, lmm_constraint_t cnst,
                                  double bound)
 {
   sys->modified = 1;
+  lmm_update_modified_set(sys, cnst);
   cnst->bound = bound;
 }
 
@@ -683,3 +743,70 @@ lmm_constraint_t lmm_get_next_active_constraint(lmm_system_t sys,
 {
   return xbt_swag_getNext(cnst, (sys->active_constraint_set).offset);
 }
+
+/** \brief Update the constraint set propagating recursively to
+ *  other constraints so the system should not be entirely computed.
+ *
+ *  \param sys the lmm_system_t
+ *  \param cnst the lmm_constraint_t affected by the change
+ *
+ *  A recursive algorithm to optimize the system recalculation selecting only
+ *  constraints that have changed. Each constraint change is propagated
+ *  to the list of constraints for each variable.
+ */
+static void lmm_update_modified_set(lmm_system_t sys, lmm_constraint_t cnst)
+{
+  lmm_element_t elem = NULL;
+  lmm_variable_t var = NULL;
+  xbt_swag_t elem_list = NULL;
+  int i;
+
+  /* return if selective update isn't active */
+  if (!sys->selective_update_active)
+    return;
+
+  //DEBUG1("Updating modified constraint set with constraint %d", cnst->id_int);
+
+  if (xbt_swag_belongs(cnst, &(sys->modified_constraint_set)))
+    return;
+
+  //DEBUG1("Inserting into modified constraint set %d", cnst->id_int);
+
+  /* add to modified set */
+  xbt_swag_insert(cnst, &(sys->modified_constraint_set));
+
+  elem_list = &(cnst->element_set);
+  xbt_swag_foreach(elem, elem_list) {
+    var = elem->variable;
+    for (i = 0; i < var->cnsts_number; i++)
+      if (cnst != var->cnsts[i].constraint) {
+        //DEBUG2("Updating modified %d calling for %d", cnst->id_int, var->cnsts[i].constraint->id_int);
+        lmm_update_modified_set(sys, var->cnsts[i].constraint);
+      }
+  }
+}
+
+/** \brief Remove all constraints of the modified_constraint_set.
+ *
+ *  \param sys the lmm_system_t
+ */
+static void lmm_remove_all_modified_set(lmm_system_t sys)
+{
+  lmm_element_t elem = NULL;
+  lmm_element_t elem_next = NULL;
+  xbt_swag_t elem_list = NULL;
+
+  elem_list = &(sys->modified_constraint_set);
+  xbt_swag_foreach_safe(elem, elem_next, elem_list) {
+    xbt_swag_remove(elem, elem_list);
+  }
+}
+
+void *lmm_extract_modified_variable(lmm_system_t sys)
+{
+  lmm_variable_t var;
+  var = xbt_swag_extract(&(sys->modified_variable_set));
+  if (var)
+    return var->id;
+  return NULL;
+}
index dc2edc5..e492e6e 100644 (file)
@@ -28,6 +28,7 @@ typedef struct lmm_constraint {
   /* hookup to system */
   s_xbt_swag_hookup_t constraint_set_hookup;
   s_xbt_swag_hookup_t active_constraint_set_hookup;
+  s_xbt_swag_hookup_t modified_constraint_set_hookup;
   s_xbt_swag_hookup_t saturated_constraint_set_hookup;
 
   s_xbt_swag_t element_set;     /* a list of lmm_mat_element_t */
@@ -39,12 +40,14 @@ typedef struct lmm_constraint {
   int shared;
   double usage;
   void *id;
+  int id_int;
 } s_lmm_constraint_t;
 
 typedef struct lmm_variable {
   /* hookup to system */
   s_xbt_swag_hookup_t variable_set_hookup;
   s_xbt_swag_hookup_t saturated_variable_set_hookup;
+  s_xbt_swag_hookup_t modified_variable_set_hookup;
 
   s_lmm_element_t *cnsts;
   int cnsts_size;
@@ -53,6 +56,7 @@ typedef struct lmm_variable {
   double bound;
   double value;
   void *id;
+  int id_int;
   /* \begin{For Lagrange only} */
   double mu;
   double new_mu;
@@ -64,14 +68,19 @@ typedef struct lmm_variable {
 
 typedef struct lmm_system {
   int modified;
+  int selective_update_active;  /* flag to update partially the system only selecting changed portions */
+
   s_xbt_swag_t variable_set;    /* a list of lmm_variable_t */
   s_xbt_swag_t constraint_set;  /* a list of lmm_constraint_t */
 
   s_xbt_swag_t active_constraint_set;   /* a list of lmm_constraint_t */
+  s_xbt_swag_t modified_constraint_set; /* a list of modified lmm_constraint_t */
 
   s_xbt_swag_t saturated_variable_set;  /* a list of lmm_variable_t */
   s_xbt_swag_t saturated_constraint_set;        /* a list of lmm_constraint_t_t */
 
+  s_xbt_swag_t modified_variable_set;   /* list of modified variables used in new model CpuIM */
+
   xbt_mallocator_t variable_mallocator;
 } s_lmm_system_t;
 
index e7292f1..90f9721 100644 (file)
@@ -36,11 +36,12 @@ static link_CM02_t link_new(char *name,
 {
   link_CM02_t nw_link = (link_CM02_t)
     surf_resource_lmm_new(sizeof(s_link_CM02_t),
-        surf_network_model,name,properties,
-        network_maxmin_system, bandwidth_factor * bw_initial,
-        history,
-        state_initial,state_trace,
-        bw_initial,bw_trace);
+                          surf_network_model, name, properties,
+                          network_maxmin_system,
+                          bandwidth_factor * bw_initial,
+                          history,
+                          state_initial, state_trace,
+                          bw_initial, bw_trace);
 
   xbt_assert1(!xbt_dict_get_or_null(surf_network_model->resource_set, name),
               "Link '%s' declared several times in the platform file.", name);
@@ -53,7 +54,8 @@ static link_CM02_t link_new(char *name,
   if (policy == SURF_LINK_FATPIPE)
     lmm_constraint_shared(nw_link->lmm_resource.constraint);
 
-  xbt_dict_set(surf_network_model->resource_set, name, nw_link, surf_resource_free);
+  xbt_dict_set(surf_network_model->resource_set, name, nw_link,
+               surf_resource_free);
 
   return nw_link;
 }
@@ -110,31 +112,36 @@ static void add_traces(void)
   /* connect all traces relative to network */
   xbt_dict_foreach(trace_connect_list_link_avail, cursor, trace_name, elm) {
     tmgr_trace_t trace = xbt_dict_get_or_null(traces_set_list, trace_name);
-    link_CM02_t link = xbt_dict_get_or_null(surf_network_model->resource_set, elm);
+    link_CM02_t link =
+      xbt_dict_get_or_null(surf_network_model->resource_set, elm);
 
     xbt_assert2(link, "Cannot connect trace %s to link %s: link undefined",
                 trace_name, elm);
     xbt_assert2(trace, "Cannot connect trace %s to link %s: trace undefined",
                 trace_name, elm);
 
-    link->lmm_resource.state_event = tmgr_history_add_trace(history, trace, 0.0, 0, link);
+    link->lmm_resource.state_event =
+      tmgr_history_add_trace(history, trace, 0.0, 0, link);
   }
 
   xbt_dict_foreach(trace_connect_list_bandwidth, cursor, trace_name, elm) {
     tmgr_trace_t trace = xbt_dict_get_or_null(traces_set_list, trace_name);
-    link_CM02_t link = xbt_dict_get_or_null(surf_network_model->resource_set, elm);
+    link_CM02_t link =
+      xbt_dict_get_or_null(surf_network_model->resource_set, elm);
 
     xbt_assert2(link, "Cannot connect trace %s to link %s: link undefined",
                 trace_name, elm);
     xbt_assert2(trace, "Cannot connect trace %s to link %s: trace undefined",
                 trace_name, elm);
 
-    link->lmm_resource.power.event = tmgr_history_add_trace(history, trace, 0.0, 0, link);
+    link->lmm_resource.power.event =
+      tmgr_history_add_trace(history, trace, 0.0, 0, link);
   }
 
   xbt_dict_foreach(trace_connect_list_latency, cursor, trace_name, elm) {
     tmgr_trace_t trace = xbt_dict_get_or_null(traces_set_list, trace_name);
-    link_CM02_t link = xbt_dict_get_or_null(surf_network_model->resource_set, elm);
+    link_CM02_t link =
+      xbt_dict_get_or_null(surf_network_model->resource_set, elm);
 
     xbt_assert2(link, "Cannot connect trace %s to link %s: link undefined",
                 trace_name, elm);
@@ -182,6 +189,11 @@ static void action_recycle(surf_action_t action)
   return;
 }
 
+static double action_get_remains(surf_action_t action)
+{
+  return action->remains;
+}
+
 static double share_resources(double now)
 {
   s_surf_action_network_CM02_t s_action;
@@ -241,11 +253,13 @@ static void update_actions_state(double now, double delta)
     if ((action->generic_action.remains <= 0) &&
         (lmm_get_variable_weight(action->variable) > 0)) {
       action->generic_action.finish = surf_get_clock();
-      surf_network_model->action_state_set((surf_action_t) action, SURF_ACTION_DONE);
-    } else if ((action->generic_action.max_duration != NO_MAX_DURATION) &&
-               (action->generic_action.max_duration <= 0)) {
+      surf_network_model->action_state_set((surf_action_t) action,
+                                           SURF_ACTION_DONE);
+    } else if ((action->generic_action.max_duration != NO_MAX_DURATION)
+               && (action->generic_action.max_duration <= 0)) {
       action->generic_action.finish = surf_get_clock();
-      surf_network_model->action_state_set((surf_action_t) action, SURF_ACTION_DONE);
+      surf_network_model->action_state_set((surf_action_t) action,
+                                           SURF_ACTION_DONE);
     }
   }
 
@@ -264,17 +278,21 @@ static void update_resource_state(void *id,
   if (event_type == nw_link->lmm_resource.power.event) {
     double delta =
       weight_S_parameter / value - weight_S_parameter /
-          (nw_link->lmm_resource.power.peak * nw_link->lmm_resource.power.scale);
+      (nw_link->lmm_resource.power.peak * nw_link->lmm_resource.power.scale);
     lmm_variable_t var = NULL;
     lmm_element_t elem = NULL;
     surf_action_network_CM02_t action = NULL;
 
     nw_link->lmm_resource.power.peak = value;
-    lmm_update_constraint_bound(network_maxmin_system, nw_link->lmm_resource.constraint,
-                                bandwidth_factor * (nw_link->lmm_resource.power.peak * nw_link->lmm_resource.power.scale));
+    lmm_update_constraint_bound(network_maxmin_system,
+                                nw_link->lmm_resource.constraint,
+                                bandwidth_factor *
+                                (nw_link->lmm_resource.power.peak *
+                                 nw_link->lmm_resource.power.scale));
     if (weight_S_parameter > 0) {
       while ((var = lmm_get_var_from_cnst
-              (network_maxmin_system, nw_link->lmm_resource.constraint, &elem))) {
+              (network_maxmin_system, nw_link->lmm_resource.constraint,
+               &elem))) {
         action = lmm_variable_id(var);
         action->weight += delta;
         if (!(action->suspended))
@@ -282,6 +300,8 @@ static void update_resource_state(void *id,
                                      action->weight);
       }
     }
+    if (tmgr_trace_event_free(event_type))
+      nw_link->lmm_resource.power.event = NULL;
   } else if (event_type == nw_link->lat_event) {
     double delta = value - nw_link->lat_current;
     lmm_variable_t var = NULL;
@@ -290,7 +310,8 @@ static void update_resource_state(void *id,
 
     nw_link->lat_current = value;
     while ((var = lmm_get_var_from_cnst
-            (network_maxmin_system, nw_link->lmm_resource.constraint, &elem))) {
+            (network_maxmin_system, nw_link->lmm_resource.constraint,
+             &elem))) {
       action = lmm_variable_id(var);
       action->lat_current += delta;
       action->weight += delta;
@@ -307,6 +328,8 @@ static void update_resource_state(void *id,
                                    action->weight);
 
     }
+    if (tmgr_trace_event_free(event_type))
+      nw_link->lat_event = NULL;
   } else if (event_type == nw_link->lmm_resource.state_event) {
     if (value > 0)
       nw_link->lmm_resource.state_current = SURF_RESOURCE_ON;
@@ -327,6 +350,8 @@ static void update_resource_state(void *id,
         }
       }
     }
+    if (tmgr_trace_event_free(event_type))
+      nw_link->lmm_resource.state_event = NULL;
   } else {
     CRITICAL0("Unknown event ! \n");
     xbt_abort();
@@ -335,8 +360,8 @@ static void update_resource_state(void *id,
   return;
 }
 
-static surf_action_t communicate(const char *src_name, const char *dst_name,int src, int dst, double size,
-                                 double rate)
+static surf_action_t communicate(const char *src_name, const char *dst_name,
+                                 int src, int dst, double size, double rate)
 {
   surf_action_network_CM02_t action = NULL;
   /* LARGE PLATFORMS HACK:
@@ -355,26 +380,28 @@ static surf_action_t communicate(const char *src_name, const char *dst_name,int
               src_name, dst_name);
 
   link_CM02_t link;
-  int failed=0;
-  xbt_dynar_foreach(route,i,link) {
+  int failed = 0;
+  xbt_dynar_foreach(route, i, link) {
     if (link->lmm_resource.state_current == SURF_RESOURCE_OFF) {
       failed = 1;
       break;
     }
   }
-  action = surf_action_new(sizeof(s_surf_action_network_CM02_t),size,surf_network_model,failed);
+  action =
+    surf_action_new(sizeof(s_surf_action_network_CM02_t), size,
+                    surf_network_model, failed);
 
   xbt_swag_insert(action, action->generic_action.state_set);
   action->rate = rate;
 
   action->latency = 0.0;
   action->weight = 0.0;
-  xbt_dynar_foreach(route,i,link) {
+  xbt_dynar_foreach(route, i, link) {
     action->latency += link->lat_current;
     action->weight +=
       link->lat_current +
       weight_S_parameter /
-        (link->lmm_resource.power.peak * link->lmm_resource.power.scale);
+      (link->lmm_resource.power.peak * link->lmm_resource.power.scale);
   }
   /* LARGE PLATFORMS HACK:
      Add src->link and dst->link latencies */
@@ -385,10 +412,12 @@ static surf_action_t communicate(const char *src_name, const char *dst_name,int
      lmm_variable_new(..., total_route_size) */
   if (action->latency > 0)
     action->variable =
-      lmm_variable_new(network_maxmin_system, action, 0.0, -1.0, xbt_dynar_length(route));
+      lmm_variable_new(network_maxmin_system, action, 0.0, -1.0,
+                       xbt_dynar_length(route));
   else
     action->variable =
-      lmm_variable_new(network_maxmin_system, action, 1.0, -1.0, xbt_dynar_length(route));
+      lmm_variable_new(network_maxmin_system, action, 1.0, -1.0,
+                       xbt_dynar_length(route));
 
   if (action->rate < 0) {
     if (action->lat_current > 0)
@@ -408,7 +437,7 @@ static surf_action_t communicate(const char *src_name, const char *dst_name,int
                                 action->rate);
   }
 
-  xbt_dynar_foreach(route,i,link) {
+  xbt_dynar_foreach(route, i, link) {
     lmm_expand(network_maxmin_system, link->lmm_resource.constraint,
                action->variable, 1.0);
   }
@@ -422,7 +451,7 @@ static surf_action_t communicate(const char *src_name, const char *dst_name,int
 
 static double get_link_bandwidth(const void *link)
 {
-  surf_resource_lmm_t lmm = (surf_resource_lmm_t)link;
+  surf_resource_lmm_t lmm = (surf_resource_lmm_t) link;
   return lmm->power.peak * lmm->power.scale;
 }
 
@@ -483,6 +512,7 @@ static void surf_network_model_init_internal(void)
   surf_network_model->action_unref = action_unref;
   surf_network_model->action_cancel = action_cancel;
   surf_network_model->action_recycle = action_recycle;
+  surf_network_model->get_remains = action_get_remains;
 
   surf_network_model->model_private->resource_used = resource_used;
   surf_network_model->model_private->share_resources = share_resources;
@@ -507,9 +537,10 @@ static void surf_network_model_init_internal(void)
     network_maxmin_system = lmm_system_new();
 
   routing_model_create(sizeof(link_CM02_t),
-      link_new(xbt_strdup("__loopback__"),
-          498000000, NULL, 0.000015, NULL,
-          SURF_RESOURCE_ON, NULL, SURF_LINK_FATPIPE, NULL));
+                       link_new(xbt_strdup("__loopback__"),
+                                498000000, NULL, 0.000015, NULL,
+                                SURF_RESOURCE_ON, NULL, SURF_LINK_FATPIPE,
+                                NULL));
 }
 
 /************************************************************************/
index ec3ac7d..df8eaf5 100644 (file)
@@ -59,6 +59,11 @@ static void action_recycle(surf_action_t action)
   return;
 }
 
+static double action_get_remains(surf_action_t action)
+{
+  return action->remains;
+}
+
 static double share_resources(double now)
 {
   surf_action_network_Constant_t action = NULL;
@@ -98,11 +103,13 @@ static void update_actions_state(double now, double delta)
 
     if (action->generic_action.remains <= 0) {
       action->generic_action.finish = surf_get_clock();
-      surf_network_model->action_state_set((surf_action_t) action, SURF_ACTION_DONE);
-    } else if ((action->generic_action.max_duration != NO_MAX_DURATION) &&
-               (action->generic_action.max_duration <= 0)) {
+      surf_network_model->action_state_set((surf_action_t) action,
+                                           SURF_ACTION_DONE);
+    } else if ((action->generic_action.max_duration != NO_MAX_DURATION)
+               && (action->generic_action.max_duration <= 0)) {
       action->generic_action.finish = surf_get_clock();
-      surf_network_model->action_state_set((surf_action_t) action, SURF_ACTION_DONE);
+      surf_network_model->action_state_set((surf_action_t) action,
+                                           SURF_ACTION_DONE);
     }
   }
 }
@@ -114,18 +121,20 @@ static void update_resource_state(void *id,
   DIE_IMPOSSIBLE;
 }
 
-static surf_action_t communicate(const char *src_name,const char *dst_name,int src, int dst, double size,
-    double rate)
+static surf_action_t communicate(const char *src_name, const char *dst_name,
+                                 int src, int dst, double size, double rate)
 {
   surf_action_network_Constant_t action = NULL;
 
   XBT_IN4("(%s,%s,%g,%g)", src_name, dst_name, size, rate);
 
-  action = surf_action_new(sizeof(s_surf_action_network_Constant_t),size,surf_network_model,0);
+  action =
+    surf_action_new(sizeof(s_surf_action_network_Constant_t), size,
+                    surf_network_model, 0);
 
   action->suspended = 0;
 
-  action->latency = 1;//random_generate(random_latency);
+  action->latency = 1;          //random_generate(random_latency);
   action->lat_init = action->latency;
 
   if (action->latency <= 0.0) {
@@ -201,6 +210,7 @@ void surf_network_model_init_Constant(const char *filename)
   surf_network_model->action_unref = action_unref;
   surf_network_model->action_cancel = action_cancel;
   surf_network_model->action_recycle = action_recycle;
+  surf_network_model->get_remains = action_get_remains;
 
   surf_network_model->model_private->resource_used = resource_used;
   surf_network_model->model_private->share_resources = share_resources;
@@ -229,7 +239,6 @@ void surf_network_model_init_Constant(const char *filename)
   update_model_description(surf_network_model_description,
                            "Constant", surf_network_model);
 
-  xbt_cfg_set_string(_surf_cfg_set,"routing","none");
-  routing_model_create(sizeof(double),NULL);
+  xbt_cfg_set_string(_surf_cfg_set, "routing", "none");
+  routing_model_create(sizeof(double), NULL);
 }
-
index 2fba3bf..b119559 100644 (file)
@@ -75,7 +75,8 @@ static void link_new(char *name, double bw, double lat, xbt_dict_t props)
   gtnets_link->lat_current = lat;
   gtnets_link->id = link_count;
 
-  xbt_dict_set(surf_network_model->resource_set, name, gtnets_link, surf_resource_free);
+  xbt_dict_set(surf_network_model->resource_set, name, gtnets_link,
+               surf_resource_free);
 
   return;
 }
@@ -242,7 +243,8 @@ static void add_route()
 
     xbt_dynar_foreach(links, cpt, link) {
       TRY {
-        link_list[nb_link++] = xbt_dict_get(surf_network_model->resource_set, link);
+        link_list[nb_link++] =
+          xbt_dict_get(surf_network_model->resource_set, link);
       }
       CATCH(e) {
         RETHROW1("Link %s not found (dict raised this exception: %s)", link);
@@ -267,7 +269,8 @@ static void add_route()
 
     xbt_dynar_foreach(links, cpt, link) {
       TRY {
-        link_list[nb_link++] = xbt_dict_get(surf_network_model->resource_set, link);
+        link_list[nb_link++] =
+          xbt_dict_get(surf_network_model->resource_set, link);
       }
       CATCH(e) {
         RETHROW1("Link %s not found (dict raised this exception: %s)", link);
@@ -323,8 +326,13 @@ static void action_recycle(surf_action_t action)
   return;
 }
 
+static double action_get_remains(surf_action_t action)
+{
+  return action->remains;
+}
+
 static void action_state_set(surf_action_t action,
-                                e_surf_action_state_t state)
+                             e_surf_action_state_t state)
 {
 /*   if((state==SURF_ACTION_DONE) || (state==SURF_ACTION_FAILED)) */
 /*     if(((surf_action_network_GTNETS_t)action)->variable) { */
@@ -340,8 +348,7 @@ static void action_state_set(surf_action_t action,
 /* share_resources() */
 static double share_resources(double now)
 {
-  xbt_swag_t running_actions =
-    surf_network_model->states.running_action_set;
+  xbt_swag_t running_actions = surf_network_model->states.running_action_set;
 
   //get the first relevant value from the running_actions list
   if (!xbt_swag_size(running_actions))
@@ -366,8 +373,7 @@ static void update_actions_state(double now, double delta)
 {
   surf_action_network_GTNETS_t action = NULL;
   //  surf_action_network_GTNETS_t next_action = NULL;
-  xbt_swag_t running_actions =
-    surf_network_model->states.running_action_set;
+  xbt_swag_t running_actions = surf_network_model->states.running_action_set;
 
   /* If there are no renning flows, just return */
   if (time_to_next_flow_completion < 0.0) {
@@ -434,12 +440,14 @@ static void update_resource_state(void *id,
 
 /* KF: Rate not supported */
 /* Max durations are not supported */
-static surf_action_t communicate(const char *src_name, const char *dst_name,int src, int dst, double size,
-                                 double rate)
+static surf_action_t communicate(const char *src_name, const char *dst_name,
+                                 int src, int dst, double size, double rate)
 {
   surf_action_network_GTNETS_t action = NULL;
 
-  action = surf_action_new(sizeof(s_surf_action_network_GTNETS_t),size,surf_network_model,0);
+  action =
+    surf_action_new(sizeof(s_surf_action_network_GTNETS_t), size,
+                    surf_network_model, 0);
 
   /* KF: Add a flow to the GTNets Simulation, associated to this action */
   if (gtnets_create_flow(src, dst, size, (void *) action) < 0) {
@@ -489,6 +497,7 @@ static void surf_network_model_init_internal(void)
   surf_network_model->action_cancel = action_cancel;
   surf_network_model->action_recycle = action_recycle;
   surf_network_model->action_state_set = action_state_set;
+  surf_network_model->get_remains = action_get_remains;
 
   surf_network_model->model_private->resource_used = resource_used;
   surf_network_model->model_private->share_resources = share_resources;
index dfd9943..438f3b3 100644 (file)
@@ -11,6 +11,7 @@
 <!ATTLIST trace id CDATA #REQUIRED>
 <!ATTLIST trace file CDATA "">
 <!ATTLIST trace periodicity CDATA #REQUIRED>
+<!ATTLIST trace timestep CDATA "10.0">
 
 <!ELEMENT random (prop*)>
 <!ATTLIST random id CDATA #REQUIRED>
index 99364c1..ae38da7 100644 (file)
@@ -69,7 +69,7 @@ typedef uint32_t flex_uint32_t;
 typedef signed char flex_int8_t;
 typedef short int flex_int16_t;
 typedef int flex_int32_t;
-typedef unsigned char flex_uint8_t;
+typedef unsigned char flex_uint8_t; 
 typedef unsigned short int flex_uint16_t;
 typedef unsigned int flex_uint32_t;
 
@@ -111,15 +111,15 @@ typedef unsigned int flex_uint32_t;
 /* The "const" storage-class-modifier is valid. */
 #define YY_USE_CONST
 
-#else /* ! __cplusplus */
+#else  /* ! __cplusplus */
 
 /* C99 requires __STDC__ to be defined as 1. */
 #if defined (__STDC__)
 
 #define YY_USE_CONST
 
-#endif /* defined (__STDC__) */
-#endif /* ! __cplusplus */
+#endif /* defined (__STDC__) */
+#endif /* ! __cplusplus */
 
 #ifdef YY_USE_CONST
 #define yyconst const
@@ -195,14 +195,14 @@ extern FILE *surf_parse_in, *surf_parse_out;
      *       a 5% performance hit in a non-surf_parse_lineno scanner, because yy_act is
      *       normally declared as a register variable-- so it is not worth it.
      */
-#define  YY_LESS_LINENO(n) \
+    #define  YY_LESS_LINENO(n) \
             do { \
                 int yyl;\
                 for ( yyl = n; yyl < surf_parse_leng; ++yyl )\
                     if ( surf_parse_text[yyl] == '\n' )\
                         --surf_parse_lineno;\
             }while(0)
-
+    
 /* Return all but the first "n" matched characters back to the input stream. */
 #define yyless(n) \
        do \
@@ -226,72 +226,73 @@ typedef size_t yy_size_t;
 
 #ifndef YY_STRUCT_YY_BUFFER_STATE
 #define YY_STRUCT_YY_BUFFER_STATE
-struct yy_buffer_state {
-  FILE *yy_input_file;
-
-  char *yy_ch_buf;              /* input buffer */
-  char *yy_buf_pos;             /* current position in input buffer */
-
-  /* Size of input buffer in bytes, not including room for EOB
-   * characters.
-   */
-  yy_size_t yy_buf_size;
-
-  /* Number of characters read into yy_ch_buf, not including EOB
-   * characters.
-   */
-  int yy_n_chars;
-
-  /* Whether we "own" the buffer - i.e., we know we created it,
-   * and can realloc() it to grow it, and should free() it to
-   * delete it.
-   */
-  int yy_is_our_buffer;
-
-  /* Whether this is an "interactive" input source; if so, and
-   * if we're using stdio for input, then we want to use getc()
-   * instead of fread(), to make sure we stop fetching input after
-   * each newline.
-   */
-  int yy_is_interactive;
-
-  /* Whether we're considered to be at the beginning of a line.
-   * If so, '^' rules will be active on the next match, otherwise
-   * not.
-   */
-  int yy_at_bol;
-
-  int yy_bs_lineno;   /**< The line count. */
-  int yy_bs_column;   /**< The column count. */
-
-  /* Whether to try to fill the input buffer when we reach the
-   * end of it.
-   */
-  int yy_fill_buffer;
-
-  int yy_buffer_status;
+struct yy_buffer_state
+       {
+       FILE *yy_input_file;
+
+       char *yy_ch_buf;                /* input buffer */
+       char *yy_buf_pos;               /* current position in input buffer */
+
+       /* Size of input buffer in bytes, not including room for EOB
+        * characters.
+        */
+       yy_size_t yy_buf_size;
+
+       /* Number of characters read into yy_ch_buf, not including EOB
+        * characters.
+        */
+       int yy_n_chars;
+
+       /* Whether we "own" the buffer - i.e., we know we created it,
+        * and can realloc() it to grow it, and should free() it to
+        * delete it.
+        */
+       int yy_is_our_buffer;
+
+       /* Whether this is an "interactive" input source; if so, and
+        * if we're using stdio for input, then we want to use getc()
+        * instead of fread(), to make sure we stop fetching input after
+        * each newline.
+        */
+       int yy_is_interactive;
+
+       /* Whether we're considered to be at the beginning of a line.
+        * If so, '^' rules will be active on the next match, otherwise
+        * not.
+        */
+       int yy_at_bol;
+
+    int yy_bs_lineno; /**< The line count. */
+    int yy_bs_column; /**< The column count. */
+    
+       /* Whether to try to fill the input buffer when we reach the
+        * end of it.
+        */
+       int yy_fill_buffer;
+
+       int yy_buffer_status;
 
 #define YY_BUFFER_NEW 0
 #define YY_BUFFER_NORMAL 1
-  /* When an EOF's been seen but there's still some text to process
-   * then we mark the buffer as YY_EOF_PENDING, to indicate that we
-   * shouldn't try reading from the input source any more.  We might
-   * still have a bunch of tokens to match, though, because of
-   * possible backing-up.
-   *
-   * When we actually see the EOF, we change the status to "new"
-   * (via surf_parse_restart()), so that the user can continue scanning by
-   * just pointing surf_parse_in at a new input file.
-   */
+       /* When an EOF's been seen but there's still some text to process
+        * then we mark the buffer as YY_EOF_PENDING, to indicate that we
+        * shouldn't try reading from the input source any more.  We might
+        * still have a bunch of tokens to match, though, because of
+        * possible backing-up.
+        *
+        * When we actually see the EOF, we change the status to "new"
+        * (via surf_parse_restart()), so that the user can continue scanning by
+        * just pointing surf_parse_in at a new input file.
+        */
 #define YY_BUFFER_EOF_PENDING 2
 
-};
+       };
 #endif /* !YY_STRUCT_YY_BUFFER_STATE */
 
 /* Stack of input buffers. */
 static size_t yy_buffer_stack_top = 0; /**< index of top of stack. */
 static size_t yy_buffer_stack_max = 0; /**< capacity of stack. */
-static YY_BUFFER_STATE *yy_buffer_stack = 0;  /**< Stack as an array. */
+static YY_BUFFER_STATE * yy_buffer_stack = 0; /**< Stack as an array. */
 
 /* We provide macros for accessing buffer states in case in the
  * future we want to put the buffer states in a more general
@@ -310,40 +311,40 @@ static YY_BUFFER_STATE *yy_buffer_stack = 0;  /**< Stack as an array. */
 
 /* yy_hold_char holds the character lost when surf_parse_text is formed. */
 static char yy_hold_char;
-static int yy_n_chars;          /* number of characters read into yy_ch_buf */
+static int yy_n_chars;         /* number of characters read into yy_ch_buf */
 int surf_parse_leng;
 
 /* Points to current character in buffer. */
 static char *yy_c_buf_p = (char *) 0;
-static int yy_init = 0;         /* whether we need to initialize */
-static int yy_start = 0;        /* start state number */
+static int yy_init = 0;                /* whether we need to initialize */
+static int yy_start = 0;       /* start state number */
 
 /* Flag which is used to allow surf_parse_wrap()'s to do buffer switches
  * instead of setting up a fresh surf_parse_in.  A bit of a hack ...
  */
 static int yy_did_buffer_switch_on_eof;
 
-void surf_parse_restart(FILE * input_file);
-void surf_parse__switch_to_buffer(YY_BUFFER_STATE new_buffer);
-YY_BUFFER_STATE surf_parse__create_buffer(FILE * file, int size);
-void surf_parse__delete_buffer(YY_BUFFER_STATE b);
-void surf_parse__flush_buffer(YY_BUFFER_STATE b);
-void surf_parse_push_buffer_state(YY_BUFFER_STATE new_buffer);
-void surf_parse_pop_buffer_state(void);
+void surf_parse_restart (FILE *input_file  );
+void surf_parse__switch_to_buffer (YY_BUFFER_STATE new_buffer  );
+YY_BUFFER_STATE surf_parse__create_buffer (FILE *file,int size  );
+void surf_parse__delete_buffer (YY_BUFFER_STATE b  );
+void surf_parse__flush_buffer (YY_BUFFER_STATE b  );
+void surf_parse_push_buffer_state (YY_BUFFER_STATE new_buffer  );
+void surf_parse_pop_buffer_state (void );
 
-static void surf_parse_ensure_buffer_stack(void);
-static void surf_parse__load_buffer_state(void);
-static void surf_parse__init_buffer(YY_BUFFER_STATE b, FILE * file);
+static void surf_parse_ensure_buffer_stack (void );
+static void surf_parse__load_buffer_state (void );
+static void surf_parse__init_buffer (YY_BUFFER_STATE b,FILE *file  );
 
 #define YY_FLUSH_BUFFER surf_parse__flush_buffer(YY_CURRENT_BUFFER )
 
-YY_BUFFER_STATE surf_parse__scan_buffer(char *base, yy_size_t size);
-YY_BUFFER_STATE surf_parse__scan_string(yyconst char *yy_str);
-YY_BUFFER_STATE surf_parse__scan_bytes(yyconst char *bytes, int len);
+YY_BUFFER_STATE surf_parse__scan_buffer (char *base,yy_size_t size  );
+YY_BUFFER_STATE surf_parse__scan_string (yyconst char *yy_str  );
+YY_BUFFER_STATE surf_parse__scan_bytes (yyconst char *bytes,int len  );
 
-void *surf_parse_alloc(yy_size_t);
-void *surf_parse_realloc(void *, yy_size_t);
-void surf_parse_free(void *);
+void *surf_parse_alloc (yy_size_t  );
+void *surf_parse_realloc (void *,yy_size_t  );
+void surf_parse_free (void *  );
 
 #define yy_new_buffer surf_parse__create_buffer
 
@@ -387,10 +388,10 @@ int surf_parse_lineno = 1;
 extern char *surf_parse_text;
 #define yytext_ptr surf_parse_text
 
-static yy_state_type yy_get_previous_state(void);
-static yy_state_type yy_try_NUL_trans(yy_state_type current_state);
-static int yy_get_next_buffer(void);
-static void yy_fatal_error(yyconst char msg[]);
+static yy_state_type yy_get_previous_state (void );
+static yy_state_type yy_try_NUL_trans (yy_state_type current_state  );
+static int yy_get_next_buffer (void );
+static void yy_fatal_error (yyconst char msg[]  );
 
 /* Done after the current pattern has been matched and before the
  * corresponding action - sets up surf_parse_text.
@@ -402,2386 +403,2409 @@ static void yy_fatal_error(yyconst char msg[]);
        *yy_cp = '\0'; \
        (yy_c_buf_p) = yy_cp;
 
-#define YY_NUM_RULES 351
-#define YY_END_OF_BUFFER 352
+#define YY_NUM_RULES 353
+#define YY_END_OF_BUFFER 354
 /* This struct is not used in this scanner,
    but its presence is necessary. */
-struct yy_trans_info {
-  flex_int32_t yy_verify;
-  flex_int32_t yy_nxt;
-};
-static yyconst flex_int16_t yy_accept[2023] = { 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 352, 350, 15, 10, 10, 15, 15, 330,
-  10, 330, 5, 6, 5, 8, 9, 8, 346, 338,
-  339, 347, 344, 347, 345, 349, 338, 339, 349, 350,
-  26, 10, 26, 26, 26, 24, 26, 26, 30, 10,
-  30, 30, 350, 350, 30, 37, 10, 37, 37, 37,
-  35, 37, 41, 10, 41, 52, 10, 52, 52, 52,
-
-  50, 52, 52, 52, 347, 346, 74, 10, 74, 74,
-  74, 72, 74, 74, 74, 74, 78, 10, 78, 350,
-  78, 97, 10, 97, 97, 97, 95, 97, 97, 97,
-  101, 10, 101, 114, 10, 114, 114, 114, 112, 114,
-  114, 114, 114, 118, 10, 118, 125, 10, 125, 125,
-  125, 123, 125, 350, 350, 129, 10, 129, 156, 10,
-  156, 156, 156, 154, 156, 156, 156, 156, 156, 160,
-  10, 160, 160, 169, 10, 169, 169, 169, 167, 169,
-  169, 173, 10, 173, 196, 10, 196, 196, 196, 194,
-  196, 196, 196, 196, 196, 196, 200, 10, 200, 207,
-
-  10, 207, 207, 207, 205, 207, 211, 10, 211, 236,
-  10, 236, 236, 236, 234, 236, 236, 236, 236, 240,
-  10, 240, 240, 259, 10, 259, 259, 259, 257, 259,
-  259, 259, 350, 263, 10, 263, 263, 286, 10, 286,
-  286, 286, 284, 286, 286, 286, 286, 290, 10, 290,
-  290, 297, 10, 297, 297, 297, 295, 297, 301, 10,
-  301, 314, 10, 314, 314, 314, 312, 314, 314, 314,
-  314, 318, 10, 318, 350, 318, 325, 10, 325, 325,
-  325, 323, 325, 329, 10, 329, 10, 0, 2, 2,
-  0, 4, 7, 341, 340, 0, 0, 0, 0, 0,
-
-  0, 0, 25, 27, 27, 27, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 36,
-  38, 38, 0, 51, 53, 53, 53, 53, 0, 0,
-  0, 73, 75, 75, 75, 75, 75, 75, 75, 0,
-  0, 96, 98, 98, 98, 98, 0, 113, 115, 115,
-  115, 115, 115, 0, 124, 126, 126, 0, 155, 157,
-  157, 157, 157, 157, 157, 157, 0, 168, 170, 170,
-  170, 0, 195, 197, 197, 197, 197, 197, 197, 197,
-  197, 197, 0, 206, 208, 208, 0, 235, 237, 237,
-
-  237, 237, 237, 237, 0, 258, 260, 260, 260, 260,
-  260, 0, 0, 285, 287, 287, 287, 287, 287, 0,
-  296, 298, 298, 0, 313, 315, 315, 315, 315, 315,
-  0, 0, 324, 326, 326, 0, 0, 0, 0, 0,
-  3, 0, 0, 0, 0, 0, 0, 0, 348, 0,
-  27, 27, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 38,
-  0, 0, 53, 0, 0, 53, 0, 0, 0, 343,
-  75, 0, 0, 75, 75, 75, 75, 0, 0, 0,
-
-  98, 98, 98, 0, 0, 0, 0, 115, 115, 115,
-  0, 0, 126, 0, 0, 157, 0, 0, 157, 157,
-  157, 157, 0, 0, 0, 0, 170, 0, 0, 197,
-  0, 0, 0, 0, 197, 197, 197, 197, 197, 0,
-  0, 0, 0, 0, 0, 237, 0, 0, 237, 237,
-  237, 0, 0, 260, 260, 260, 260, 0, 0, 0,
-  287, 287, 287, 287, 0, 0, 0, 0, 0, 0,
-  315, 315, 315, 315, 0, 0, 0, 326, 0, 0,
-  0, 14, 1, 0, 0, 336, 0, 0, 0, 333,
-  332, 0, 0, 27, 27, 0, 0, 29, 0, 0,
-
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 103,
-  0, 0, 0, 0, 0, 0, 0, 102, 0, 0,
-  0, 0, 0, 0, 38, 0, 0, 40, 0, 53,
-  0, 45, 44, 53, 0, 0, 0, 55, 0, 75,
-  0, 59, 58, 0, 0, 75, 0, 0, 75, 0,
-  0, 77, 0, 0, 98, 98, 98, 0, 0, 100,
-  0, 0, 105, 104, 115, 115, 115, 0, 0, 117,
-  0, 126, 0, 0, 128, 0, 157, 0, 133, 132,
-  157, 157, 157, 157, 0, 0, 159, 0, 0, 164,
-  163, 170, 0, 0, 172, 0, 197, 197, 0, 187,
-
-  186, 0, 177, 176, 0, 0, 197, 197, 197, 197,
-  0, 0, 199, 0, 0, 204, 203, 0, 0, 210,
-  0, 237, 0, 215, 214, 237, 237, 237, 0, 0,
-  239, 0, 260, 0, 0, 0, 0, 260, 0, 0,
-  0, 262, 0, 287, 0, 0, 287, 0, 0, 0,
-  0, 289, 0, 0, 294, 293, 0, 0, 300, 0,
-  315, 315, 315, 315, 0, 0, 317, 0, 0, 326,
-  0, 0, 328, 0, 0, 0, 337, 331, 0, 0,
-  0, 27, 27, 0, 0, 0, 0, 131, 0, 213,
-  0, 0, 161, 0, 0, 103, 0, 0, 0, 130,
-
-  212, 0, 0, 102, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 53, 0, 0, 75, 0,
-  63, 62, 0, 0, 0, 61, 60, 75, 0, 162,
-  98, 0, 0, 98, 0, 115, 115, 115, 0, 126,
-  0, 157, 157, 157, 157, 157, 0, 170, 0, 197,
-  197, 0, 189, 188, 197, 197, 197, 197, 0, 0,
-  237, 237, 237, 237, 0, 260, 0, 246, 245, 0,
-  244, 243, 260, 212, 0, 287, 0, 269, 268, 287,
-  0, 267, 266, 0, 0, 315, 0, 0, 315, 315,
-  0, 0, 326, 0, 0, 0, 0, 12, 0, 334,
-
-  335, 0, 27, 27, 0, 0, 0, 0, 131, 0,
-  213, 0, 0, 0, 161, 0, 265, 43, 0, 0,
-  130, 212, 0, 265, 42, 0, 264, 0, 264, 42,
-  0, 34, 33, 0, 0, 47, 46, 53, 0, 0,
-  75, 0, 65, 64, 75, 0, 162, 98, 0, 0,
-  0, 0, 0, 0, 115, 115, 115, 0, 116, 126,
-  0, 157, 157, 157, 0, 0, 0, 0, 157, 0,
-  0, 0, 0, 0, 0, 197, 0, 0, 197, 197,
-  197, 0, 0, 237, 237, 237, 0, 0, 237, 0,
-  260, 260, 0, 0, 287, 287, 0, 0, 315, 0,
-
-  305, 304, 315, 315, 0, 0, 0, 0, 0, 0,
-  0, 0, 11, 0, 27, 27, 27, 0, 0, 0,
-  0, 0, 0, 0, 0, 57, 265, 0, 202, 43,
-  0, 0, 0, 56, 201, 42, 0, 264, 0, 0,
-  0, 0, 53, 0, 0, 75, 75, 0, 98, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 92, 91,
-  0, 0, 0, 115, 0, 0, 0, 0, 0, 157,
-  157, 157, 0, 135, 134, 0, 0, 0, 157, 0,
-  158, 0, 166, 165, 0, 171, 0, 191, 190, 0,
-  0, 0, 185, 184, 0, 0, 197, 0, 0, 0,
-
-  0, 237, 237, 237, 0, 0, 0, 237, 0, 238,
-  0, 0, 260, 0, 0, 0, 0, 287, 0, 0,
-  315, 315, 315, 0, 0, 0, 322, 321, 0, 0,
-  0, 0, 0, 0, 0, 27, 27, 0, 0, 175,
-  120, 32, 0, 0, 303, 57, 0, 202, 0, 174,
-  119, 56, 201, 302, 0, 31, 0, 0, 53, 0,
-  0, 54, 75, 75, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 107,
-  106, 0, 0, 0, 109, 108, 0, 122, 121, 0,
-  157, 157, 157, 0, 0, 157, 0, 193, 192, 0,
-
-  179, 178, 0, 0, 0, 181, 180, 0, 0, 237,
-  0, 0, 237, 237, 0, 0, 237, 0, 0, 0,
-  260, 0, 0, 0, 0, 0, 287, 0, 288, 0,
-  315, 315, 315, 0, 0, 0, 0, 0, 0, 17,
-  0, 19, 18, 27, 27, 0, 319, 175, 120, 32,
-  291, 16, 303, 0, 0, 174, 119, 302, 0, 31,
-  0, 0, 53, 342, 75, 75, 0, 76, 0, 94,
-  93, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 111, 110, 0, 157, 157, 157, 0,
-  0, 0, 0, 157, 0, 183, 182, 0, 0, 209,
-
-  237, 0, 221, 220, 237, 237, 0, 0, 0, 0,
-  237, 0, 0, 0, 0, 260, 292, 0, 0, 0,
-  0, 0, 287, 0, 0, 0, 315, 315, 0, 320,
-  0, 0, 0, 0, 17, 27, 27, 0, 319, 291,
-  16, 0, 0, 0, 0, 0, 39, 53, 0, 0,
-  75, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 127, 157, 157, 157, 0, 141, 0,
-  140, 157, 0, 198, 0, 0, 237, 237, 237, 0,
-  225, 0, 224, 237, 0, 0, 0, 0, 0, 0,
-  0, 0, 292, 0, 0, 0, 0, 0, 0, 0,
-
-  287, 0, 0, 307, 306, 0, 0, 315, 0, 316,
-  320, 0, 0, 0, 0, 0, 0, 27, 0, 28,
-  0, 0, 0, 0, 53, 0, 0, 0, 75, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  157, 157, 157, 143, 142, 0, 0, 0, 217, 216,
-  237, 237, 237, 227, 226, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 287, 287, 0, 299, 0, 311, 310,
-  0, 0, 0, 327, 0, 0, 0, 0, 21, 20,
-  0, 0, 242, 0, 241, 0, 0, 0, 0, 0,
-
-  0, 0, 75, 0, 0, 0, 0, 84, 0, 0,
-  0, 0, 83, 0, 157, 157, 157, 0, 145, 144,
-  237, 237, 237, 0, 229, 228, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 287, 287, 0, 309, 308, 0, 0,
-  0, 0, 23, 22, 242, 0, 241, 0, 0, 49,
-  48, 0, 0, 0, 0, 75, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 157, 157, 157,
-  237, 0, 0, 237, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-
-  0, 287, 287, 0, 0, 0, 0, 80, 79, 0,
-  0, 0, 0, 0, 0, 0, 0, 90, 0, 0,
-  0, 89, 0, 0, 0, 137, 136, 157, 157, 157,
-  157, 237, 0, 223, 222, 237, 0, 0, 0, 0,
-  0, 0, 256, 0, 255, 0, 0, 261, 0, 0,
-  0, 0, 0, 0, 0, 0, 287, 0, 0, 287,
-  0, 0, 0, 0, 0, 0, 80, 79, 0, 0,
-  0, 0, 0, 67, 66, 0, 0, 0, 0, 0,
-  0, 0, 157, 157, 157, 157, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 254, 253, 0, 0,
-
-  0, 0, 0, 0, 0, 273, 272, 287, 0, 271,
-  270, 287, 0, 0, 0, 0, 0, 0, 0, 71,
-  0, 70, 88, 0, 0, 87, 0, 0, 0, 99,
-  157, 157, 157, 157, 0, 219, 218, 0, 0, 0,
-  0, 0, 250, 0, 0, 249, 0, 0, 281, 0,
-  0, 280, 287, 287, 0, 0, 0, 12, 0, 12,
-  0, 0, 0, 82, 86, 81, 85, 157, 157, 157,
-  157, 0, 0, 0, 0, 252, 248, 251, 247, 283,
-  279, 282, 278, 287, 287, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 157, 0,
-
-  0, 0, 0, 0, 0, 287, 287, 0, 0, 69,
-  68, 0, 139, 138, 0, 149, 148, 0, 147, 146,
-  157, 0, 153, 152, 0, 0, 0, 0, 287, 287,
-  0, 11, 157, 0, 0, 0, 0, 287, 287, 0,
-  157, 0, 0, 0, 0, 287, 287, 0, 157, 0,
-  0, 0, 0, 287, 287, 0, 0, 0, 0, 231,
-  0, 230, 287, 287, 0, 0, 151, 150, 233, 232,
-  287, 287, 0, 287, 287, 0, 287, 287, 0, 0,
-  287, 287, 0, 0, 287, 287, 0, 0, 287, 287,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 277,
-
-  276, 0, 275, 274, 0, 0, 0, 0, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-  13, 0
-};
-
-static yyconst flex_int32_t yy_ec[256] = { 0,
-  1, 1, 1, 1, 1, 1, 1, 1, 2, 3,
-  1, 2, 4, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 2, 5, 6, 7, 1, 1, 8, 9, 1,
-  1, 1, 1, 1, 10, 11, 12, 13, 13, 13,
-  13, 14, 13, 13, 13, 15, 13, 16, 17, 18,
-  19, 20, 21, 1, 22, 23, 24, 25, 26, 27,
-  28, 29, 30, 28, 31, 32, 33, 34, 35, 36,
-  28, 37, 38, 39, 28, 40, 41, 28, 42, 28,
-  43, 1, 44, 1, 45, 1, 46, 47, 48, 49,
-
-  50, 51, 52, 53, 54, 28, 55, 56, 57, 58,
-  59, 60, 61, 62, 63, 64, 65, 66, 67, 68,
-  69, 28, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-  1, 1, 1, 1, 1
-};
-
-static yyconst flex_int32_t yy_meta[70] = { 0,
-  1, 2, 2, 2, 1, 1, 1, 1, 1, 3,
-  3, 1, 4, 4, 4, 5, 6, 1, 7, 8,
-  1, 9, 9, 9, 9, 9, 9, 5, 5, 5,
-  5, 5, 5, 5, 5, 5, 5, 5, 5, 5,
-  5, 5, 1, 1, 5, 9, 9, 9, 9, 9,
-  9, 5, 5, 5, 5, 5, 5, 5, 5, 5,
-  5, 5, 5, 5, 5, 5, 5, 5, 5
-};
-
-static yyconst flex_int16_t yy_base[2256] = { 0,
-  0, 0, 0, 3, 6, 9, 12, 29, 16, 19,
-  14, 17, 33, 36, 49, 55, 45, 61, 66, 72,
-  105, 173, 75, 78, 83, 125, 128, 132, 135, 138,
-  193, 196, 200, 203, 206, 224, 242, 293, 262, 265,
-  344, 404, 271, 273, 464, 527, 269, 316, 320, 323,
-  364, 367, 371, 374, 590, 654, 424, 427, 718, 781,
-  431, 434, 844, 907, 484, 487, 491, 494, 497, 547,
-  970, 1033, 550, 554, 557, 560, 610, 613, 617, 620,
-  1096, 1162, 623, 674, 1228, 0, 677, 681, 1297, 1351,
-  684, 687, 1405, 1468, 738, 741, 745, 748, 751, 801,
-
-  804, 808, 1531, 1594, 811, 814, 864, 867, 871, 874,
-  877, 927, 1657, 1720, 930, 934, 937, 940, 990, 993,
-  997, 1000, 1783, 1837, 1003, 1053, 1891, 1954, 1056, 1060,
-  1063, 1066, 1116, 1119, 1123, 1126, 2017, 2083, 1129, 1182,
-  0, 0, 5066, 7094, 7094, 95, 100, 29, 41, 7094,
-  155, 51, 7094, 7094, 5055, 7094, 7094, 5043, 7094, 5058,
-  5042, 1141, 7094, 7094, 7094, 7094, 5036, 5032, 4990, 210,
-  7094, 158, 5012, 0, 142, 7094, 4977, 4969, 7094, 162,
-  2145, 2205, 160, 5007, 176, 7094, 165, 4998, 0, 149,
-  7094, 4961, 7094, 230, 378, 7094, 326, 4994, 0, 208,
-
-  7094, 4958, 4949, 4947, 379, 4950, 7094, 329, 4972, 0,
-  214, 7094, 4938, 4937, 238, 4915, 7094, 377, 11, 31,
-  4965, 7094, 399, 4948, 0, 435, 7094, 4907, 4905, 4888,
-  7094, 457, 441, 7094, 520, 4922, 0, 436, 7094, 4892,
-  4870, 4871, 4851, 7094, 583, 498, 7094, 640, 4894, 0,
-  499, 7094, 4862, 513, 4840, 7094, 644, 4879, 7094, 647,
-  4870, 0, 562, 7094, 4802, 34, 4821, 4797, 4788, 7094,
-  704, 177, 4838, 7094, 708, 4827, 0, 568, 7094, 4793,
-  4783, 7094, 711, 752, 7094, 772, 4808, 0, 631, 7094,
-  211, 4777, 4775, 93, 4773, 4753, 7094, 834, 818, 7094,
-
-  894, 4796, 0, 632, 7094, 4753, 7094, 897, 881, 7094,
-  901, 4781, 0, 695, 7094, 4739, 4735, 4736, 80, 7094,
-  957, 360, 4765, 7094, 960, 4755, 0, 696, 7094, 4726,
-  4709, 26, 304, 7094, 963, 330, 4746, 7094, 1149, 4726,
-  0, 885, 7094, 4694, 4675, 4679, 4673, 7094, 1152, 499,
-  4721, 7094, 1155, 4705, 0, 948, 7094, 4672, 7094, 1186,
-  1005, 7094, 1192, 4696, 0, 1004, 7094, 4650, 4654, 4655,
-  4643, 7094, 1205, 1100, 4694, 4691, 7094, 1208, 4678, 0,
-  1007, 7094, 4650, 7094, 1211, 1068, 1215, 429, 4627, 7094,
-  4683, 4665, 7094, 7094, 7094, 1306, 283, 4614, 4612, 4607,
-
-  4647, 4609, 7094, 0, 4598, 4601, 4586, 4583, 4584, 4580,
-  4574, 4570, 4573, 4, 166, 4567, 4554, 4558, 4546, 4545,
-  4541, 404, 4544, 4530, 38, 467, 4530, 712, 4523, 7094,
-  0, 4526, 4527, 7094, 0, 4523, 1320, 4516, 533, 4512,
-  4555, 7094, 0, 4514, 1323, 4486, 4507, 4493, 4497, 4477,
-  89, 7094, 0, 4488, 4462, 4473, 4453, 7094, 0, 1326,
-  4459, 4459, 4455, 4435, 7094, 0, 4429, 4441, 7094, 0,
-  4444, 1329, 4422, 4400, 4400, 4419, 4407, 7094, 0, 1373,
-  4398, 4393, 7094, 0, 4406, 1377, 1380, 4375, 4371, 4386,
-  4372, 4366, 4367, 7094, 0, 1383, 4348, 7094, 0, 4351,
-
-  1425, 4340, 4357, 4355, 4340, 7094, 0, 4327, 4326, 4340,
-  4326, 4323, 4308, 7094, 0, 4305, 4289, 4291, 4298, 4283,
-  7094, 0, 1428, 4287, 7094, 0, 4277, 4271, 4272, 4280,
-  4264, 4261, 7094, 0, 4265, 4267, 4286, 4295, 807, 4246,
-  7094, 1207, 0, 4229, 4229, 4269, 4268, 4224, 7094, 4231,
-  4213, 4213, 1431, 1434, 4218, 4203, 4205, 4201, 4215, 4194,
-  4202, 4187, 4187, 4178, 4170, 4186, 4165, 4167, 4164, 4155,
-  4154, 4145, 4145, 4157, 4143, 4135, 4141, 4122, 4139, 4128,
-  1437, 1489, 4127, 1494, 1497, 4108, 4137, 1551, 1556, 7094,
-  4106, 1559, 1514, 1562, 4097, 1565, 4108, 1619, 1627, 4090,
-
-  4091, 4097, 4083, 1622, 1630, 1677, 1583, 4079, 4065, 4067,
-  1682, 1695, 4068, 1685, 1740, 4058, 1691, 1642, 4059, 4062,
-  4056, 4037, 1745, 1748, 1751, 1710, 4035, 1755, 1808, 583,
-  1811, 1814, 1857, 1860, 1869, 4032, 4030, 4025, 4021, 1911,
-  1920, 1914, 1880, 1917, 1923, 4022, 1926, 1975, 4014, 3994,
-  3987, 1983, 1986, 3996, 1989, 1992, 3981, 3977, 2039, 2046,
-  3979, 1997, 3983, 2043, 2049, 2052, 2061, 2072, 2104, 2110,
-  3976, 3952, 3959, 3943, 2113, 2116, 3952, 3927, 2119, 2138,
-  3970, 7094, 7094, 315, 3922, 7094, 3934, 3933, 3878, 7094,
-  7094, 3872, 3870, 3879, 3868, 2141, 2149, 7094, 2168, 3865,
-
-  3859, 3871, 3849, 3854, 3849, 3830, 261, 3839, 3819, 1223,
-  3834, 3802, 3814, 3798, 3796, 3801, 3784, 1332, 3795, 384,
-  3777, 3784, 3774, 3788, 2144, 2172, 2177, 7094, 2182, 2209,
-  2216, 7094, 7094, 2229, 3810, 2232, 2235, 7094, 2240, 3756,
-  2268, 7094, 7094, 2243, 2276, 2287, 2290, 2293, 3767, 2301,
-  2308, 7094, 2311, 432, 3761, 2314, 3760, 2320, 2323, 7094,
-  2332, 2335, 7094, 7094, 3754, 3751, 3743, 2343, 2346, 7094,
-  2351, 3739, 2354, 2357, 7094, 2377, 3735, 2380, 7094, 7094,
-  3728, 3721, 3717, 3727, 2388, 2391, 7094, 2396, 2400, 7094,
-  7094, 3722, 2410, 2415, 7094, 2418, 3702, 3717, 2422, 7094,
-
-  7094, 2438, 7094, 7094, 2430, 2448, 3700, 3698, 3703, 3695,
-  2458, 2461, 7094, 2464, 2467, 7094, 7094, 2483, 2486, 7094,
-  2489, 3673, 2492, 7094, 7094, 3679, 3672, 3662, 2508, 2511,
-  7094, 2514, 3611, 2517, 2521, 2536, 2539, 3618, 3612, 2547,
-  2554, 7094, 2557, 3602, 2560, 2567, 3607, 2578, 2581, 2589,
-  2592, 7094, 2596, 2599, 7094, 7094, 2611, 2615, 7094, 2621,
-  3590, 2624, 3607, 3576, 2630, 2634, 7094, 2642, 3573, 3586,
-  2645, 2649, 7094, 2653, 726, 2656, 7094, 7094, 3618, 3616,
-  3569, 3560, 3587, 2664, 3545, 3528, 3544, 1386, 3520, 2152,
-  3533, 3532, 1460, 3512, 3519, 1463, 3518, 3502, 3518, 1523,
-
-  2678, 3504, 3511, 1526, 3497, 3496, 3494, 3478, 3491, 3490,
-  2668, 2686, 2694, 2700, 2704, 3489, 3504, 2713, 3479, 2718,
-  7094, 7094, 2727, 2732, 2745, 7094, 7094, 3473, 2740, 1650,
-  3457, 2753, 2760, 2771, 2774, 3446, 3466, 3439, 2777, 3457,
-  2780, 3458, 3452, 3436, 2783, 2789, 2801, 2807, 2811, 2814,
-  2821, 2833, 7094, 7094, 2825, 2843, 2847, 2850, 2853, 2856,
-  3442, 3447, 3431, 2876, 2879, 3430, 2885, 7094, 7094, 2894,
-  7094, 7094, 3418, 2903, 2906, 3419, 2921, 7094, 7094, 3412,
-  2929, 7094, 7094, 2937, 2940, 3420, 2910, 2943, 3401, 3418,
-  2951, 3402, 2959, 2962, 181, 3437, 2965, 7094, 3436, 7094,
-
-  7094, 3395, 3388, 518, 2970, 3395, 3393, 3394, 1705, 3391,
-  1769, 3387, 3375, 3365, 1774, 3370, 2973, 2977, 3375, 3365,
-  1777, 1829, 3354, 2984, 2994, 3347, 3000, 3358, 3003, 3009,
-  3020, 7094, 7094, 3030, 3034, 7094, 7094, 3351, 3362, 3049,
-  3328, 3052, 7094, 7094, 3325, 3064, 1832, 3325, 3068, 1059,
-  1113, 3045, 3076, 3084, 3087, 3090, 3094, 3098, 7094, 3108,
-  3112, 3337, 3333, 3317, 3117, 3122, 3135, 3138, 3328, 3146,
-  3149, 3153, 3161, 3167, 3170, 3180, 3185, 3188, 3198, 3203,
-  3206, 3209, 3212, 3328, 3307, 3321, 3216, 3224, 3321, 3234,
-  3237, 3241, 3322, 3244, 3247, 3265, 3268, 3273, 3310, 3276,
-
-  7094, 7094, 3313, 3302, 3288, 3306, 3293, 3296, 3311, 1422,
-  612, 568, 7094, 3279, 3317, 3320, 3323, 3326, 3282, 3275,
-  3282, 3267, 3252, 3249, 3246, 1875, 1945, 3250, 1948, 2010,
-  3258, 3242, 3248, 3330, 3341, 3345, 3224, 3348, 3229, 3233,
-  3233, 3351, 3226, 3243, 3355, 3204, 3207, 3358, 3361, 3236,
-  3222, 260, 3220, 3231, 3217, 421, 3207, 3384, 7094, 7094,
-  3392, 3395, 3400, 3414, 3417, 3420, 3428, 3435, 3446, 3180,
-  3169, 3172, 3449, 7094, 7094, 3458, 3188, 3186, 3149, 3466,
-  7094, 3469, 7094, 7094, 3477, 7094, 3481, 7094, 7094, 3489,
-  3496, 3507, 7094, 7094, 3515, 3518, 3526, 3529, 3533, 3547,
-
-  3550, 3134, 3553, 3151, 3556, 3160, 3158, 3131, 3571, 7094,
-  3574, 3577, 3585, 3116, 3597, 3592, 3612, 3603, 3606, 3621,
-  3120, 3120, 3121, 3625, 3109, 3628, 7094, 7094, 3640, 808,
-  1330, 747, 3104, 3644, 3647, 3655, 3662, 3669, 3096, 3673,
-  3676, 3680, 3087, 3086, 3683, 3689, 3070, 3692, 3074, 3695,
-  3698, 3701, 3704, 3707, 3065, 3712, 3070, 3715, 3068, 3074,
-  3718, 7094, 3046, 3061, 3721, 3726, 3730, 3071, 3065, 3044,
-  3047, 3035, 3041, 3035, 3024, 3026, 3018, 3740, 3744, 7094,
-  7094, 3752, 3755, 3764, 7094, 7094, 3772, 7094, 7094, 3780,
-  3001, 2995, 2985, 669, 743, 2986, 3783, 7094, 7094, 3792,
-
-  7094, 7094, 3800, 3803, 3811, 7094, 7094, 3819, 3822, 2988,
-  3825, 3828, 2988, 2970, 806, 857, 2972, 3843, 358, 361,
-  3851, 2962, 3854, 3857, 658, 785, 3865, 3869, 7094, 3873,
-  3876, 2968, 2960, 3883, 2950, 3894, 3888, 927, 1009, 3898,
-  3903, 7094, 7094, 3913, 3916, 3922, 3925, 3936, 3941, 3945,
-  3951, 3954, 3957, 2953, 2950, 3960, 3963, 3967, 2938, 3970,
-  2934, 3973, 2927, 7094, 3979, 2920, 3982, 7094, 3985, 7094,
-  7094, 2958, 2920, 2932, 2925, 2925, 2925, 2909, 2911, 2905,
-  2902, 3993, 3997, 7094, 7094, 4005, 2868, 2859, 2848, 2865,
-  2878, 2850, 2865, 2818, 4008, 7094, 7094, 4016, 4019, 7094,
-
-  4024, 4028, 7094, 7094, 2810, 2784, 2761, 2746, 2713, 2723,
-  2624, 81, 919, 466, 985, 4038, 4042, 4045, 474, 1048,
-  477, 1057, 4051, 4056, 4059, 4071, 4064, 527, 4082, 4085,
-  4088, 4091, 748, 840, 4095, 4101, 4113, 4119, 4122, 4125,
-  4131, 518, 548, 565, 624, 4134, 7094, 665, 4138, 4141,
-  706, 738, 786, 838, 838, 886, 894, 901, 915, 912,
-  931, 4156, 4162, 7094, 934, 971, 965, 1025, 7094, 1023,
-  7094, 4165, 4168, 7094, 4171, 4177, 998, 1005, 1019, 1080,
-  7094, 1115, 7094, 4189, 1109, 1100, 1117, 1135, 1140, 1165,
-  4192, 4195, 4203, 4213, 1166, 1160, 1173, 1175, 1165, 1178,
-
-  4216, 4219, 4222, 7094, 7094, 4234, 4238, 4247, 4252, 7094,
-  4255, 4258, 1293, 1347, 1384, 4271, 4278, 4289, 4292, 7094,
-  1169, 1287, 1284, 1293, 4295, 4298, 1366, 1470, 1285, 1316,
-  1325, 1349, 1371, 1391, 1368, 1378, 1397, 1423, 1437, 4307,
-  1381, 1403, 1403, 7094, 7094, 4313, 4316, 4327, 7094, 7094,
-  1402, 1410, 1430, 7094, 7094, 4335, 4338, 1457, 1463, 1468,
-  1468, 1469, 1474, 4346, 1548, 1549, 4354, 1477, 1480, 1485,
-  1519, 1518, 1534, 4357, 4360, 4364, 7094, 4369, 7094, 7094,
-  4378, 4383, 4391, 7094, 1573, 1552, 1559, 4396, 7094, 7094,
-  4404, 4410, 4422, 1525, 4425, 1540, 4428, 4431, 1579, 1598,
-
-  1590, 1606, 1577, 1611, 1601, 1607, 1615, 7094, 1631, 1642,
-  1641, 1650, 7094, 4439, 4442, 1646, 1659, 4446, 7094, 7094,
-  1661, 4454, 1670, 4460, 7094, 7094, 1699, 1710, 1730, 1724,
-  1726, 1741, 1747, 1779, 1771, 1782, 4468, 1772, 1783, 1795,
-  1785, 1788, 1799, 4472, 4475, 4493, 7094, 7094, 1916, 1833,
-  4481, 4501, 7094, 7094, 4478, 1765, 4509, 1801, 4512, 7094,
-  7094, 1845, 1834, 1852, 1841, 4522, 1848, 1868, 1901, 1910,
-  1899, 1917, 1932, 1931, 4525, 4528, 4531, 1919, 1995, 1921,
-  1952, 4540, 4546, 1935, 1980, 1989, 1999, 2009, 2018, 2033,
-  2062, 2032, 2062, 2035, 4554, 2047, 2053, 2048, 2069, 2083,
-
-  2076, 4558, 4561, 2108, 4564, 4567, 4587, 4595, 4598, 2091,
-  2104, 2097, 2107, 4606, 4609, 2105, 2105, 7094, 2107, 2109,
-  2130, 7094, 2132, 4617, 4620, 7094, 7094, 2111, 2117, 2123,
-  2131, 4628, 4632, 7094, 7094, 4640, 2157, 2149, 2162, 2164,
-  2156, 2169, 7094, 2189, 7094, 2194, 4646, 7094, 2179, 2172,
-  2190, 2191, 2187, 2198, 4649, 4652, 4660, 4667, 4671, 4680,
-  2204, 4685, 4688, 4708, 4747, 4791, 4698, 4716, 2202, 2223,
-  2215, 2232, 4720, 7094, 7094, 2243, 2218, 2222, 2248, 2232,
-  2234, 4737, 2217, 2227, 2218, 2217, 4741, 4728, 4759, 4767,
-  2257, 2259, 2281, 2272, 2275, 2292, 7094, 7094, 2281, 2283,
-
-  2313, 2294, 2304, 2321, 4777, 7094, 7094, 4785, 4811, 7094,
-  7094, 4803, 2345, 4821, 2356, 2355, 4857, 4901, 2318, 7094,
-  2328, 7094, 7094, 2345, 2361, 7094, 2359, 2361, 4829, 7094,
-  2322, 2307, 2336, 2337, 4834, 7094, 7094, 4842, 2410, 2418,
-  2382, 2390, 7094, 2392, 2396, 7094, 2404, 2417, 7094, 2418,
-  2420, 7094, 4851, 4869, 2423, 2452, 2454, 2430, 2488, 2437,
-  4877, 2438, 2440, 7094, 7094, 7094, 7094, 4880, 4892, 4921,
-  4924, 2457, 2453, 2461, 2470, 7094, 7094, 7094, 7094, 7094,
-  7094, 7094, 7094, 4927, 4932, 4935, 2494, 2481, 2495, 4945,
-  2499, 2498, 4950, 4883, 4954, 4958, 4968, 4972, 2460, 4980,
-
-  4987, 2487, 2510, 2494, 2513, 4998, 5001, 5004, 2517, 7094,
-  7094, 5007, 7094, 7094, 5019, 7094, 7094, 5027, 7094, 7094,
-  2494, 5035, 7094, 7094, 2510, 2510, 2516, 2516, 5045, 5048,
-  2546, 7094, 2517, 2538, 2549, 2548, 2560, 5051, 5054, 2569,
-  2538, 2570, 2585, 2575, 2595, 5057, 5075, 2601, 5078, 2603,
-  2624, 2613, 2633, 5081, 5084, 2665, 5087, 5110, 2657, 7094,
-  2655, 7094, 5118, 5121, 2666, 5139, 7094, 7094, 7094, 7094,
-  5147, 5150, 5153, 5156, 5159, 5168, 5182, 5187, 2655, 2663,
-  5194, 5201, 2658, 2691, 5205, 5208, 2680, 2738, 5212, 5226,
-  2673, 2719, 5231, 5237, 5253, 5256, 2703, 2739, 5264, 7094,
-
-  7094, 5273, 7094, 7094, 2778, 2787, 2747, 2750, 2850, 2852,
-  2799, 2818, 2689, 2748, 2855, 2866, 2800, 2881, 5281, 5284,
-  7094, 7094, 5304, 5313, 5322, 5331, 5340, 5349, 5358, 5367,
-  5376, 5385, 5394, 5403, 5412, 5421, 5430, 5439, 5448, 5457,
-  5466, 5475, 5484, 5493, 5502, 5511, 5520, 5529, 5538, 5547,
-  5556, 5565, 5574, 5583, 5592, 5601, 5610, 5619, 5628, 5637,
-  5646, 5653, 5660, 5667, 5674, 5681, 5688, 5695, 5702, 5709,
-  5716, 5723, 5730, 5737, 5744, 5751, 5758, 5765, 5774, 5779,
-  5784, 5789, 5794, 5799, 5804, 5809, 5814, 5819, 5826, 5831,
-  5838, 5843, 5850, 5855, 5862, 5867, 5874, 5879, 5886, 5891,
-
-  5898, 5903, 5910, 5915, 5924, 5930, 5937, 5945, 5952, 5960,
-  5967, 5975, 5982, 5990, 5997, 6005, 6012, 6020, 6027, 6035,
-  6042, 6050, 6057, 6065, 6072, 6080, 6088, 6095, 6103, 6110,
-  6118, 6125, 6133, 6141, 6148, 6156, 6163, 6171, 6180, 6186,
-  6193, 6201, 6209, 6217, 6225, 6233, 6240, 6248, 6255, 6263,
-  6270, 6278, 6285, 6293, 6300, 6308, 6315, 6323, 6330, 6338,
-  6346, 6353, 6361, 6368, 6376, 6383, 6391, 6399, 6406, 6414,
-  6421, 6429, 6438, 6447, 6454, 6462, 6470, 6477, 6485, 6492,
-  6500, 6507, 6515, 6522, 6530, 6537, 6545, 6552, 6560, 6568,
-  6576, 6584, 6592, 6600, 6607, 6615, 6622, 6630, 6637, 6645,
-
-  6653, 6660, 6668, 6676, 6684, 6693, 6702, 6709, 6717, 6725,
-  6732, 6740, 6747, 6755, 6762, 6770, 6778, 6786, 6794, 6801,
-  6809, 6817, 6825, 6833, 6841, 6848, 6856, 6864, 6872, 6880,
-  6888, 6896, 6903, 6911, 6919, 6928, 6937, 6945, 6953, 6961,
-  6968, 6976, 6983, 6991, 6999, 7007, 7015, 7023, 7030, 7039,
-  7048, 7057, 7066, 7075, 7084
-};
-
-static yyconst flex_int16_t yy_def[2256] = { 0,
-  2023, 2023, 2024, 2024, 2024, 2024, 2025, 2025, 2026, 2026,
-  2027, 2027, 2028, 2028, 2028, 2028, 2029, 2029, 2023, 2023,
-  2030, 2030, 2031, 2031, 2031, 2031, 2023, 2023, 2031, 2031,
-  2023, 2023, 2031, 2031, 2031, 2031, 2032, 2032, 2033, 2033,
-  2034, 2034, 2028, 2028, 2035, 2035, 2036, 2036, 2023, 2023,
-  2036, 2036, 2036, 2036, 2037, 2037, 2038, 2038, 2039, 2039,
-  2040, 2040, 2041, 2041, 2023, 2023, 2023, 2023, 2042, 2042,
-  2043, 2043, 2044, 2044, 2023, 2023, 2044, 2044, 2044, 2044,
-  2045, 2045, 2046, 2046, 2022, 85, 2047, 2047, 2048, 2048,
-  2049, 2049, 2050, 2050, 2051, 2051, 2023, 2023, 2051, 2051,
-
-  2051, 2051, 2052, 2052, 2023, 2023, 2023, 2023, 2053, 2053,
-  2053, 2053, 2054, 2054, 2055, 2055, 2023, 2023, 2055, 2055,
-  2055, 2055, 2056, 2056, 2057, 2057, 2058, 2058, 2059, 2059,
-  2023, 2023, 2059, 2059, 2059, 2059, 2060, 2060, 2061, 2061,
-  2023, 2023, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2062, 2022, 2022, 2062, 2062, 2022, 2022,
-  2022, 2022, 181, 182, 182, 2022, 2022, 2022, 2063, 2022,
-  2022, 2063, 2022, 2022, 2022, 2022, 2022, 2022, 2064, 2022,
-
-  2022, 2064, 2064, 2064, 2022, 2022, 2022, 2022, 2022, 2065,
-  2022, 2022, 2065, 2065, 2065, 2065, 2022, 2022, 185, 185,
-  185, 2022, 2022, 2022, 2066, 2022, 2022, 2066, 2066, 2066,
-  2022, 2022, 2022, 2022, 2022, 2022, 2067, 2022, 2022, 2067,
-  2067, 2067, 2067, 2022, 2022, 2022, 2022, 2022, 2022, 2068,
-  2022, 2022, 2068, 185, 254, 2022, 2022, 185, 2022, 2022,
-  2022, 2069, 2022, 2022, 2069, 2069, 2069, 2069, 2069, 2022,
-  2022, 185, 185, 2022, 2022, 2022, 2070, 2022, 2022, 2070,
-  2070, 2022, 2022, 2022, 2022, 2022, 2022, 2071, 2022, 2022,
-  2071, 2071, 2071, 2071, 2071, 2071, 2022, 2022, 2022, 2022,
-
-  2022, 2022, 2072, 2022, 2022, 2072, 2022, 2022, 2022, 2022,
-  2022, 2022, 2073, 2022, 2022, 2073, 2073, 2073, 2073, 2022,
-  2022, 185, 185, 2022, 2022, 2022, 2074, 2022, 2022, 2074,
-  2074, 2074, 185, 2022, 2022, 185, 185, 2022, 2022, 2022,
-  2075, 2022, 2022, 2075, 2075, 2075, 2075, 2022, 2022, 185,
-  185, 2022, 2022, 2022, 2076, 2022, 2022, 2076, 2022, 2022,
-  2022, 2022, 2022, 2022, 2077, 2022, 2022, 2077, 2077, 2077,
-  2077, 2022, 2022, 185, 374, 185, 2022, 2022, 2022, 2078,
-  2022, 2022, 2078, 2022, 2022, 2022, 2022, 2079, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-
-  2022, 2022, 2022, 2062, 2062, 2062, 2080, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2063, 2063, 2081, 2022, 2064, 2064, 2064, 2064, 2022, 2082,
-  2022, 2022, 2065, 2065, 2065, 2065, 2065, 2065, 2065, 2083,
-  2022, 2022, 2066, 2066, 2066, 2066, 2084, 2022, 2067, 2067,
-  2067, 2067, 2067, 2085, 2022, 2068, 2068, 2086, 2022, 2069,
-  2069, 2069, 2069, 2069, 2069, 2069, 2087, 2022, 2070, 2070,
-  2070, 2088, 2022, 2089, 2089, 2089, 2089, 2089, 2089, 2089,
-  2089, 2089, 2090, 2022, 2091, 2091, 2092, 2022, 2093, 2093,
-
-  2093, 2093, 2093, 2093, 2094, 2022, 2095, 2095, 2095, 2095,
-  2095, 2022, 2096, 2022, 2097, 2097, 2097, 2097, 2097, 2098,
-  2022, 2099, 2099, 2100, 2022, 2101, 2101, 2101, 2101, 2101,
-  2102, 2022, 2022, 2103, 2103, 2104, 2105, 2022, 2105, 2022,
-  2022, 2022, 2106, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2107, 2107, 2108, 2108, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2109,
-  2110, 2110, 2111, 2022, 2022, 2111, 2022, 2112, 2112, 2022,
-  2113, 2022, 2022, 2113, 2113, 2113, 2113, 2114, 2114, 2022,
-
-  2115, 2115, 2115, 2116, 2116, 2022, 2022, 2117, 2117, 2117,
-  2118, 2118, 2119, 2120, 2120, 2121, 2022, 2022, 2121, 2121,
-  2121, 2121, 2122, 2122, 2022, 2022, 2123, 2124, 2124, 2125,
-  2022, 2022, 2022, 2022, 2125, 2125, 2125, 2125, 2125, 2126,
-  2126, 2022, 2022, 2127, 2127, 2128, 2022, 2022, 2128, 2128,
-  2128, 2129, 2129, 2130, 2130, 2130, 2130, 2022, 2131, 2131,
-  2132, 2132, 2132, 2132, 2133, 2133, 2022, 2022, 2134, 2134,
-  2135, 2135, 2135, 2135, 2136, 2136, 2022, 2137, 2138, 2138,
-  2139, 2022, 2022, 2139, 2022, 2022, 2140, 2022, 2022, 2022,
-  2022, 2022, 2022, 2141, 2141, 2022, 2142, 2022, 2142, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2143, 2022, 2144, 2022, 2144, 2145,
-  2022, 2022, 2022, 2145, 2022, 2022, 2146, 2022, 2146, 2147,
-  2022, 2022, 2022, 2022, 2022, 2147, 2022, 2022, 2147, 2022,
-  2148, 2022, 2148, 2022, 2149, 2149, 2149, 2022, 2150, 2022,
-  2150, 2022, 2022, 2022, 2151, 2151, 2151, 2022, 2152, 2022,
-  2152, 2153, 2022, 2154, 2022, 2154, 2155, 2022, 2022, 2022,
-  2155, 2155, 2155, 2155, 2022, 2156, 2022, 2156, 2022, 2022,
-  2022, 2157, 2022, 2158, 2022, 2158, 2159, 2159, 2022, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 2022, 2159, 2159, 2159, 2159,
-  2022, 2160, 2022, 2160, 2022, 2022, 2022, 2022, 2161, 2022,
-  2161, 2162, 2022, 2022, 2022, 2162, 2162, 2162, 2022, 2163,
-  2022, 2163, 2164, 2022, 2022, 2022, 2022, 2164, 2022, 2022,
-  2165, 2022, 2165, 2166, 2022, 2022, 2166, 2022, 2022, 2022,
-  2167, 2022, 2167, 2022, 2022, 2022, 2022, 2168, 2022, 2168,
-  2169, 2169, 2169, 2169, 2022, 2170, 2022, 2170, 2022, 2171,
-  2022, 2172, 2022, 2172, 2173, 2174, 2022, 2022, 2022, 2022,
-  2022, 2175, 2175, 2176, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2177, 2022, 2022, 2178, 2022, 2179, 2180, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2180, 2181, 2022,
-  2182, 2022, 2022, 2182, 2183, 2184, 2184, 2184, 2185, 2186,
-  2187, 2188, 2188, 2188, 2188, 2188, 2189, 2190, 2191, 2192,
-  2192, 2022, 2022, 2022, 2192, 2192, 2192, 2192, 2193, 2194,
-  2195, 2195, 2195, 2195, 2196, 2197, 2022, 2022, 2022, 2022,
-  2022, 2022, 2197, 2022, 2198, 2199, 2022, 2022, 2022, 2199,
-  2022, 2022, 2022, 2200, 2201, 2202, 2022, 2022, 2202, 2202,
-  2203, 2022, 2204, 2205, 2206, 2207, 2207, 2022, 2207, 2022,
-
-  2022, 2022, 2208, 2208, 2209, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2210, 2022, 2022, 2022, 2211, 2022, 2212,
-  2213, 2022, 2022, 2022, 2213, 2214, 2022, 2215, 2022, 2022,
-  2022, 2022, 2022, 2216, 2217, 2217, 2217, 2022, 2022, 2218,
-  2219, 2220, 2220, 2220, 2022, 2022, 2022, 2022, 2220, 2221,
-  2022, 2022, 2222, 2022, 2022, 2223, 2022, 2022, 2223, 2223,
-  2223, 2224, 2225, 2226, 2226, 2226, 2022, 2022, 2226, 2227,
-  2228, 2228, 2022, 2229, 2230, 2230, 2231, 2232, 2233, 2022,
-
-  2022, 2022, 2233, 2233, 2234, 2022, 2022, 2022, 2235, 2236,
-  2237, 2237, 2022, 2022, 2238, 2238, 2238, 2239, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2240, 2241, 2022, 2242, 2243, 2243, 2244, 2245, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2246, 2022, 2022, 2247, 2022, 2022, 2022, 2022, 2248, 2249,
-  2249, 2249, 2022, 2022, 2022, 2022, 2022, 2022, 2249, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2223, 2022, 2022, 2224,
-
-  2225, 2226, 2226, 2226, 2022, 2022, 2022, 2226, 2022, 2022,
-  2022, 2022, 2228, 2022, 2229, 2022, 2022, 2230, 2231, 2232,
-  2233, 2233, 2233, 2234, 2022, 2022, 2022, 2022, 2235, 2236,
-  2237, 2237, 2022, 2022, 2022, 2238, 2238, 2239, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2240, 2241, 2022,
-  2022, 2022, 2243, 2243, 2244, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2246, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2248,
-  2249, 2249, 2249, 2022, 2022, 2249, 2022, 2022, 2022, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2224, 2225, 2226,
-  2022, 2022, 2226, 2226, 2022, 2022, 2226, 2022, 2022, 2022,
-  2228, 2022, 2229, 2022, 2022, 2022, 2230, 2022, 2022, 2232,
-  2233, 2233, 2233, 2234, 2022, 2235, 2236, 2237, 2237, 2022,
-  2022, 2022, 2022, 2238, 2238, 2239, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2240, 2241, 2022, 2243, 2243, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2246, 2022, 2022, 2022, 2248, 2249, 2249, 2249, 2022,
-  2022, 2022, 2022, 2249, 2022, 2022, 2022, 2224, 2022, 2022,
-
-  2226, 2022, 2022, 2022, 2226, 2226, 2022, 2022, 2022, 2022,
-  2226, 2022, 2022, 2022, 2022, 2228, 2022, 2229, 2022, 2022,
-  2022, 2022, 2230, 2232, 2022, 2022, 2233, 2233, 2234, 2022,
-  2235, 2236, 2237, 2237, 2022, 2238, 2238, 2239, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2241, 2022, 2022,
-  2243, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2246, 2022, 2022, 2249, 2249, 2249, 2022, 2022, 2022,
-  2022, 2249, 2022, 2022, 2022, 2022, 2226, 2226, 2226, 2022,
-  2022, 2022, 2022, 2226, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2229, 2022, 2022, 2022, 2022, 2022, 2022,
-
-  2230, 2232, 2022, 2022, 2022, 2022, 2022, 2233, 2022, 2022,
-  2022, 2235, 2236, 2237, 2237, 2022, 2022, 2238, 2022, 2022,
-  2022, 2022, 2022, 2022, 2241, 2022, 2022, 2022, 2243, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2246,
-  2249, 2249, 2249, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2226, 2226, 2226, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2229, 2022, 2022, 2022,
-  2022, 2022, 2022, 2230, 2230, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2236, 2237, 2237, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-
-  2022, 2022, 2243, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2246, 2249, 2249, 2249, 2022, 2022, 2022,
-  2226, 2226, 2226, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2229, 2022, 2022, 2022,
-  2022, 2022, 2022, 2230, 2230, 2022, 2022, 2022, 2236, 2237,
-  2237, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2243, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2246, 2022, 2022, 2249, 2249, 2249,
-  2226, 2022, 2022, 2226, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2229, 2022, 2022, 2022, 2022, 2022,
-
-  2022, 2230, 2230, 2236, 2237, 2237, 2237, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2246, 2022, 2022, 2022, 2249, 2249, 2249,
-  2249, 2226, 2022, 2022, 2022, 2226, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2230, 2022, 2022, 2230,
-  2236, 2237, 2237, 2237, 2250, 2251, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2246, 2249, 2249, 2249, 2249, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2230, 2022, 2022,
-  2022, 2230, 2236, 2237, 2252, 2253, 2250, 2251, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2249, 2249, 2249, 2249, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2230, 2230, 2236, 2252, 2237, 2254, 2253, 2255,
-  2237, 2022, 2022, 2022, 2022, 2022, 2022, 2249, 2249, 2249,
-  2249, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2230, 2230, 2236, 2254, 2022, 2255, 2237,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2249, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 2230, 2230, 2236, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2249, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2230, 2230,
-  2236, 2022, 2249, 2022, 2022, 2022, 2022, 2230, 2230, 2236,
-  2249, 2022, 2022, 2022, 2022, 2230, 2230, 2236, 2249, 2022,
-  2022, 2022, 2022, 2230, 2230, 2236, 2022, 2022, 2022, 2022,
-  2022, 2022, 2230, 2230, 2236, 2022, 2022, 2022, 2022, 2022,
-  2230, 2230, 2236, 2230, 2230, 2236, 2230, 2230, 2236, 2236,
-  2230, 2230, 2236, 2236, 2230, 2230, 2236, 2236, 2230, 2230,
-  2236, 2236, 2022, 2022, 2022, 2022, 2236, 2236, 2022, 2022,
-
-  2022, 2022, 2022, 2022, 2236, 2236, 2236, 2236, 2236, 2236,
-  2236, 2236, 2236, 2236, 2236, 2236, 2236, 2236, 2236, 2236,
-  2022, 0, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022
-};
-
-static yyconst flex_int16_t yy_nxt[7164] = { 0,
-  2022, 146, 147, 146, 146, 147, 146, 146, 147, 146,
-  146, 147, 146, 151, 147, 151, 157, 148, 154, 157,
-  148, 154, 450, 149, 2022, 155, 149, 2022, 155, 152,
-  151, 147, 151, 388, 158, 160, 161, 158, 160, 161,
-  162, 163, 2022, 162, 163, 388, 152, 167, 168, 389,
-  164, 160, 161, 164, 165, 391, 162, 160, 161, 561,
-  165, 390, 162, 167, 168, 562, 164, 147, 147, 147,
-  451, 390, 164, 147, 147, 147, 180, 147, 180, 180,
-  147, 180, 472, 170, 180, 147, 180, 510, 169, 170,
-  451, 473, 181, 561, 511, 181, 387, 387, 387, 575,
-
-  182, 387, 387, 387, 169, 171, 172, 147, 172, 171,
-  171, 171, 171, 171, 171, 171, 173, 171, 171, 171,
-  1485, 171, 175, 171, 176, 171, 180, 147, 180, 147,
-  147, 147, 503, 147, 147, 147, 180, 147, 180, 180,
-  147, 180, 182, 504, 561, 183, 391, 171, 171, 183,
-  600, 489, 181, 391, 490, 181, 387, 387, 387, 387,
-  387, 387, 390, 387, 387, 387, 387, 387, 387, 390,
-  177, 2022, 178, 171, 172, 147, 172, 171, 171, 171,
-  171, 171, 171, 171, 173, 171, 171, 171, 477, 171,
-  175, 171, 176, 171, 147, 147, 147, 147, 147, 147,
-
-  682, 180, 147, 180, 180, 147, 180, 180, 147, 180,
-  184, 563, 391, 184, 391, 171, 171, 182, 391, 425,
-  182, 426, 1110, 185, 564, 180, 147, 180, 390, 427,
-  390, 387, 387, 387, 390, 425, 451, 428, 177, 429,
-  178, 185, 186, 187, 147, 187, 186, 186, 186, 186,
-  186, 186, 186, 188, 186, 186, 186, 485, 186, 190,
-  186, 191, 186, 194, 147, 194, 194, 147, 194, 402,
-  218, 147, 218, 160, 161, 160, 161, 486, 162, 195,
-  162, 1270, 195, 446, 186, 186, 219, 447, 205, 1271,
-  205, 448, 192, 186, 187, 147, 187, 186, 186, 186,
-
-  186, 186, 186, 186, 188, 186, 186, 186, 892, 186,
-  190, 186, 191, 186, 206, 2022, 206, 218, 147, 218,
-  893, 147, 147, 147, 147, 147, 147, 387, 387, 387,
-  387, 387, 387, 219, 682, 186, 186, 220, 875, 544,
-  220, 513, 545, 192, 196, 197, 147, 197, 196, 196,
-  196, 196, 196, 196, 196, 198, 196, 196, 196, 512,
-  196, 200, 196, 201, 196, 218, 147, 218, 218, 147,
-  218, 505, 218, 147, 218, 218, 147, 218, 387, 387,
-  387, 219, 391, 439, 219, 512, 196, 196, 221, 433,
-  440, 221, 1412, 1413, 202, 1414, 1415, 203, 390, 390,
-
-  387, 387, 387, 204, 196, 197, 147, 197, 196, 196,
-  196, 196, 196, 196, 196, 198, 196, 196, 196, 451,
-  196, 200, 196, 201, 196, 232, 147, 232, 232, 147,
-  232, 906, 245, 147, 245, 245, 147, 245, 538, 391,
-  391, 233, 1275, 893, 233, 391, 196, 196, 246, 571,
-  1276, 246, 457, 539, 202, 390, 390, 203, 387, 387,
-  387, 390, 572, 204, 207, 208, 147, 208, 207, 207,
-  207, 207, 207, 207, 207, 209, 207, 207, 207, 906,
-  207, 211, 207, 212, 207, 147, 147, 147, 147, 147,
-  147, 930, 147, 147, 147, 147, 147, 147, 257, 147,
-
-  257, 254, 391, 391, 254, 1488, 207, 207, 255, 464,
-  520, 255, 563, 1495, 258, 213, 1498, 214, 390, 390,
-  215, 387, 387, 387, 2022, 576, 216, 207, 208, 147,
-  208, 207, 207, 207, 207, 207, 207, 207, 209, 207,
-  207, 207, 538, 207, 211, 207, 212, 207, 257, 147,
-  257, 271, 147, 271, 512, 271, 147, 271, 147, 147,
-  147, 147, 147, 147, 258, 411, 391, 272, 413, 207,
-  207, 272, 391, 1116, 220, 587, 1508, 220, 213, 1117,
-  214, 1521, 390, 215, 387, 387, 387, 998, 390, 216,
-  222, 223, 147, 223, 222, 222, 222, 222, 222, 222,
-
-  222, 224, 222, 222, 222, 1522, 222, 226, 222, 227,
-  222, 271, 147, 271, 271, 147, 271, 1232, 271, 147,
-  271, 271, 147, 271, 283, 147, 283, 272, 1523, 797,
-  272, 998, 222, 222, 273, 391, 391, 273, 798, 228,
-  284, 387, 387, 387, 229, 387, 387, 387, 387, 387,
-  387, 390, 390, 230, 222, 223, 147, 223, 222, 222,
-  222, 222, 222, 222, 222, 224, 222, 222, 222, 1231,
-  222, 226, 222, 227, 222, 283, 147, 283, 298, 147,
-  298, 1524, 298, 147, 298, 308, 147, 308, 308, 147,
-  308, 284, 1419, 1420, 299, 1390, 222, 222, 299, 391,
-
-  391, 309, 1391, 228, 309, 387, 387, 387, 229, 387,
-  387, 387, 387, 387, 387, 390, 390, 230, 234, 235,
-  147, 235, 234, 234, 234, 234, 234, 234, 234, 236,
-  234, 234, 234, 1525, 234, 238, 234, 239, 234, 321,
-  147, 321, 321, 147, 321, 682, 147, 147, 147, 147,
-  147, 147, 321, 147, 321, 322, 391, 571, 322, 1529,
-  234, 234, 220, 482, 995, 220, 998, 998, 322, 1392,
-  578, 240, 390, 387, 387, 387, 1393, 241, 1530, 242,
-  243, 234, 235, 147, 235, 234, 234, 234, 234, 234,
-  234, 234, 236, 234, 234, 234, 1514, 234, 238, 234,
-
-  239, 234, 321, 147, 321, 321, 147, 321, 1339, 321,
-  147, 321, 147, 147, 147, 147, 147, 147, 322, 1421,
-  1422, 323, 391, 234, 234, 323, 682, 682, 333, 493,
-  1531, 333, 1407, 1337, 240, 387, 387, 387, 390, 1408,
-  241, 684, 242, 243, 247, 248, 147, 248, 247, 247,
-  247, 247, 247, 247, 247, 249, 247, 247, 247, 998,
-  247, 251, 247, 252, 247, 147, 147, 147, 147, 147,
-  147, 1532, 335, 147, 335, 335, 147, 335, 335, 147,
-  335, 333, 1533, 1409, 333, 391, 247, 247, 336, 391,
-  1410, 336, 497, 1515, 337, 387, 387, 387, 387, 387,
-
-  387, 390, 387, 387, 387, 390, 253, 247, 248, 147,
-  248, 247, 247, 247, 247, 247, 247, 247, 249, 247,
-  247, 247, 1534, 247, 251, 247, 252, 247, 335, 147,
-  335, 349, 147, 349, 1535, 349, 147, 349, 147, 147,
-  147, 147, 147, 147, 337, 1536, 998, 350, 1537, 247,
-  247, 350, 391, 1486, 333, 1487, 1538, 333, 387, 387,
-  387, 387, 387, 387, 387, 387, 387, 1539, 390, 253,
-  259, 260, 147, 260, 259, 259, 259, 259, 259, 259,
-  259, 261, 259, 259, 259, 1433, 259, 263, 259, 264,
-  259, 349, 147, 349, 349, 147, 349, 1541, 349, 147,
-
-  349, 349, 147, 349, 360, 147, 360, 350, 391, 391,
-  350, 391, 259, 259, 351, 265, 524, 351, 1542, 1489,
-  361, 1490, 1543, 266, 390, 390, 267, 390, 998, 268,
-  1544, 1545, 269, 259, 260, 147, 260, 259, 259, 259,
-  259, 259, 259, 259, 261, 259, 259, 259, 1551, 259,
-  263, 259, 264, 259, 360, 147, 360, 373, 147, 373,
-  1552, 373, 147, 373, 147, 147, 147, 147, 147, 147,
-  361, 1434, 391, 374, 1553, 259, 259, 374, 265, 536,
-  375, 1150, 1496, 375, 1497, 1554, 266, 1151, 390, 267,
-  1152, 1499, 268, 1500, 1153, 269, 274, 275, 147, 275,
-
-  274, 274, 274, 274, 274, 274, 274, 276, 274, 274,
-  274, 531, 274, 278, 274, 279, 274, 373, 147, 373,
-  373, 147, 373, 1555, 373, 147, 373, 373, 147, 373,
-  385, 147, 385, 374, 1558, 1154, 374, 1559, 274, 274,
-  376, 1155, 1560, 376, 1156, 532, 386, 396, 1157, 280,
-  387, 387, 387, 387, 387, 387, 387, 387, 387, 451,
-  1561, 281, 274, 275, 147, 275, 274, 274, 274, 274,
-  274, 274, 274, 276, 274, 274, 274, 1562, 274, 278,
-  274, 279, 274, 385, 147, 385, 397, 387, 387, 387,
-  1563, 1568, 398, 387, 387, 387, 399, 1569, 1570, 386,
-
-  1571, 400, 1572, 1573, 274, 274, 387, 387, 387, 387,
-  387, 387, 387, 387, 387, 280, 387, 387, 387, 542,
-  542, 542, 1593, 686, 896, 896, 896, 281, 285, 286,
-  147, 286, 285, 285, 285, 285, 285, 285, 285, 287,
-  285, 285, 285, 288, 285, 289, 285, 290, 285, 288,
-  288, 288, 288, 288, 288, 288, 288, 288, 288, 288,
-  288, 288, 288, 288, 288, 288, 288, 288, 288, 288,
-  285, 285, 288, 288, 291, 288, 288, 288, 288, 288,
-  288, 292, 288, 293, 288, 288, 288, 294, 288, 295,
-  296, 288, 288, 288, 288, 288, 288, 300, 301, 147,
-
-  301, 300, 300, 300, 300, 300, 300, 300, 302, 300,
-  300, 300, 682, 300, 304, 300, 305, 300, 542, 542,
-  542, 584, 584, 584, 592, 592, 592, 606, 606, 606,
-  617, 617, 617, 904, 904, 904, 1594, 1595, 585, 300,
-  300, 593, 1596, 1603, 607, 1604, 1605, 618, 1585, 998,
-  306, 300, 301, 147, 301, 300, 300, 300, 300, 300,
-  300, 300, 302, 300, 300, 300, 998, 300, 304, 300,
-  305, 300, 1606, 543, 625, 625, 625, 1338, 631, 631,
-  631, 633, 633, 633, 642, 642, 642, 1009, 1009, 1009,
-  1599, 626, 1607, 300, 300, 632, 1608, 1609, 634, 1610,
-
-  1586, 643, 1600, 998, 306, 310, 311, 147, 311, 310,
-  310, 310, 310, 310, 310, 310, 312, 310, 310, 310,
-  1611, 310, 314, 310, 315, 310, 647, 647, 647, 667,
-  667, 667, 696, 696, 696, 696, 696, 696, 726, 726,
-  726, 682, 1587, 648, 1612, 1613, 668, 310, 310, 1615,
-  698, 316, 1616, 698, 1617, 1621, 728, 1230, 317, 1622,
-  318, 1015, 1015, 1015, 896, 896, 896, 319, 310, 311,
-  147, 311, 310, 310, 310, 310, 310, 310, 310, 312,
-  310, 310, 310, 1623, 310, 314, 310, 315, 310, 699,
-  726, 726, 726, 1627, 1601, 584, 584, 584, 731, 731,
-
-  731, 1628, 732, 1629, 1630, 733, 1602, 1631, 728, 1632,
-  310, 310, 585, 1638, 316, 741, 741, 741, 1639, 742,
-  1640, 317, 743, 318, 1021, 1021, 1021, 904, 904, 904,
-  319, 324, 325, 147, 325, 324, 324, 324, 324, 324,
-  324, 324, 326, 324, 324, 324, 729, 324, 328, 324,
-  329, 324, 736, 736, 736, 1641, 1642, 736, 736, 736,
-  592, 592, 592, 744, 744, 744, 747, 747, 747, 1643,
-  738, 998, 1656, 324, 324, 738, 330, 593, 998, 331,
-  745, 1633, 1635, 748, 762, 762, 762, 1658, 763, 1634,
-  1636, 764, 682, 332, 324, 325, 147, 325, 324, 324,
-
-  324, 324, 324, 324, 324, 326, 324, 324, 324, 1650,
-  324, 328, 324, 329, 324, 1662, 1651, 739, 1649, 1663,
-  750, 750, 750, 758, 758, 758, 1664, 1665, 750, 750,
-  750, 758, 758, 758, 1666, 1667, 324, 324, 752, 330,
-  1668, 760, 331, 778, 778, 778, 752, 779, 1669, 760,
-  780, 1047, 1047, 1047, 1670, 1671, 332, 338, 339, 147,
-  339, 338, 338, 338, 338, 338, 338, 338, 340, 338,
-  338, 338, 753, 338, 342, 338, 343, 338, 606, 606,
-  606, 1672, 1673, 768, 768, 768, 773, 773, 773, 1674,
-  1679, 761, 617, 617, 617, 607, 768, 768, 768, 338,
-
-  338, 770, 344, 1680, 775, 345, 1009, 1009, 1009, 618,
-  346, 789, 789, 789, 770, 790, 1681, 1684, 791, 347,
-  338, 339, 147, 339, 338, 338, 338, 338, 338, 338,
-  338, 340, 338, 338, 338, 1685, 338, 342, 338, 343,
-  338, 773, 773, 773, 771, 1686, 785, 785, 785, 785,
-  785, 785, 625, 625, 625, 1687, 793, 793, 793, 775,
-  1688, 1689, 338, 338, 787, 344, 1690, 787, 345, 626,
-  1011, 1011, 1011, 346, 795, 1015, 1015, 1015, 1021, 1021,
-  1021, 1691, 347, 352, 353, 147, 353, 352, 352, 352,
-  352, 352, 352, 352, 354, 352, 352, 352, 776, 352,
-
-  356, 352, 357, 352, 1692, 1693, 788, 1694, 1696, 793,
-  793, 793, 631, 631, 631, 799, 799, 799, 1697, 800,
-  1698, 1699, 801, 1700, 1701, 352, 352, 795, 1708, 632,
-  1022, 1022, 1022, 1047, 1047, 1047, 358, 352, 353, 147,
-  353, 352, 352, 352, 352, 352, 352, 352, 354, 352,
-  352, 352, 998, 352, 356, 352, 357, 352, 633, 633,
-  633, 802, 802, 802, 1709, 803, 1710, 1711, 804, 796,
-  805, 805, 805, 1712, 1713, 634, 1246, 1246, 1246, 352,
-  352, 815, 815, 815, 1705, 816, 1716, 806, 817, 1717,
-  358, 362, 363, 147, 363, 362, 362, 362, 362, 362,
-
-  362, 362, 364, 362, 362, 362, 1718, 362, 366, 362,
-  367, 362, 811, 811, 811, 642, 642, 642, 818, 818,
-  818, 811, 811, 811, 818, 818, 818, 647, 647, 647,
-  813, 1719, 643, 362, 362, 682, 820, 1720, 1721, 813,
-  1722, 368, 820, 369, 648, 370, 1127, 1127, 1127, 1248,
-  1248, 1248, 1723, 371, 362, 363, 147, 363, 362, 362,
-  362, 362, 362, 362, 362, 364, 362, 362, 362, 1728,
-  362, 366, 362, 367, 362, 814, 823, 823, 823, 1704,
-  824, 821, 1731, 825, 829, 829, 829, 829, 829, 829,
-  834, 834, 834, 836, 836, 836, 362, 362, 845, 845,
-
-  845, 1732, 831, 1736, 368, 831, 369, 835, 370, 1737,
-  837, 1130, 1130, 1130, 1738, 846, 371, 377, 378, 147,
-  378, 377, 377, 377, 377, 377, 377, 377, 379, 377,
-  377, 377, 1739, 377, 381, 377, 382, 377, 1740, 832,
-  840, 840, 840, 1741, 848, 848, 848, 840, 840, 840,
-  850, 850, 850, 850, 850, 850, 1729, 1730, 842, 377,
-  377, 849, 667, 667, 667, 842, 1742, 1743, 852, 1744,
-  1745, 852, 1746, 854, 854, 854, 1749, 855, 1750, 668,
-  856, 1751, 383, 377, 378, 147, 378, 377, 377, 377,
-  377, 377, 377, 377, 379, 377, 377, 377, 1752, 377,
-
-  381, 377, 382, 377, 843, 857, 857, 857, 1753, 1754,
-  853, 857, 857, 857, 865, 865, 865, 865, 865, 865,
-  871, 871, 871, 859, 1769, 377, 377, 682, 1770, 859,
-  1771, 1772, 867, 1776, 1777, 867, 1778, 1779, 873, 871,
-  871, 871, 696, 696, 696, 911, 911, 911, 383, 391,
-  696, 696, 696, 1011, 1011, 1011, 407, 873, 1761, 1780,
-  698, 1781, 912, 860, 1783, 390, 1784, 1012, 698, 696,
-  696, 696, 1785, 726, 726, 726, 1786, 868, 726, 726,
-  726, 1791, 1792, 726, 726, 726, 1793, 698, 1794, 1795,
-  408, 728, 409, 1796, 1797, 410, 728, 411, 412, 874,
-
-  413, 728, 1798, 1799, 414, 1800, 415, 416, 417, 391,
-  914, 914, 914, 884, 1801, 1802, 407, 731, 731, 731,
-  1803, 732, 1804, 682, 733, 390, 1819, 915, 1820, 913,
-  2022, 2022, 2022, 736, 736, 736, 736, 736, 736, 1821,
-  1822, 736, 736, 736, 744, 744, 744, 2022, 1823, 1824,
-  408, 738, 418, 1825, 738, 419, 1826, 420, 412, 738,
-  421, 745, 1813, 1827, 414, 1828, 422, 423, 424, 741,
-  741, 741, 1831, 742, 1832, 1833, 743, 920, 920, 920,
-  1834, 921, 1841, 1842, 922, 918, 1843, 916, 923, 923,
-  923, 747, 747, 747, 925, 925, 925, 1844, 926, 1845,
-
-  1846, 927, 750, 750, 750, 924, 1847, 1848, 748, 750,
-  750, 750, 750, 750, 750, 932, 932, 932, 1849, 1850,
-  752, 758, 758, 758, 758, 758, 758, 752, 1851, 1852,
-  752, 1862, 933, 758, 758, 758, 762, 762, 762, 760,
-  763, 1863, 760, 764, 768, 768, 768, 768, 768, 768,
-  1864, 760, 768, 768, 768, 773, 773, 773, 773, 773,
-  773, 1857, 770, 1857, 682, 770, 1865, 1866, 929, 1867,
-  770, 1868, 1869, 775, 1860, 1858, 775, 935, 773, 773,
-  773, 778, 778, 778, 1870, 779, 1871, 1876, 780, 785,
-  785, 785, 785, 785, 785, 1877, 775, 785, 785, 785,
-
-  1878, 789, 789, 789, 1879, 790, 1855, 787, 791, 1880,
-  787, 793, 793, 793, 939, 787, 793, 793, 793, 793,
-  793, 793, 1881, 799, 799, 799, 1882, 800, 1883, 795,
-  801, 805, 805, 805, 795, 1888, 1872, 795, 941, 802,
-  802, 802, 682, 803, 1874, 1888, 804, 1873, 806, 952,
-  952, 952, 1891, 953, 1892, 1875, 954, 1857, 947, 811,
-  811, 811, 811, 811, 811, 811, 811, 811, 815, 815,
-  815, 1858, 816, 998, 999, 817, 949, 813, 1902, 1886,
-  813, 1903, 1904, 813, 818, 818, 818, 818, 818, 818,
-  818, 818, 818, 823, 823, 823, 1857, 824, 1905, 1888,
-
-  825, 1909, 820, 1888, 1910, 820, 1911, 1860, 820, 829,
-  829, 829, 829, 829, 829, 829, 829, 829, 834, 834,
-  834, 1921, 967, 967, 967, 1925, 968, 831, 959, 969,
-  831, 1926, 1927, 831, 1928, 835, 1932, 836, 836, 836,
-  970, 970, 970, 1933, 971, 1934, 1935, 972, 840, 840,
-  840, 1936, 1937, 960, 837, 840, 840, 840, 840, 840,
-  840, 845, 845, 845, 1941, 682, 842, 1942, 977, 977,
-  977, 965, 978, 842, 1943, 979, 842, 1944, 846, 848,
-  848, 848, 981, 981, 981, 1945, 982, 1940, 682, 983,
-  850, 850, 850, 850, 850, 850, 849, 850, 850, 850,
-
-  854, 854, 854, 1949, 855, 1950, 1948, 856, 852, 1951,
-  1952, 852, 857, 857, 857, 852, 857, 857, 857, 1953,
-  682, 975, 857, 857, 857, 987, 987, 987, 1959, 1960,
-  859, 865, 865, 865, 859, 865, 865, 865, 1961, 1956,
-  859, 1962, 988, 865, 865, 865, 871, 871, 871, 867,
-  871, 871, 871, 867, 871, 871, 871, 997, 997, 997,
-  984, 867, 1969, 1970, 873, 696, 696, 696, 873, 911,
-  911, 911, 873, 1484, 682, 998, 999, 682, 985, 1022,
-  1022, 1022, 682, 698, 682, 682, 912, 1031, 1031, 1031,
-  1965, 1032, 682, 1012, 1033, 726, 726, 726, 1973, 682,
-
-  991, 914, 914, 914, 994, 1035, 1035, 1035, 682, 1036,
-  682, 1987, 1037, 728, 736, 736, 736, 1983, 915, 920,
-  920, 920, 682, 921, 1997, 1984, 922, 1005, 923, 923,
-  923, 1483, 738, 1042, 1042, 1042, 1991, 1043, 682, 1482,
-  1044, 750, 750, 750, 1988, 924, 925, 925, 925, 1034,
-  926, 1481, 2015, 927, 932, 932, 932, 682, 682, 752,
-  1040, 1049, 1049, 1049, 2005, 1050, 682, 682, 1051, 682,
-  1998, 933, 1052, 1052, 1052, 758, 758, 758, 1058, 1058,
-  1058, 773, 773, 773, 1065, 1065, 1065, 1480, 1046, 1053,
-  1067, 1067, 1067, 760, 1992, 2009, 1059, 682, 2010, 775,
-
-  2006, 1066, 785, 785, 785, 2019, 682, 1068, 1071, 1071,
-  1071, 2016, 793, 793, 793, 1074, 1074, 1074, 682, 682,
-  787, 1054, 2022, 2022, 2022, 1072, 1077, 1077, 1077, 1061,
-  795, 2007, 1075, 1069, 952, 952, 952, 682, 953, 2022,
-  2008, 954, 1479, 1078, 2022, 2022, 2022, 2013, 2022, 2022,
-  2022, 2022, 2022, 2022, 811, 811, 811, 818, 818, 818,
-  2011, 2022, 2012, 1478, 1070, 2022, 2014, 1472, 2022, 682,
-  1073, 682, 813, 1471, 682, 820, 1470, 1087, 1087, 1087,
-  829, 829, 829, 1469, 1076, 682, 967, 967, 967, 2019,
-  968, 1468, 1080, 969, 1088, 970, 970, 970, 831, 971,
-
-  682, 1467, 972, 2017, 1022, 1022, 1022, 840, 840, 840,
-  1079, 987, 987, 987, 2018, 1082, 1466, 1081, 1093, 1083,
-  1089, 1465, 977, 977, 977, 842, 978, 1461, 988, 979,
-  981, 981, 981, 1090, 982, 1460, 1459, 983, 850, 850,
-  850, 857, 857, 857, 1100, 1100, 1100, 1458, 1101, 1457,
-  1456, 1102, 865, 865, 865, 1455, 852, 1454, 1453, 859,
-  1107, 1107, 1107, 871, 871, 871, 997, 997, 997, 1094,
-  867, 696, 696, 696, 1127, 1127, 1127, 1108, 1130, 1130,
-  1130, 873, 1452, 1451, 998, 1127, 1127, 1127, 1128, 698,
-  1448, 1445, 1131, 1444, 1098, 1136, 1136, 1136, 1105, 1128,
-
-  1097, 1138, 1138, 1138, 1138, 1138, 1138, 1443, 1442, 1131,
-  1136, 1136, 1136, 1430, 1111, 1139, 1428, 1427, 1139, 1417,
-  1118, 1031, 1031, 1031, 1141, 1032, 1109, 1411, 1033, 1406,
-  1112, 726, 726, 726, 1129, 1035, 1035, 1035, 1405, 1036,
-  1401, 1394, 1037, 1389, 1388, 1135, 1052, 1052, 1052, 728,
-  736, 736, 736, 1042, 1042, 1042, 1387, 1043, 1381, 1380,
-  1044, 1129, 1379, 1053, 1135, 750, 750, 750, 738, 1049,
-  1049, 1049, 1378, 1050, 1377, 1376, 1051, 1158, 1158, 1158,
-  1375, 1159, 1374, 752, 1160, 758, 758, 758, 1162, 1162,
-  1162, 2022, 2022, 2022, 1142, 1165, 1165, 1165, 1145, 1058,
-
-  1058, 1058, 1373, 760, 1372, 1163, 1366, 1365, 2022, 1167,
-  1167, 1167, 1166, 773, 773, 773, 1364, 1059, 1065, 1065,
-  1065, 1363, 1148, 1173, 1173, 1173, 1168, 1174, 1361, 1359,
-  1175, 775, 1355, 1161, 1354, 1066, 1067, 1067, 1067, 1176,
-  1176, 1176, 1352, 1177, 1351, 1164, 1178, 1180, 1180, 1180,
-  1071, 1071, 1071, 1068, 1182, 1182, 1182, 1169, 1183, 1347,
-  1340, 1184, 1185, 1185, 1185, 1181, 1335, 1072, 1074, 1074,
-  1074, 1187, 1187, 1187, 1333, 1188, 1332, 1331, 1189, 1322,
-  1186, 1190, 1190, 1190, 1317, 1075, 1077, 1077, 1077, 1192,
-  1192, 1192, 1316, 1193, 1315, 1314, 1194, 1310, 1191, 1195,
-
-  1195, 1195, 1296, 1078, 2022, 2022, 2022, 1198, 1198, 1198,
-  811, 811, 811, 818, 818, 818, 1196, 1087, 1087, 1087,
-  1295, 2022, 1294, 1293, 1199, 1205, 1205, 1205, 813, 1206,
-  1292, 820, 1207, 1291, 1088, 1209, 1209, 1209, 1211, 1211,
-  1211, 1277, 2022, 2022, 2022, 840, 840, 840, 1216, 1216,
-  1216, 1274, 1273, 1210, 1272, 1212, 1269, 1268, 1197, 2022,
-  1264, 1201, 1263, 842, 1260, 1217, 2022, 2022, 2022, 850,
-  850, 850, 1200, 1259, 857, 857, 857, 1100, 1100, 1100,
-  1257, 1101, 1256, 2022, 1102, 1255, 1254, 852, 1220, 865,
-  865, 865, 859, 1215, 1107, 1107, 1107, 1226, 1226, 1226,
-
-  1251, 1227, 1213, 1250, 1228, 1249, 1247, 867, 1245, 1218,
-  1244, 1108, 871, 871, 871, 1243, 1242, 1219, 1234, 1234,
-  1234, 2022, 2022, 2022, 2022, 2022, 2022, 696, 696, 696,
-  873, 1252, 1252, 1252, 1241, 1235, 1240, 1224, 2022, 1239,
-  1233, 2022, 1253, 1253, 1253, 698, 1136, 1136, 1136, 1138,
-  1138, 1138, 726, 726, 726, 1225, 1261, 1261, 1261, 750,
-  750, 750, 1266, 1266, 1266, 1223, 1222, 1229, 1221, 1214,
-  728, 1208, 1204, 1236, 1262, 1203, 1202, 752, 1179, 1267,
-  1172, 1237, 1171, 1170, 1238, 1158, 1158, 1158, 1149, 1159,
-  1147, 1146, 1160, 758, 758, 758, 1162, 1162, 1162, 1258,
-
-  1144, 1279, 1279, 1279, 1143, 1280, 1140, 1278, 1281, 1137,
-  1134, 760, 1133, 1163, 1265, 1282, 1282, 1282, 1165, 1165,
-  1165, 1284, 1284, 1284, 1132, 1285, 1126, 1125, 1286, 1167,
-  1167, 1167, 1283, 1124, 1123, 1166, 1287, 1287, 1287, 1122,
-  1288, 1121, 1120, 1289, 1119, 1115, 1168, 773, 773, 773,
-  1173, 1173, 1173, 1114, 1174, 1113, 998, 1175, 1106, 1176,
-  1176, 1176, 1104, 1177, 1103, 775, 1178, 1180, 1180, 1180,
-  1182, 1182, 1182, 1099, 1183, 1096, 1095, 1184, 1185, 1185,
-  1185, 1092, 1187, 1187, 1187, 1181, 1188, 1091, 1086, 1189,
-  1190, 1190, 1190, 1290, 1085, 1084, 1186, 1297, 1297, 1297,
-
-  1064, 1298, 1063, 1062, 1299, 1060, 1057, 1191, 1192, 1192,
-  1192, 1056, 1193, 1055, 1048, 1194, 1195, 1195, 1195, 1300,
-  1300, 1300, 1045, 1301, 1041, 1039, 1302, 1303, 1303, 1303,
-  1198, 1198, 1198, 1196, 1305, 1305, 1305, 1038, 1306, 1030,
-  1029, 1307, 1028, 1027, 1304, 1026, 1025, 1199, 811, 811,
-  811, 818, 818, 818, 1311, 1311, 1311, 1205, 1205, 1205,
-  1024, 1206, 1023, 1020, 1207, 1019, 813, 1018, 1017, 820,
-  1016, 1312, 1209, 1209, 1209, 1211, 1211, 1211, 1318, 1318,
-  1318, 1014, 1319, 1013, 1010, 1320, 2022, 2022, 2022, 1008,
-  1210, 1007, 1212, 1216, 1216, 1216, 1308, 1313, 840, 840,
-
-  840, 1006, 1004, 2022, 2022, 2022, 2022, 1328, 1328, 1328,
-  1217, 1309, 1323, 1324, 1324, 1324, 842, 1325, 1003, 1002,
-  1326, 2022, 857, 857, 857, 1329, 865, 865, 865, 1226,
-  1226, 1226, 1001, 1227, 1000, 993, 1228, 992, 1321, 990,
-  859, 871, 871, 871, 867, 1234, 1234, 1234, 1341, 1341,
-  1341, 989, 1342, 986, 980, 1343, 2022, 2022, 2022, 873,
-  976, 1327, 1235, 2022, 2022, 2022, 974, 973, 1330, 966,
-  696, 696, 696, 2022, 1348, 1348, 1348, 1349, 1349, 1349,
-  2022, 1350, 1350, 1350, 1353, 1353, 1353, 1334, 698, 1336,
-  1246, 1246, 1246, 1248, 1248, 1248, 1356, 1356, 1356, 1357,
-
-  1357, 1357, 1252, 1252, 1252, 1253, 1253, 1253, 1358, 1358,
-  1358, 964, 1344, 1360, 1360, 1360, 726, 726, 726, 1261,
-  1261, 1261, 1367, 1367, 1367, 963, 1345, 1266, 1266, 1266,
-  1346, 1369, 1369, 1369, 728, 1370, 962, 1262, 1371, 961,
-  1368, 758, 758, 758, 1267, 1279, 1279, 1279, 958, 1280,
-  957, 956, 1281, 1282, 1282, 1282, 1383, 1383, 1383, 760,
-  1384, 955, 951, 1385, 1362, 1284, 1284, 1284, 950, 1285,
-  1283, 948, 1286, 1287, 1287, 1287, 946, 1288, 945, 944,
-  1289, 773, 773, 773, 1297, 1297, 1297, 1382, 1298, 943,
-  942, 1299, 940, 1300, 1300, 1300, 938, 1301, 937, 775,
-
-  1302, 1303, 1303, 1303, 1395, 1395, 1395, 936, 1396, 934,
-  931, 1397, 1305, 1305, 1305, 928, 1306, 919, 1304, 1307,
-  811, 811, 811, 1399, 1399, 1399, 1311, 1311, 1311, 1402,
-  1402, 1402, 1386, 1403, 917, 910, 1404, 909, 813, 908,
-  907, 1400, 905, 1312, 1318, 1318, 1318, 903, 1319, 902,
-  901, 1320, 2022, 2022, 2022, 840, 840, 840, 1324, 1324,
-  1324, 900, 1325, 899, 898, 1326, 2022, 2022, 2022, 2022,
-  1328, 1328, 1328, 842, 857, 857, 857, 1425, 1425, 1425,
-  1398, 897, 895, 2022, 865, 865, 865, 894, 1329, 1432,
-  1432, 1432, 859, 891, 1426, 871, 871, 871, 1416, 1435,
-
-  1435, 1435, 867, 890, 1341, 1341, 1341, 682, 1342, 889,
-  1418, 1343, 888, 873, 2022, 2022, 2022, 2022, 2022, 2022,
-  887, 886, 1423, 696, 696, 696, 1439, 1439, 1439, 885,
-  883, 2022, 882, 881, 2022, 880, 1424, 1348, 1348, 1348,
-  879, 698, 1349, 1349, 1349, 1429, 1350, 1350, 1350, 878,
-  877, 1431, 1440, 1440, 1440, 1441, 1441, 1441, 1353, 1353,
-  1353, 1356, 1356, 1356, 1357, 1357, 1357, 1436, 1358, 1358,
-  1358, 1360, 1360, 1360, 1446, 1446, 1446, 876, 1438, 1437,
-  1449, 1449, 1449, 1367, 1367, 1367, 1369, 1369, 1369, 682,
-  1370, 870, 1447, 1371, 758, 758, 758, 1450, 1383, 1383,
-
-  1383, 1368, 1384, 869, 864, 1385, 1463, 1463, 1463, 1395,
-  1395, 1395, 760, 1396, 863, 862, 1397, 1473, 1473, 1473,
-  1399, 1399, 1399, 861, 1464, 1475, 1475, 1475, 847, 1402,
-  1402, 1402, 844, 1403, 839, 1474, 1404, 838, 1400, 1491,
-  1491, 1491, 1476, 1493, 1493, 1493, 840, 840, 840, 833,
-  828, 1462, 2022, 2022, 2022, 827, 1492, 857, 857, 857,
-  1425, 1425, 1425, 826, 842, 1506, 1506, 1506, 1477, 2022,
-  822, 810, 1503, 1503, 1503, 859, 1504, 1426, 809, 1505,
-  808, 807, 1507, 1509, 1509, 1509, 1511, 1511, 1511, 871,
-  871, 871, 1432, 1432, 1432, 1501, 1435, 1435, 1435, 792,
-
-  784, 1510, 1516, 1516, 1516, 783, 782, 873, 781, 1494,
-  682, 777, 772, 1502, 2022, 2022, 2022, 767, 766, 1517,
-  1519, 1519, 1519, 1439, 1439, 1439, 1440, 1440, 1440, 765,
-  757, 2022, 1441, 1441, 1441, 1446, 1446, 1446, 1520, 1449,
-  1449, 1449, 1526, 1526, 1526, 756, 1527, 755, 754, 1528,
-  1513, 1512, 749, 1447, 746, 740, 1450, 758, 758, 758,
-  735, 734, 1518, 1463, 1463, 1463, 1546, 1546, 1546, 1473,
-  1473, 1473, 1475, 1475, 1475, 760, 730, 725, 1548, 1548,
-  1548, 1464, 1549, 1547, 724, 1550, 723, 1474, 722, 1476,
-  1556, 1556, 1556, 1491, 1491, 1491, 1564, 1564, 1564, 721,
-
-  1565, 720, 719, 1566, 1493, 1493, 1493, 1557, 718, 717,
-  1492, 716, 715, 1540, 840, 840, 840, 2022, 2022, 2022,
-  1576, 1576, 1576, 1503, 1503, 1503, 714, 1504, 713, 712,
-  1505, 711, 842, 710, 2022, 1506, 1506, 1506, 1577, 1578,
-  1578, 1578, 709, 1579, 708, 707, 1580, 706, 1581, 1581,
-  1581, 705, 1507, 1509, 1509, 1509, 1511, 1511, 1511, 1583,
-  1583, 1583, 704, 703, 1574, 1582, 702, 701, 1567, 700,
-  695, 1510, 1516, 1516, 1516, 694, 693, 1584, 1575, 1588,
-  1588, 1588, 692, 1589, 691, 690, 1590, 689, 688, 1517,
-  1591, 1591, 1591, 1519, 1519, 1519, 1597, 1597, 1597, 1526,
-
-  1526, 1526, 685, 1527, 683, 682, 1528, 1592, 758, 758,
-  758, 1520, 680, 1598, 1546, 1546, 1546, 1618, 1618, 1618,
-  678, 1619, 677, 676, 1620, 674, 760, 673, 1548, 1548,
-  1548, 1547, 1549, 672, 671, 1550, 1556, 1556, 1556, 1624,
-  1624, 1624, 670, 1625, 666, 664, 1626, 1564, 1564, 1564,
-  663, 1565, 662, 1557, 1566, 840, 840, 840, 2022, 2022,
-  2022, 2022, 2022, 2022, 1614, 1576, 1576, 1576, 661, 660,
-  1578, 1578, 1578, 842, 1579, 2022, 658, 1580, 2022, 1581,
-  1581, 1581, 657, 1577, 1646, 1646, 1646, 656, 1647, 655,
-  654, 1648, 1583, 1583, 1583, 653, 1582, 1588, 1588, 1588,
-
-  651, 1589, 650, 649, 1590, 1591, 1591, 1591, 646, 645,
-  1584, 1652, 1652, 1652, 641, 1653, 639, 1637, 1654, 1644,
-  638, 1645, 1592, 1655, 1655, 1655, 1657, 1657, 1657, 1597,
-  1597, 1597, 1659, 1659, 1659, 637, 1660, 636, 635, 1661,
-  758, 758, 758, 1676, 1676, 1676, 1598, 1618, 1618, 1618,
-  630, 1619, 629, 627, 1620, 1682, 1682, 1682, 760, 624,
-  1677, 1624, 1624, 1624, 622, 1625, 621, 620, 1626, 840,
-  840, 840, 1683, 2022, 2022, 2022, 2022, 2022, 2022, 1655,
-  1655, 1655, 1706, 1706, 1706, 619, 1678, 842, 1675, 616,
-  2022, 615, 613, 2022, 1646, 1646, 1646, 612, 1647, 1707,
-
-  998, 1648, 1652, 1652, 1652, 610, 1653, 609, 608, 1654,
-  1657, 1657, 1657, 1659, 1659, 1659, 605, 1660, 603, 602,
-  1661, 1695, 1703, 1714, 1714, 1714, 758, 758, 758, 1676,
-  1676, 1676, 1725, 1725, 1725, 1702, 1726, 601, 599, 1727,
-  1715, 1682, 1682, 1682, 760, 597, 1677, 1733, 1733, 1733,
-  596, 1734, 595, 594, 1735, 1747, 1747, 1747, 1683, 1755,
-  1755, 1755, 1758, 1758, 1758, 1762, 1762, 1762, 1706, 1706,
-  1706, 591, 1724, 1748, 590, 589, 1756, 586, 583, 1759,
-  582, 580, 1763, 998, 579, 1707, 998, 577, 1764, 1764,
-  1764, 574, 1765, 573, 570, 1766, 1767, 1767, 1767, 1768,
-
-  1768, 1768, 1757, 569, 568, 1760, 998, 1714, 1714, 1714,
-  1773, 1773, 1773, 567, 1774, 566, 565, 1775, 758, 758,
-  758, 1725, 1725, 1725, 1715, 1726, 560, 559, 1727, 1787,
-  1787, 1787, 558, 1733, 1733, 1733, 760, 1734, 557, 556,
-  1735, 1789, 1789, 1789, 555, 554, 1788, 1747, 1747, 1747,
-  1755, 1755, 1755, 1805, 1805, 1805, 552, 1806, 1790, 551,
-  1807, 2022, 2022, 2022, 550, 1748, 549, 1756, 1758, 1758,
-  1758, 548, 1809, 1809, 1809, 547, 1810, 546, 2022, 1811,
-  1782, 2022, 2022, 2022, 541, 1759, 1762, 1762, 1762, 1814,
-  1814, 1814, 538, 1815, 540, 535, 1816, 533, 2022, 1767,
-
-  1767, 1767, 531, 1763, 998, 2022, 530, 998, 529, 1764,
-  1764, 1764, 528, 1765, 527, 525, 1766, 1768, 1768, 1768,
-  523, 1773, 1773, 1773, 521, 1774, 1808, 998, 1775, 1835,
-  1835, 1835, 520, 1836, 519, 518, 1837, 517, 1829, 1829,
-  1829, 516, 1787, 1787, 1787, 514, 1812, 996, 996, 996,
-  996, 996, 996, 996, 996, 996, 1830, 513, 996, 1788,
-  1789, 1789, 1789, 996, 996, 996, 998, 996, 1838, 1838,
-  1838, 509, 1839, 508, 506, 1840, 505, 1790, 1805, 1805,
-  1805, 502, 1806, 501, 500, 1807, 2022, 2022, 2022, 996,
-  996, 996, 996, 996, 996, 996, 996, 996, 996, 996,
-
-  498, 496, 996, 2022, 2022, 2022, 2022, 996, 996, 996,
-  998, 996, 1809, 1809, 1809, 494, 1810, 492, 491, 1811,
-  488, 2022, 1814, 1814, 1814, 487, 1815, 483, 481, 1816,
-  1829, 1829, 1829, 996, 996, 1835, 1835, 1835, 1853, 1836,
-  998, 480, 1837, 1838, 1838, 1838, 478, 1839, 1830, 477,
-  1840, 476, 2022, 2022, 2022, 475, 1854, 996, 996, 996,
-  996, 996, 1861, 996, 996, 996, 474, 471, 996, 2022,
-  2022, 2022, 2022, 996, 996, 996, 998, 996, 1890, 1890,
-  1890, 1893, 1893, 1893, 1912, 1912, 1912, 2022, 1913, 469,
-  468, 1914, 420, 1895, 1895, 1895, 998, 999, 1894, 996,
-
-  996, 996, 996, 996, 996, 996, 996, 996, 996, 1861,
-  1896, 467, 996, 465, 1884, 463, 462, 996, 996, 996,
-  998, 996, 1897, 1897, 1897, 1900, 1900, 1900, 2022, 2022,
-  2022, 461, 1885, 2022, 2022, 2022, 1908, 1908, 1908, 1898,
-  460, 458, 1901, 996, 996, 2022, 1890, 1890, 1890, 456,
-  2022, 1893, 1893, 1893, 682, 1895, 1895, 1895, 455, 1915,
-  1915, 1915, 454, 1916, 998, 1899, 1917, 452, 1894, 1897,
-  1897, 1897, 1896, 1918, 1918, 1918, 450, 1919, 449, 1906,
-  1920, 1900, 1900, 1900, 1907, 445, 1898, 444, 1922, 1922,
-  1922, 442, 1923, 441, 1111, 1924, 438, 437, 1901, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 1908, 1908, 1908, 1912, 1912,
-  1912, 436, 1913, 434, 432, 1914, 2022, 430, 2022, 2022,
-  1915, 1915, 1915, 682, 1916, 406, 405, 1917, 1918, 1918,
-  1918, 403, 1919, 401, 395, 1920, 1922, 1922, 1922, 394,
-  1923, 1931, 1929, 1924, 395, 1930, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 394, 393, 2022, 392, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 1957,
-  1957, 1957, 2022, 2022, 2022, 2022, 2022, 2022, 1957, 1957,
-  1957, 2022, 2022, 2022, 2022, 2022, 1958, 2022, 2022, 2022,
-
-  2022, 2022, 2022, 1938, 2022, 1958, 1939, 2022, 2022, 1954,
-  2022, 1966, 1966, 1966, 1946, 1967, 2022, 1947, 1968, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 1955, 2022, 2022,
-  1963, 2022, 2022, 1964, 2022, 2022, 2022, 2022, 2022, 2022,
-  1966, 1966, 1966, 2022, 1967, 2022, 2022, 1968, 2022, 2022,
-  2022, 2022, 2022, 2022, 1976, 1976, 1976, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 1976,
-  1976, 1976, 682, 1979, 2022, 2022, 1980, 2022, 2022, 1971,
-  2022, 2022, 1972, 2022, 2022, 2022, 2022, 682, 2022, 2022,
-  2022, 1974, 2022, 2022, 1975, 2022, 2022, 2022, 2022, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 1993, 1993, 1993, 2022, 2022, 1977, 2022,
-  1978, 2022, 2022, 2022, 2022, 2022, 2022, 1995, 1995, 1995,
-  1994, 1981, 1993, 1993, 1993, 2022, 1982, 2022, 1999, 1999,
-  1999, 2022, 2000, 2022, 1996, 2001, 2022, 2022, 1986, 1994,
-  2022, 1985, 2022, 1989, 1995, 1995, 1995, 2002, 2002, 2002,
-  2022, 2003, 2022, 2022, 2004, 1999, 1999, 1999, 2022, 2000,
-  2022, 1996, 2001, 1990, 2002, 2002, 2002, 2022, 2003, 2022,
-  2022, 2004, 2020, 2020, 2020, 2020, 2020, 2020, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-
-  2021, 2022, 2022, 2021, 144, 144, 144, 144, 144, 144,
-  144, 144, 144, 145, 145, 145, 145, 145, 145, 145,
-  145, 145, 150, 150, 150, 150, 150, 150, 150, 150,
-  150, 153, 153, 153, 153, 153, 153, 153, 153, 153,
-  156, 156, 156, 156, 156, 156, 156, 156, 156, 159,
-  159, 159, 159, 159, 159, 159, 159, 159, 166, 166,
-  166, 166, 166, 166, 166, 166, 166, 174, 174, 174,
-  174, 174, 174, 174, 174, 174, 179, 179, 179, 179,
-  179, 179, 179, 179, 179, 189, 189, 189, 189, 189,
-  189, 189, 189, 189, 193, 193, 193, 193, 193, 193,
-
-  193, 193, 193, 199, 199, 199, 199, 199, 199, 199,
-  199, 199, 210, 210, 210, 210, 210, 210, 210, 210,
-  210, 217, 217, 217, 217, 217, 217, 217, 217, 217,
-  225, 225, 225, 225, 225, 225, 225, 225, 225, 231,
-  231, 231, 231, 231, 231, 231, 231, 231, 237, 237,
-  237, 237, 237, 237, 237, 237, 237, 244, 244, 244,
-  244, 244, 244, 244, 244, 244, 250, 250, 250, 250,
-  250, 250, 250, 250, 250, 256, 256, 256, 256, 256,
-  256, 256, 256, 256, 262, 262, 262, 262, 262, 262,
-  262, 262, 262, 270, 270, 270, 270, 270, 270, 270,
-
-  270, 270, 277, 277, 277, 277, 277, 277, 277, 277,
-  277, 282, 282, 282, 282, 282, 282, 282, 282, 282,
-  297, 297, 297, 297, 297, 297, 297, 297, 297, 303,
-  303, 303, 303, 303, 303, 303, 303, 303, 307, 307,
-  307, 307, 307, 307, 307, 307, 307, 313, 313, 313,
-  313, 313, 313, 313, 313, 313, 320, 320, 320, 320,
-  320, 320, 320, 320, 320, 327, 327, 327, 327, 327,
-  327, 327, 327, 327, 334, 334, 334, 334, 334, 334,
-  334, 334, 334, 341, 341, 341, 341, 341, 341, 341,
-  341, 341, 348, 348, 348, 348, 348, 348, 348, 348,
-
-  348, 355, 355, 355, 355, 355, 355, 355, 355, 355,
-  359, 359, 359, 359, 359, 359, 359, 359, 359, 365,
-  365, 365, 365, 365, 365, 365, 365, 365, 372, 372,
-  372, 372, 372, 372, 372, 372, 372, 380, 380, 380,
-  380, 380, 380, 380, 380, 380, 384, 384, 384, 384,
-  384, 384, 384, 384, 384, 404, 404, 404, 2022, 2022,
-  2022, 404, 431, 431, 431, 2022, 2022, 2022, 431, 435,
-  435, 435, 2022, 2022, 2022, 435, 443, 443, 443, 2022,
-  2022, 2022, 443, 453, 453, 453, 2022, 2022, 2022, 453,
-  459, 459, 459, 2022, 2022, 2022, 459, 466, 466, 466,
-
-  2022, 2022, 2022, 466, 470, 470, 470, 2022, 2022, 2022,
-  470, 479, 479, 479, 2022, 2022, 2022, 479, 484, 484,
-  484, 2022, 2022, 2022, 484, 495, 495, 495, 2022, 2022,
-  2022, 495, 499, 499, 499, 2022, 2022, 2022, 499, 507,
-  507, 507, 2022, 2022, 2022, 507, 515, 515, 515, 2022,
-  2022, 2022, 515, 522, 522, 522, 2022, 2022, 2022, 522,
-  526, 526, 526, 2022, 2022, 2022, 526, 534, 534, 534,
-  2022, 2022, 2022, 534, 537, 537, 537, 537, 537, 537,
-  537, 2022, 537, 553, 2022, 2022, 2022, 553, 581, 2022,
-  2022, 2022, 581, 588, 2022, 2022, 2022, 588, 598, 2022,
-
-  2022, 2022, 598, 604, 2022, 2022, 2022, 604, 611, 2022,
-  2022, 2022, 611, 614, 2022, 2022, 2022, 614, 623, 2022,
-  2022, 2022, 623, 628, 2022, 2022, 2022, 628, 484, 484,
-  484, 2022, 2022, 2022, 484, 640, 2022, 2022, 2022, 640,
-  495, 495, 495, 2022, 2022, 2022, 495, 644, 2022, 2022,
-  2022, 644, 499, 499, 499, 2022, 2022, 2022, 499, 652,
-  2022, 2022, 2022, 652, 507, 507, 507, 2022, 2022, 2022,
-  507, 659, 2022, 2022, 2022, 659, 515, 515, 515, 2022,
-  2022, 2022, 515, 665, 2022, 2022, 2022, 665, 522, 522,
-  522, 2022, 2022, 2022, 522, 669, 2022, 2022, 2022, 669,
-
-  526, 526, 526, 2022, 2022, 2022, 526, 675, 2022, 2022,
-  2022, 675, 534, 534, 534, 2022, 2022, 2022, 534, 679,
-  2022, 2022, 2022, 679, 681, 681, 681, 681, 681, 681,
-  681, 681, 681, 687, 2022, 2022, 2022, 2022, 687, 404,
-  404, 404, 2022, 2022, 2022, 404, 697, 697, 697, 697,
-  2022, 2022, 697, 697, 431, 431, 431, 2022, 2022, 2022,
-  431, 727, 727, 727, 727, 2022, 2022, 727, 727, 435,
-  435, 435, 2022, 2022, 2022, 435, 737, 737, 737, 737,
-  2022, 2022, 737, 737, 443, 443, 443, 2022, 2022, 2022,
-  443, 751, 751, 751, 751, 2022, 2022, 751, 751, 453,
-
-  453, 453, 2022, 2022, 2022, 453, 759, 759, 759, 759,
-  2022, 2022, 759, 759, 459, 459, 459, 2022, 2022, 2022,
-  459, 769, 769, 769, 769, 2022, 2022, 769, 769, 466,
-  466, 466, 2022, 2022, 2022, 466, 774, 774, 774, 774,
-  2022, 2022, 774, 774, 470, 470, 470, 2022, 2022, 2022,
-  470, 786, 786, 786, 786, 2022, 2022, 786, 786, 479,
-  479, 479, 2022, 2022, 2022, 479, 794, 794, 794, 794,
-  2022, 2022, 794, 794, 484, 484, 484, 2022, 2022, 2022,
-  484, 812, 812, 812, 812, 2022, 2022, 812, 812, 819,
-  819, 819, 819, 2022, 2022, 819, 819, 499, 499, 499,
-
-  2022, 2022, 2022, 499, 830, 830, 830, 830, 2022, 2022,
-  830, 830, 507, 507, 507, 2022, 2022, 2022, 507, 841,
-  841, 841, 841, 2022, 2022, 841, 841, 515, 515, 515,
-  2022, 2022, 2022, 515, 851, 851, 851, 851, 2022, 2022,
-  851, 851, 858, 858, 858, 858, 2022, 2022, 858, 858,
-  526, 526, 526, 2022, 2022, 2022, 526, 866, 866, 866,
-  866, 2022, 2022, 866, 866, 534, 534, 534, 2022, 2022,
-  2022, 534, 872, 872, 872, 872, 2022, 2022, 872, 872,
-  681, 681, 681, 681, 681, 681, 681, 681, 681, 687,
-  2022, 687, 2022, 2022, 687, 404, 404, 404, 2022, 2022,
-
-  2022, 404, 697, 697, 697, 697, 2022, 2022, 697, 697,
-  431, 431, 431, 431, 2022, 431, 2022, 431, 727, 727,
-  727, 727, 2022, 2022, 727, 727, 435, 435, 435, 435,
-  2022, 435, 2022, 435, 737, 737, 737, 737, 2022, 2022,
-  737, 737, 443, 443, 443, 2022, 2022, 2022, 443, 751,
-  751, 751, 751, 2022, 2022, 751, 751, 453, 453, 453,
-  2022, 2022, 2022, 453, 759, 759, 759, 759, 2022, 2022,
-  759, 759, 459, 459, 459, 2022, 2022, 2022, 459, 769,
-  769, 769, 769, 2022, 2022, 769, 769, 466, 466, 466,
-  2022, 2022, 2022, 466, 774, 774, 774, 774, 2022, 2022,
-
-  774, 774, 470, 470, 470, 2022, 2022, 2022, 470, 786,
-  786, 786, 786, 2022, 2022, 786, 786, 479, 479, 479,
-  2022, 2022, 2022, 479, 794, 794, 794, 794, 2022, 2022,
-  794, 794, 484, 484, 484, 2022, 2022, 2022, 484, 812,
-  812, 812, 812, 2022, 2022, 812, 812, 819, 819, 819,
-  819, 2022, 2022, 819, 819, 499, 499, 499, 2022, 2022,
-  2022, 499, 830, 830, 830, 830, 2022, 2022, 830, 830,
-  507, 507, 507, 2022, 2022, 2022, 507, 841, 841, 841,
-  841, 2022, 2022, 841, 841, 515, 515, 515, 2022, 2022,
-  2022, 515, 851, 851, 851, 851, 2022, 2022, 851, 851,
-
-  858, 858, 858, 858, 2022, 2022, 858, 858, 526, 526,
-  526, 2022, 2022, 2022, 526, 866, 866, 866, 866, 2022,
-  2022, 866, 866, 534, 534, 534, 2022, 2022, 2022, 534,
-  872, 872, 872, 872, 2022, 2022, 872, 872, 681, 681,
-  681, 681, 681, 681, 681, 681, 681, 996, 996, 996,
-  996, 996, 996, 996, 996, 996, 404, 404, 404, 2022,
-  2022, 2022, 404, 697, 697, 697, 697, 2022, 2022, 697,
-  697, 727, 727, 727, 727, 2022, 2022, 727, 727, 435,
-  435, 435, 2022, 2022, 2022, 435, 737, 737, 737, 737,
-  2022, 2022, 737, 737, 443, 443, 443, 2022, 2022, 2022,
-
-  443, 751, 751, 751, 751, 2022, 2022, 751, 751, 453,
-  453, 453, 2022, 2022, 2022, 453, 759, 759, 759, 759,
-  2022, 2022, 759, 759, 459, 459, 459, 2022, 2022, 2022,
-  459, 769, 769, 769, 769, 2022, 2022, 769, 769, 466,
-  466, 466, 2022, 2022, 2022, 466, 774, 774, 774, 774,
-  2022, 2022, 774, 774, 470, 470, 470, 2022, 2022, 2022,
-  470, 786, 786, 786, 786, 2022, 2022, 786, 786, 479,
-  479, 479, 479, 2022, 479, 2022, 479, 794, 794, 794,
-  794, 2022, 2022, 794, 794, 484, 484, 484, 484, 2022,
-  484, 2022, 484, 812, 812, 812, 812, 2022, 2022, 812,
-
-  812, 819, 819, 819, 819, 2022, 2022, 819, 819, 499,
-  499, 499, 2022, 2022, 2022, 499, 830, 830, 830, 830,
-  2022, 2022, 830, 830, 507, 507, 507, 2022, 2022, 2022,
-  507, 841, 841, 841, 841, 2022, 2022, 841, 841, 515,
-  515, 515, 2022, 2022, 2022, 515, 851, 851, 851, 851,
-  2022, 2022, 851, 851, 858, 858, 858, 858, 2022, 2022,
-  858, 858, 526, 526, 526, 2022, 2022, 2022, 526, 866,
-  866, 866, 866, 2022, 2022, 866, 866, 534, 534, 534,
-  534, 2022, 534, 2022, 534, 872, 872, 872, 872, 2022,
-  2022, 872, 872, 681, 681, 681, 681, 681, 681, 681,
-
-  681, 681, 996, 996, 996, 996, 996, 996, 996, 996,
-  996, 404, 404, 404, 2022, 2022, 2022, 404, 697, 697,
-  697, 697, 2022, 2022, 697, 697, 727, 727, 727, 727,
-  2022, 2022, 727, 727, 435, 435, 435, 2022, 2022, 2022,
-  435, 737, 737, 737, 737, 2022, 2022, 737, 737, 443,
-  443, 443, 2022, 2022, 2022, 443, 751, 751, 751, 751,
-  2022, 2022, 751, 751, 453, 453, 453, 2022, 2022, 2022,
-  453, 759, 759, 759, 759, 2022, 2022, 759, 759, 459,
-  459, 459, 459, 2022, 459, 2022, 459, 466, 466, 466,
-  466, 2022, 466, 2022, 466, 774, 774, 774, 774, 2022,
-
-  2022, 774, 774, 470, 470, 470, 2022, 2022, 2022, 470,
-  786, 786, 786, 786, 2022, 2022, 786, 786, 794, 794,
-  794, 794, 2022, 2022, 794, 794, 484, 484, 484, 484,
-  2022, 484, 2022, 484, 812, 812, 812, 812, 2022, 2022,
-  812, 812, 819, 819, 819, 819, 2022, 2022, 819, 819,
-  499, 499, 499, 2022, 2022, 2022, 499, 830, 830, 830,
-  830, 2022, 2022, 830, 830, 507, 507, 507, 507, 2022,
-  507, 2022, 507, 841, 841, 841, 841, 2022, 2022, 841,
-  841, 515, 515, 515, 515, 2022, 515, 2022, 515, 851,
-  851, 851, 851, 2022, 2022, 851, 851, 858, 858, 858,
-
-  858, 2022, 2022, 858, 858, 526, 526, 526, 2022, 2022,
-  2022, 526, 866, 866, 866, 866, 2022, 2022, 866, 866,
-  872, 872, 872, 872, 2022, 2022, 872, 872, 681, 681,
-  681, 681, 681, 681, 681, 681, 681, 996, 996, 996,
-  996, 996, 996, 996, 996, 996, 404, 404, 404, 404,
-  2022, 404, 2022, 404, 697, 697, 697, 697, 2022, 2022,
-  697, 697, 727, 727, 727, 727, 2022, 2022, 727, 727,
-  435, 435, 435, 2022, 2022, 2022, 435, 737, 737, 737,
-  737, 2022, 2022, 737, 737, 443, 443, 443, 2022, 2022,
-  2022, 443, 751, 751, 751, 751, 2022, 2022, 751, 751,
-
-  453, 453, 453, 453, 2022, 453, 2022, 453, 759, 759,
-  759, 759, 2022, 2022, 759, 759, 459, 459, 459, 459,
-  2022, 459, 2022, 459, 774, 774, 774, 774, 2022, 2022,
-  774, 774, 470, 470, 470, 2022, 2022, 2022, 470, 1817,
-  1817, 1817, 1817, 1817, 1817, 1817, 1817, 1817, 1818, 1818,
-  1818, 1818, 1818, 1818, 1818, 1818, 1818, 1856, 1856, 1856,
-  1856, 1856, 1856, 1856, 1856, 1856, 1859, 1859, 1859, 1859,
-  1859, 1859, 1859, 1859, 1859, 1887, 1887, 1887, 1887, 1887,
-  1887, 1887, 1887, 1887, 1889, 1889, 1889, 1889, 1889, 1889,
-  1889, 1889, 1889, 143, 2022, 2022, 2022, 2022, 2022, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022
-};
-
-static yyconst flex_int16_t yy_chk[7164] = { 0,
-  0, 3, 3, 3, 4, 4, 4, 5, 5, 5,
-  6, 6, 6, 7, 7, 7, 11, 3, 9, 12,
-  4, 10, 219, 5, 0, 9, 6, 0, 10, 7,
-  8, 8, 8, 148, 11, 13, 13, 12, 14, 14,
-  13, 13, 220, 14, 14, 149, 8, 17, 17, 148,
-  13, 15, 15, 14, 15, 152, 15, 16, 16, 414,
-  16, 149, 16, 18, 18, 414, 15, 19, 19, 19,
-  219, 152, 16, 20, 20, 20, 23, 23, 23, 24,
-  24, 24, 266, 19, 25, 25, 25, 332, 17, 20,
-  220, 266, 23, 425, 332, 24, 146, 146, 146, 425,
-
-  25, 147, 147, 147, 18, 21, 21, 21, 21, 21,
-  21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
-  1412, 21, 21, 21, 21, 21, 26, 26, 26, 27,
-  27, 27, 319, 28, 28, 28, 29, 29, 29, 30,
-  30, 30, 26, 319, 451, 27, 175, 21, 21, 28,
-  451, 294, 29, 190, 294, 30, 151, 151, 151, 172,
-  172, 172, 175, 180, 180, 180, 187, 187, 187, 190,
-  21, 183, 21, 22, 22, 22, 22, 22, 22, 22,
-  22, 22, 22, 22, 22, 22, 22, 22, 272, 22,
-  22, 22, 22, 22, 31, 31, 31, 32, 32, 32,
-
-  995, 33, 33, 33, 34, 34, 34, 35, 35, 35,
-  31, 415, 200, 32, 170, 22, 22, 33, 211, 183,
-  34, 183, 995, 35, 415, 36, 36, 36, 200, 185,
-  170, 194, 194, 194, 211, 185, 272, 185, 22, 185,
-  22, 36, 37, 37, 37, 37, 37, 37, 37, 37,
-  37, 37, 37, 37, 37, 37, 37, 291, 37, 37,
-  37, 37, 37, 39, 39, 39, 40, 40, 40, 170,
-  47, 47, 47, 43, 43, 44, 44, 291, 43, 39,
-  44, 1152, 40, 215, 37, 37, 47, 215, 43, 1152,
-  44, 215, 37, 38, 38, 38, 38, 38, 38, 38,
-
-  38, 38, 38, 38, 38, 38, 38, 38, 707, 38,
-  38, 38, 38, 38, 43, 333, 44, 48, 48, 48,
-  707, 49, 49, 49, 50, 50, 50, 197, 197, 197,
-  208, 208, 208, 48, 684, 38, 38, 49, 684, 397,
-  50, 336, 397, 38, 41, 41, 41, 41, 41, 41,
-  41, 41, 41, 41, 41, 41, 41, 41, 41, 333,
-  41, 41, 41, 41, 41, 51, 51, 51, 52, 52,
-  52, 322, 53, 53, 53, 54, 54, 54, 218, 218,
-  218, 51, 195, 205, 52, 336, 41, 41, 53, 195,
-  205, 54, 1319, 1319, 41, 1320, 1320, 41, 195, 205,
-
-  223, 223, 223, 41, 42, 42, 42, 42, 42, 42,
-  42, 42, 42, 42, 42, 42, 42, 42, 42, 322,
-  42, 42, 42, 42, 42, 57, 57, 57, 58, 58,
-  58, 720, 61, 61, 61, 62, 62, 62, 388, 226,
-  238, 57, 1156, 720, 58, 233, 42, 42, 61, 422,
-  1156, 62, 233, 388, 42, 226, 238, 42, 232, 232,
-  232, 233, 422, 42, 45, 45, 45, 45, 45, 45,
-  45, 45, 45, 45, 45, 45, 45, 45, 45, 754,
-  45, 45, 45, 45, 45, 65, 65, 65, 66, 66,
-  66, 754, 67, 67, 67, 68, 68, 68, 69, 69,
-
-  69, 65, 246, 251, 66, 1414, 45, 45, 67, 246,
-  350, 68, 426, 1419, 69, 45, 1421, 45, 246, 251,
-  45, 235, 235, 235, 254, 426, 45, 46, 46, 46,
-  46, 46, 46, 46, 46, 46, 46, 46, 46, 46,
-  46, 46, 439, 46, 46, 46, 46, 46, 70, 70,
-  70, 73, 73, 73, 350, 74, 74, 74, 75, 75,
-  75, 76, 76, 76, 70, 254, 263, 73, 254, 46,
-  46, 74, 278, 1004, 75, 439, 1428, 76, 46, 1004,
-  46, 1442, 263, 46, 245, 245, 245, 1112, 278, 46,
-  55, 55, 55, 55, 55, 55, 55, 55, 55, 55,
-
-  55, 55, 55, 55, 55, 1443, 55, 55, 55, 55,
-  55, 77, 77, 77, 78, 78, 78, 1112, 79, 79,
-  79, 80, 80, 80, 83, 83, 83, 77, 1444, 630,
-  78, 1111, 55, 55, 79, 289, 304, 80, 630, 55,
-  83, 248, 248, 248, 55, 257, 257, 257, 260, 260,
-  260, 289, 304, 55, 56, 56, 56, 56, 56, 56,
-  56, 56, 56, 56, 56, 56, 56, 56, 56, 1111,
-  56, 56, 56, 56, 56, 84, 84, 84, 87, 87,
-  87, 1445, 88, 88, 88, 91, 91, 91, 92, 92,
-  92, 84, 1325, 1325, 87, 1294, 56, 56, 88, 314,
-
-  328, 91, 1294, 56, 92, 271, 271, 271, 56, 275,
-  275, 275, 283, 283, 283, 314, 328, 56, 59, 59,
-  59, 59, 59, 59, 59, 59, 59, 59, 59, 59,
-  59, 59, 59, 1448, 59, 59, 59, 59, 59, 95,
-  95, 95, 96, 96, 96, 875, 97, 97, 97, 98,
-  98, 98, 99, 99, 99, 95, 284, 428, 96, 1451,
-  59, 59, 97, 284, 875, 98, 1232, 1433, 99, 1295,
-  428, 59, 284, 286, 286, 286, 1295, 59, 1452, 59,
-  59, 60, 60, 60, 60, 60, 60, 60, 60, 60,
-  60, 60, 60, 60, 60, 60, 1433, 60, 60, 60,
-
-  60, 60, 100, 100, 100, 101, 101, 101, 1232, 102,
-  102, 102, 105, 105, 105, 106, 106, 106, 100, 1326,
-  1326, 101, 299, 60, 60, 102, 539, 1230, 105, 299,
-  1453, 106, 1315, 1230, 60, 298, 298, 298, 299, 1315,
-  60, 539, 60, 60, 63, 63, 63, 63, 63, 63,
-  63, 63, 63, 63, 63, 63, 63, 63, 63, 1434,
-  63, 63, 63, 63, 63, 107, 107, 107, 108, 108,
-  108, 1454, 109, 109, 109, 110, 110, 110, 111, 111,
-  111, 107, 1455, 1316, 108, 309, 63, 63, 109, 342,
-  1316, 110, 309, 1434, 111, 301, 301, 301, 308, 308,
-
-  308, 309, 311, 311, 311, 342, 63, 64, 64, 64,
-  64, 64, 64, 64, 64, 64, 64, 64, 64, 64,
-  64, 64, 1456, 64, 64, 64, 64, 64, 112, 112,
-  112, 115, 115, 115, 1457, 116, 116, 116, 117, 117,
-  117, 118, 118, 118, 112, 1458, 1338, 115, 1459, 64,
-  64, 116, 356, 1413, 117, 1413, 1460, 118, 321, 321,
-  321, 325, 325, 325, 335, 335, 335, 1461, 356, 64,
-  71, 71, 71, 71, 71, 71, 71, 71, 71, 71,
-  71, 71, 71, 71, 71, 1338, 71, 71, 71, 71,
-  71, 119, 119, 119, 120, 120, 120, 1465, 121, 121,
-
-  121, 122, 122, 122, 125, 125, 125, 119, 366, 361,
-  120, 381, 71, 71, 121, 71, 361, 122, 1466, 1415,
-  125, 1415, 1467, 71, 366, 361, 71, 381, 1339, 71,
-  1468, 1470, 71, 72, 72, 72, 72, 72, 72, 72,
-  72, 72, 72, 72, 72, 72, 72, 72, 1477, 72,
-  72, 72, 72, 72, 126, 126, 126, 129, 129, 129,
-  1478, 130, 130, 130, 131, 131, 131, 132, 132, 132,
-  126, 1339, 386, 129, 1479, 72, 72, 130, 72, 386,
-  131, 1050, 1420, 132, 1420, 1480, 72, 1050, 386, 72,
-  1050, 1422, 72, 1422, 1050, 72, 81, 81, 81, 81,
-
-  81, 81, 81, 81, 81, 81, 81, 81, 81, 81,
-  81, 374, 81, 81, 81, 81, 81, 133, 133, 133,
-  134, 134, 134, 1482, 135, 135, 135, 136, 136, 136,
-  139, 139, 139, 133, 1485, 1051, 134, 1486, 81, 81,
-  135, 1051, 1487, 136, 1051, 374, 139, 162, 1051, 81,
-  339, 339, 339, 349, 349, 349, 353, 353, 353, 374,
-  1488, 81, 82, 82, 82, 82, 82, 82, 82, 82,
-  82, 82, 82, 82, 82, 82, 82, 1489, 82, 82,
-  82, 82, 82, 140, 140, 140, 162, 360, 360, 360,
-  1490, 1495, 162, 363, 363, 363, 162, 1496, 1497, 140,
-
-  1498, 162, 1499, 1500, 82, 82, 373, 373, 373, 378,
-  378, 378, 385, 385, 385, 82, 387, 387, 387, 542,
-  542, 542, 1521, 542, 710, 710, 710, 82, 85, 85,
-  85, 85, 85, 85, 85, 85, 85, 85, 85, 85,
-  85, 85, 85, 85, 85, 85, 85, 85, 85, 85,
-  85, 85, 85, 85, 85, 85, 85, 85, 85, 85,
-  85, 85, 85, 85, 85, 85, 85, 85, 85, 85,
-  85, 85, 85, 85, 85, 85, 85, 85, 85, 85,
-  85, 85, 85, 85, 85, 85, 85, 85, 85, 85,
-  85, 85, 85, 85, 85, 85, 85, 89, 89, 89,
-
-  89, 89, 89, 89, 89, 89, 89, 89, 89, 89,
-  89, 89, 1513, 89, 89, 89, 89, 89, 396, 396,
-  396, 437, 437, 437, 445, 445, 445, 460, 460, 460,
-  472, 472, 472, 718, 718, 718, 1522, 1523, 437, 89,
-  89, 445, 1524, 1529, 460, 1530, 1531, 472, 1513, 1231,
-  89, 90, 90, 90, 90, 90, 90, 90, 90, 90,
-  90, 90, 90, 90, 90, 90, 1514, 90, 90, 90,
-  90, 90, 1532, 396, 480, 480, 480, 1231, 486, 486,
-  486, 487, 487, 487, 496, 496, 496, 888, 888, 888,
-  1527, 480, 1533, 90, 90, 486, 1534, 1535, 487, 1536,
-
-  1514, 496, 1527, 1515, 90, 93, 93, 93, 93, 93,
-  93, 93, 93, 93, 93, 93, 93, 93, 93, 93,
-  1537, 93, 93, 93, 93, 93, 501, 501, 501, 523,
-  523, 523, 553, 553, 553, 554, 554, 554, 581, 581,
-  581, 1110, 1515, 501, 1538, 1539, 523, 93, 93, 1541,
-  553, 93, 1542, 554, 1543, 1551, 581, 1110, 93, 1552,
-  93, 893, 893, 893, 896, 896, 896, 93, 94, 94,
-  94, 94, 94, 94, 94, 94, 94, 94, 94, 94,
-  94, 94, 94, 1553, 94, 94, 94, 94, 94, 554,
-  582, 582, 582, 1558, 1528, 584, 584, 584, 585, 585,
-
-  585, 1559, 585, 1560, 1561, 585, 1528, 1562, 582, 1563,
-  94, 94, 584, 1568, 94, 593, 593, 593, 1569, 593,
-  1570, 94, 593, 94, 900, 900, 900, 904, 904, 904,
-  94, 103, 103, 103, 103, 103, 103, 103, 103, 103,
-  103, 103, 103, 103, 103, 103, 582, 103, 103, 103,
-  103, 103, 588, 588, 588, 1571, 1572, 589, 589, 589,
-  592, 592, 592, 594, 594, 594, 596, 596, 596, 1573,
-  588, 1586, 1594, 103, 103, 589, 103, 592, 1587, 103,
-  594, 1565, 1566, 596, 607, 607, 607, 1596, 607, 1565,
-  1566, 607, 1585, 103, 104, 104, 104, 104, 104, 104,
-
-  104, 104, 104, 104, 104, 104, 104, 104, 104, 1586,
-  104, 104, 104, 104, 104, 1599, 1587, 589, 1585, 1600,
-  598, 598, 598, 604, 604, 604, 1601, 1602, 599, 599,
-  599, 605, 605, 605, 1603, 1604, 104, 104, 598, 104,
-  1605, 604, 104, 618, 618, 618, 599, 618, 1606, 605,
-  618, 930, 930, 930, 1607, 1609, 104, 113, 113, 113,
-  113, 113, 113, 113, 113, 113, 113, 113, 113, 113,
-  113, 113, 599, 113, 113, 113, 113, 113, 606, 606,
-  606, 1610, 1611, 611, 611, 611, 614, 614, 614, 1612,
-  1616, 605, 617, 617, 617, 606, 612, 612, 612, 113,
-
-  113, 611, 113, 1617, 614, 113, 1009, 1009, 1009, 617,
-  113, 626, 626, 626, 612, 626, 1621, 1623, 626, 113,
-  114, 114, 114, 114, 114, 114, 114, 114, 114, 114,
-  114, 114, 114, 114, 114, 1627, 114, 114, 114, 114,
-  114, 615, 615, 615, 612, 1628, 623, 623, 623, 624,
-  624, 624, 625, 625, 625, 1629, 628, 628, 628, 615,
-  1630, 1631, 114, 114, 623, 114, 1632, 624, 114, 625,
-  1011, 1011, 1011, 114, 628, 1015, 1015, 1015, 1021, 1021,
-  1021, 1633, 114, 123, 123, 123, 123, 123, 123, 123,
-  123, 123, 123, 123, 123, 123, 123, 123, 615, 123,
-
-  123, 123, 123, 123, 1634, 1635, 624, 1636, 1638, 629,
-  629, 629, 631, 631, 631, 632, 632, 632, 1639, 632,
-  1640, 1641, 632, 1642, 1643, 123, 123, 629, 1656, 631,
-  1022, 1022, 1022, 1047, 1047, 1047, 123, 124, 124, 124,
-  124, 124, 124, 124, 124, 124, 124, 124, 124, 124,
-  124, 124, 1650, 124, 124, 124, 124, 124, 633, 633,
-  633, 634, 634, 634, 1658, 634, 1662, 1663, 634, 629,
-  635, 635, 635, 1664, 1665, 633, 1126, 1126, 1126, 124,
-  124, 643, 643, 643, 1650, 643, 1667, 635, 643, 1668,
-  124, 127, 127, 127, 127, 127, 127, 127, 127, 127,
-
-  127, 127, 127, 127, 127, 127, 1669, 127, 127, 127,
-  127, 127, 640, 640, 640, 642, 642, 642, 644, 644,
-  644, 641, 641, 641, 645, 645, 645, 647, 647, 647,
-  640, 1670, 642, 127, 127, 1649, 644, 1671, 1672, 641,
-  1673, 127, 645, 127, 647, 127, 1127, 1127, 1127, 1129,
-  1129, 1129, 1674, 127, 128, 128, 128, 128, 128, 128,
-  128, 128, 128, 128, 128, 128, 128, 128, 128, 1678,
-  128, 128, 128, 128, 128, 641, 648, 648, 648, 1649,
-  648, 645, 1680, 648, 652, 652, 652, 653, 653, 653,
-  655, 655, 655, 656, 656, 656, 128, 128, 662, 662,
-
-  662, 1681, 652, 1684, 128, 653, 128, 655, 128, 1685,
-  656, 1130, 1130, 1130, 1686, 662, 128, 137, 137, 137,
-  137, 137, 137, 137, 137, 137, 137, 137, 137, 137,
-  137, 137, 1687, 137, 137, 137, 137, 137, 1688, 653,
-  659, 659, 659, 1689, 664, 664, 664, 660, 660, 660,
-  665, 665, 665, 666, 666, 666, 1679, 1679, 659, 137,
-  137, 664, 667, 667, 667, 660, 1690, 1691, 665, 1692,
-  1693, 666, 1694, 668, 668, 668, 1696, 668, 1697, 667,
-  668, 1698, 137, 138, 138, 138, 138, 138, 138, 138,
-  138, 138, 138, 138, 138, 138, 138, 138, 1699, 138,
-
-  138, 138, 138, 138, 660, 669, 669, 669, 1700, 1701,
-  666, 670, 670, 670, 675, 675, 675, 676, 676, 676,
-  679, 679, 679, 669, 1710, 138, 138, 1704, 1711, 670,
-  1712, 1713, 675, 1716, 1717, 676, 1719, 1720, 679, 680,
-  680, 680, 696, 696, 696, 725, 725, 725, 138, 181,
-  697, 697, 697, 890, 890, 890, 181, 680, 1704, 1721,
-  696, 1723, 725, 670, 1728, 181, 1729, 890, 697, 699,
-  699, 699, 1730, 726, 726, 726, 1731, 676, 727, 727,
-  727, 1737, 1738, 729, 729, 729, 1739, 699, 1740, 1741,
-  181, 726, 181, 1742, 1744, 181, 727, 181, 181, 680,
-
-  181, 729, 1746, 1749, 181, 1750, 181, 181, 181, 182,
-  730, 730, 730, 699, 1751, 1752, 182, 731, 731, 731,
-  1753, 731, 1754, 1761, 731, 182, 1769, 730, 1770, 729,
-  734, 734, 734, 736, 736, 736, 737, 737, 737, 1771,
-  1772, 739, 739, 739, 744, 744, 744, 734, 1776, 1777,
-  182, 736, 182, 1778, 737, 182, 1779, 182, 182, 739,
-  182, 744, 1761, 1780, 182, 1781, 182, 182, 182, 741,
-  741, 741, 1783, 741, 1784, 1785, 741, 745, 745, 745,
-  1786, 745, 1791, 1792, 745, 739, 1793, 734, 746, 746,
-  746, 747, 747, 747, 748, 748, 748, 1794, 748, 1795,
-
-  1796, 748, 750, 750, 750, 746, 1799, 1800, 747, 751,
-  751, 751, 753, 753, 753, 756, 756, 756, 1801, 1802,
-  750, 758, 758, 758, 759, 759, 759, 751, 1803, 1804,
-  753, 1819, 756, 761, 761, 761, 762, 762, 762, 758,
-  762, 1821, 759, 762, 768, 768, 768, 769, 769, 769,
-  1824, 761, 771, 771, 771, 773, 773, 773, 774, 774,
-  774, 1815, 768, 1816, 1813, 769, 1825, 1827, 753, 1828,
-  771, 1831, 1832, 773, 1816, 1815, 774, 761, 776, 776,
-  776, 778, 778, 778, 1833, 778, 1834, 1841, 778, 785,
-  785, 785, 786, 786, 786, 1842, 776, 788, 788, 788,
-
-  1844, 789, 789, 789, 1845, 789, 1813, 785, 789, 1847,
-  786, 793, 793, 793, 771, 788, 794, 794, 794, 796,
-  796, 796, 1848, 799, 799, 799, 1850, 799, 1851, 793,
-  799, 805, 805, 805, 794, 1858, 1839, 796, 776, 802,
-  802, 802, 1855, 802, 1840, 1860, 802, 1839, 805, 806,
-  806, 806, 1862, 806, 1863, 1840, 806, 1856, 788, 811,
-  811, 811, 812, 812, 812, 814, 814, 814, 815, 815,
-  815, 1856, 815, 1857, 1857, 815, 796, 811, 1872, 1855,
-  812, 1873, 1874, 814, 818, 818, 818, 819, 819, 819,
-  821, 821, 821, 823, 823, 823, 1859, 823, 1875, 1887,
-
-  823, 1888, 818, 1889, 1891, 819, 1892, 1859, 821, 829,
-  829, 829, 830, 830, 830, 832, 832, 832, 834, 834,
-  834, 1899, 835, 835, 835, 1902, 835, 829, 814, 835,
-  830, 1903, 1904, 832, 1905, 834, 1909, 836, 836, 836,
-  837, 837, 837, 1921, 837, 1925, 1926, 837, 840, 840,
-  840, 1927, 1928, 821, 836, 841, 841, 841, 843, 843,
-  843, 845, 845, 845, 1933, 1931, 840, 1934, 846, 846,
-  846, 832, 846, 841, 1935, 846, 843, 1936, 845, 848,
-  848, 848, 849, 849, 849, 1937, 849, 1931, 1940, 849,
-  850, 850, 850, 851, 851, 851, 848, 853, 853, 853,
-
-  854, 854, 854, 1941, 854, 1942, 1940, 854, 850, 1943,
-  1944, 851, 857, 857, 857, 853, 858, 858, 858, 1945,
-  1948, 843, 860, 860, 860, 862, 862, 862, 1950, 1951,
-  857, 865, 865, 865, 858, 866, 866, 866, 1952, 1948,
-  860, 1953, 862, 868, 868, 868, 871, 871, 871, 865,
-  872, 872, 872, 866, 874, 874, 874, 876, 876, 876,
-  853, 868, 1959, 1961, 871, 884, 884, 884, 872, 911,
-  911, 911, 874, 1411, 1979, 876, 876, 1983, 860, 901,
-  901, 901, 1980, 884, 1956, 1965, 911, 912, 912, 912,
-  1956, 912, 1991, 901, 912, 913, 913, 913, 1965, 1987,
-
-  868, 914, 914, 914, 874, 915, 915, 915, 2013, 915,
-  1984, 1983, 915, 913, 918, 918, 918, 1979, 914, 920,
-  920, 920, 1997, 920, 1991, 1980, 920, 884, 923, 923,
-  923, 1410, 918, 924, 924, 924, 1987, 924, 1992, 1409,
-  924, 929, 929, 929, 1984, 923, 925, 925, 925, 913,
-  925, 1408, 2013, 925, 932, 932, 932, 1988, 1998, 929,
-  918, 933, 933, 933, 1997, 933, 2007, 2014, 933, 2008,
-  1992, 932, 934, 934, 934, 935, 935, 935, 939, 939,
-  939, 941, 941, 941, 945, 945, 945, 1407, 929, 934,
-  946, 946, 946, 935, 1988, 2007, 939, 2005, 2008, 941,
-
-  1998, 945, 947, 947, 947, 2017, 2006, 946, 948, 948,
-  948, 2014, 949, 949, 949, 950, 950, 950, 2011, 2017,
-  947, 935, 951, 951, 951, 948, 955, 955, 955, 941,
-  949, 2005, 950, 946, 952, 952, 952, 2012, 952, 951,
-  2006, 952, 1406, 955, 956, 956, 956, 2011, 957, 957,
-  957, 958, 958, 958, 959, 959, 959, 960, 960, 960,
-  2009, 956, 2010, 1405, 947, 957, 2012, 1394, 958, 2009,
-  949, 2010, 959, 1393, 2015, 960, 1392, 964, 964, 964,
-  965, 965, 965, 1391, 951, 2016, 967, 967, 967, 2018,
-  967, 1390, 957, 967, 964, 970, 970, 970, 965, 970,
-
-  2018, 1389, 970, 2015, 974, 974, 974, 975, 975, 975,
-  956, 987, 987, 987, 2016, 959, 1388, 958, 974, 960,
-  964, 1387, 977, 977, 977, 975, 977, 1381, 987, 977,
-  981, 981, 981, 965, 981, 1380, 1379, 981, 984, 984,
-  984, 985, 985, 985, 988, 988, 988, 1378, 988, 1377,
-  1376, 988, 991, 991, 991, 1375, 984, 1374, 1373, 985,
-  993, 993, 993, 994, 994, 994, 997, 997, 997, 975,
-  991, 1005, 1005, 1005, 1017, 1017, 1017, 993, 1018, 1018,
-  1018, 994, 1372, 1366, 997, 1024, 1024, 1024, 1017, 1005,
-  1363, 1361, 1018, 1359, 985, 1025, 1025, 1025, 991, 1024,
-
-  984, 1027, 1027, 1027, 1029, 1029, 1029, 1355, 1354, 1025,
-  1030, 1030, 1030, 1335, 997, 1027, 1333, 1332, 1029, 1322,
-  1005, 1031, 1031, 1031, 1030, 1031, 994, 1317, 1031, 1314,
-  997, 1034, 1034, 1034, 1017, 1035, 1035, 1035, 1313, 1035,
-  1310, 1296, 1035, 1293, 1292, 1024, 1052, 1052, 1052, 1034,
-  1040, 1040, 1040, 1042, 1042, 1042, 1291, 1042, 1277, 1276,
-  1042, 1027, 1275, 1052, 1029, 1046, 1046, 1046, 1040, 1049,
-  1049, 1049, 1274, 1049, 1273, 1272, 1049, 1053, 1053, 1053,
-  1271, 1053, 1270, 1046, 1053, 1054, 1054, 1054, 1055, 1055,
-  1055, 1056, 1056, 1056, 1034, 1057, 1057, 1057, 1040, 1058,
-
-  1058, 1058, 1269, 1054, 1268, 1055, 1264, 1263, 1056, 1060,
-  1060, 1060, 1057, 1061, 1061, 1061, 1260, 1058, 1065, 1065,
-  1065, 1259, 1046, 1066, 1066, 1066, 1060, 1066, 1257, 1255,
-  1066, 1061, 1249, 1054, 1247, 1065, 1067, 1067, 1067, 1068,
-  1068, 1068, 1244, 1068, 1243, 1056, 1068, 1070, 1070, 1070,
-  1071, 1071, 1071, 1067, 1072, 1072, 1072, 1061, 1072, 1239,
-  1233, 1072, 1073, 1073, 1073, 1070, 1225, 1071, 1074, 1074,
-  1074, 1075, 1075, 1075, 1223, 1075, 1222, 1221, 1075, 1214,
-  1073, 1076, 1076, 1076, 1208, 1074, 1077, 1077, 1077, 1078,
-  1078, 1078, 1207, 1078, 1206, 1204, 1078, 1202, 1076, 1079,
-
-  1079, 1079, 1179, 1077, 1080, 1080, 1080, 1081, 1081, 1081,
-  1082, 1082, 1082, 1083, 1083, 1083, 1079, 1087, 1087, 1087,
-  1178, 1080, 1177, 1172, 1081, 1088, 1088, 1088, 1082, 1088,
-  1171, 1083, 1088, 1170, 1087, 1090, 1090, 1090, 1091, 1091,
-  1091, 1157, 1092, 1092, 1092, 1094, 1094, 1094, 1095, 1095,
-  1095, 1155, 1154, 1090, 1153, 1091, 1151, 1150, 1080, 1092,
-  1147, 1083, 1146, 1094, 1144, 1095, 1096, 1096, 1096, 1097,
-  1097, 1097, 1082, 1143, 1098, 1098, 1098, 1100, 1100, 1100,
-  1141, 1100, 1140, 1096, 1100, 1139, 1137, 1097, 1098, 1105,
-  1105, 1105, 1098, 1094, 1107, 1107, 1107, 1108, 1108, 1108,
-
-  1133, 1108, 1092, 1132, 1108, 1131, 1128, 1105, 1125, 1096,
-  1124, 1107, 1109, 1109, 1109, 1123, 1122, 1097, 1115, 1115,
-  1115, 1116, 1116, 1116, 1117, 1117, 1117, 1118, 1118, 1118,
-  1109, 1134, 1134, 1134, 1121, 1115, 1120, 1105, 1116, 1119,
-  1114, 1117, 1135, 1135, 1135, 1118, 1136, 1136, 1136, 1138,
-  1138, 1138, 1142, 1142, 1142, 1106, 1145, 1145, 1145, 1148,
-  1148, 1148, 1149, 1149, 1149, 1104, 1103, 1109, 1099, 1093,
-  1142, 1089, 1086, 1116, 1145, 1085, 1084, 1148, 1069, 1149,
-  1064, 1117, 1063, 1062, 1118, 1158, 1158, 1158, 1048, 1158,
-  1045, 1041, 1158, 1161, 1161, 1161, 1162, 1162, 1162, 1142,
-
-  1039, 1163, 1163, 1163, 1038, 1163, 1028, 1161, 1163, 1026,
-  1023, 1161, 1020, 1162, 1148, 1164, 1164, 1164, 1165, 1165,
-  1165, 1166, 1166, 1166, 1019, 1166, 1016, 1014, 1166, 1167,
-  1167, 1167, 1164, 1013, 1012, 1165, 1168, 1168, 1168, 1010,
-  1168, 1008, 1007, 1168, 1006, 1003, 1167, 1169, 1169, 1169,
-  1173, 1173, 1173, 1002, 1173, 999, 996, 1173, 992, 1176,
-  1176, 1176, 990, 1176, 989, 1169, 1176, 1180, 1180, 1180,
-  1182, 1182, 1182, 986, 1182, 980, 976, 1182, 1185, 1185,
-  1185, 973, 1187, 1187, 1187, 1180, 1187, 966, 963, 1187,
-  1190, 1190, 1190, 1169, 962, 961, 1185, 1191, 1191, 1191,
-
-  944, 1191, 943, 942, 1191, 940, 938, 1190, 1192, 1192,
-  1192, 937, 1192, 936, 931, 1192, 1195, 1195, 1195, 1196,
-  1196, 1196, 928, 1196, 919, 917, 1196, 1197, 1197, 1197,
-  1198, 1198, 1198, 1195, 1199, 1199, 1199, 916, 1199, 910,
-  909, 1199, 908, 907, 1197, 906, 905, 1198, 1200, 1200,
-  1200, 1201, 1201, 1201, 1203, 1203, 1203, 1205, 1205, 1205,
-  903, 1205, 902, 899, 1205, 898, 1200, 897, 895, 1201,
-  894, 1203, 1209, 1209, 1209, 1211, 1211, 1211, 1212, 1212,
-  1212, 892, 1212, 891, 889, 1212, 1213, 1213, 1213, 887,
-  1209, 886, 1211, 1216, 1216, 1216, 1200, 1203, 1215, 1215,
-
-  1215, 885, 883, 1213, 1218, 1218, 1218, 1219, 1219, 1219,
-  1216, 1201, 1215, 1217, 1217, 1217, 1215, 1217, 882, 881,
-  1217, 1218, 1220, 1220, 1220, 1219, 1224, 1224, 1224, 1226,
-  1226, 1226, 880, 1226, 879, 870, 1226, 869, 1213, 864,
-  1220, 1229, 1229, 1229, 1224, 1234, 1234, 1234, 1235, 1235,
-  1235, 863, 1235, 861, 847, 1235, 1236, 1236, 1236, 1229,
-  844, 1218, 1234, 1237, 1237, 1237, 839, 838, 1220, 833,
-  1238, 1238, 1238, 1236, 1240, 1240, 1240, 1241, 1241, 1241,
-  1237, 1242, 1242, 1242, 1245, 1245, 1245, 1224, 1238, 1229,
-  1246, 1246, 1246, 1248, 1248, 1248, 1250, 1250, 1250, 1251,
-
-  1251, 1251, 1252, 1252, 1252, 1253, 1253, 1253, 1254, 1254,
-  1254, 828, 1236, 1256, 1256, 1256, 1258, 1258, 1258, 1261,
-  1261, 1261, 1265, 1265, 1265, 827, 1237, 1266, 1266, 1266,
-  1238, 1267, 1267, 1267, 1258, 1267, 826, 1261, 1267, 822,
-  1265, 1278, 1278, 1278, 1266, 1279, 1279, 1279, 810, 1279,
-  809, 808, 1279, 1282, 1282, 1282, 1283, 1283, 1283, 1278,
-  1283, 807, 798, 1283, 1258, 1284, 1284, 1284, 797, 1284,
-  1282, 792, 1284, 1287, 1287, 1287, 784, 1287, 783, 782,
-  1287, 1290, 1290, 1290, 1297, 1297, 1297, 1278, 1297, 781,
-  777, 1297, 772, 1300, 1300, 1300, 767, 1300, 766, 1290,
-
-  1300, 1303, 1303, 1303, 1304, 1304, 1304, 765, 1304, 757,
-  755, 1304, 1305, 1305, 1305, 749, 1305, 740, 1303, 1305,
-  1308, 1308, 1308, 1309, 1309, 1309, 1311, 1311, 1311, 1312,
-  1312, 1312, 1290, 1312, 735, 724, 1312, 723, 1308, 722,
-  721, 1309, 719, 1311, 1318, 1318, 1318, 717, 1318, 716,
-  715, 1318, 1321, 1321, 1321, 1323, 1323, 1323, 1324, 1324,
-  1324, 714, 1324, 713, 712, 1324, 1327, 1327, 1327, 1321,
-  1328, 1328, 1328, 1323, 1330, 1330, 1330, 1331, 1331, 1331,
-  1308, 711, 709, 1327, 1334, 1334, 1334, 708, 1328, 1337,
-  1337, 1337, 1330, 706, 1331, 1336, 1336, 1336, 1321, 1340,
-
-  1340, 1340, 1334, 705, 1341, 1341, 1341, 1337, 1341, 704,
-  1323, 1341, 703, 1336, 1344, 1344, 1344, 1345, 1345, 1345,
-  702, 701, 1327, 1346, 1346, 1346, 1347, 1347, 1347, 700,
-  695, 1344, 694, 693, 1345, 692, 1330, 1348, 1348, 1348,
-  689, 1346, 1349, 1349, 1349, 1334, 1350, 1350, 1350, 688,
-  687, 1336, 1351, 1351, 1351, 1352, 1352, 1352, 1353, 1353,
-  1353, 1356, 1356, 1356, 1357, 1357, 1357, 1344, 1358, 1358,
-  1358, 1360, 1360, 1360, 1362, 1362, 1362, 685, 1346, 1345,
-  1365, 1365, 1365, 1367, 1367, 1367, 1369, 1369, 1369, 681,
-  1369, 678, 1362, 1369, 1382, 1382, 1382, 1365, 1383, 1383,
-
-  1383, 1367, 1383, 677, 674, 1383, 1386, 1386, 1386, 1395,
-  1395, 1395, 1382, 1395, 673, 672, 1395, 1398, 1398, 1398,
-  1399, 1399, 1399, 671, 1386, 1401, 1401, 1401, 663, 1402,
-  1402, 1402, 661, 1402, 658, 1398, 1402, 657, 1399, 1416,
-  1416, 1416, 1401, 1417, 1417, 1417, 1418, 1418, 1418, 654,
-  651, 1382, 1423, 1423, 1423, 650, 1416, 1424, 1424, 1424,
-  1425, 1425, 1425, 649, 1418, 1427, 1427, 1427, 1401, 1423,
-  646, 639, 1426, 1426, 1426, 1424, 1426, 1425, 638, 1426,
-  637, 636, 1427, 1429, 1429, 1429, 1430, 1430, 1430, 1431,
-  1431, 1431, 1432, 1432, 1432, 1423, 1435, 1435, 1435, 627,
-
-  622, 1429, 1436, 1436, 1436, 621, 620, 1431, 619, 1418,
-  1432, 616, 613, 1424, 1437, 1437, 1437, 610, 609, 1436,
-  1438, 1438, 1438, 1439, 1439, 1439, 1440, 1440, 1440, 608,
-  603, 1437, 1441, 1441, 1441, 1446, 1446, 1446, 1438, 1449,
-  1449, 1449, 1450, 1450, 1450, 602, 1450, 601, 600, 1450,
-  1432, 1431, 597, 1446, 595, 591, 1449, 1462, 1462, 1462,
-  587, 586, 1437, 1463, 1463, 1463, 1472, 1472, 1472, 1473,
-  1473, 1473, 1475, 1475, 1475, 1462, 583, 580, 1476, 1476,
-  1476, 1463, 1476, 1472, 579, 1476, 578, 1473, 577, 1475,
-  1484, 1484, 1484, 1491, 1491, 1491, 1492, 1492, 1492, 576,
-
-  1492, 575, 574, 1492, 1493, 1493, 1493, 1484, 573, 572,
-  1491, 571, 570, 1462, 1494, 1494, 1494, 1501, 1501, 1501,
-  1502, 1502, 1502, 1503, 1503, 1503, 569, 1503, 568, 567,
-  1503, 566, 1494, 565, 1501, 1506, 1506, 1506, 1502, 1507,
-  1507, 1507, 564, 1507, 563, 562, 1507, 561, 1508, 1508,
-  1508, 560, 1506, 1509, 1509, 1509, 1511, 1511, 1511, 1512,
-  1512, 1512, 559, 558, 1501, 1508, 557, 556, 1494, 555,
-  552, 1509, 1516, 1516, 1516, 551, 550, 1512, 1501, 1517,
-  1517, 1517, 548, 1517, 547, 546, 1517, 545, 544, 1516,
-  1518, 1518, 1518, 1519, 1519, 1519, 1525, 1525, 1525, 1526,
-
-  1526, 1526, 540, 1526, 538, 537, 1526, 1518, 1540, 1540,
-  1540, 1519, 536, 1525, 1546, 1546, 1546, 1547, 1547, 1547,
-  535, 1547, 532, 531, 1547, 530, 1540, 529, 1548, 1548,
-  1548, 1546, 1548, 528, 527, 1548, 1556, 1556, 1556, 1557,
-  1557, 1557, 524, 1557, 520, 519, 1557, 1564, 1564, 1564,
-  518, 1564, 517, 1556, 1564, 1567, 1567, 1567, 1574, 1574,
-  1574, 1575, 1575, 1575, 1540, 1576, 1576, 1576, 516, 513,
-  1578, 1578, 1578, 1567, 1578, 1574, 512, 1578, 1575, 1581,
-  1581, 1581, 511, 1576, 1582, 1582, 1582, 510, 1582, 509,
-  508, 1582, 1583, 1583, 1583, 505, 1581, 1588, 1588, 1588,
-
-  504, 1588, 503, 502, 1588, 1591, 1591, 1591, 500, 497,
-  1583, 1592, 1592, 1592, 493, 1592, 492, 1567, 1592, 1574,
-  491, 1575, 1591, 1593, 1593, 1593, 1595, 1595, 1595, 1597,
-  1597, 1597, 1598, 1598, 1598, 490, 1598, 489, 488, 1598,
-  1614, 1614, 1614, 1615, 1615, 1615, 1597, 1618, 1618, 1618,
-  485, 1618, 482, 481, 1618, 1622, 1622, 1622, 1614, 477,
-  1615, 1624, 1624, 1624, 476, 1624, 475, 474, 1624, 1637,
-  1637, 1637, 1622, 1644, 1644, 1644, 1645, 1645, 1645, 1655,
-  1655, 1655, 1651, 1651, 1651, 473, 1615, 1637, 1614, 471,
-  1644, 468, 467, 1645, 1646, 1646, 1646, 464, 1646, 1651,
-
-  1651, 1646, 1652, 1652, 1652, 463, 1652, 462, 461, 1652,
-  1657, 1657, 1657, 1659, 1659, 1659, 457, 1659, 456, 455,
-  1659, 1637, 1645, 1666, 1666, 1666, 1675, 1675, 1675, 1676,
-  1676, 1676, 1677, 1677, 1677, 1644, 1677, 454, 450, 1677,
-  1666, 1682, 1682, 1682, 1675, 449, 1676, 1683, 1683, 1683,
-  448, 1683, 447, 446, 1683, 1695, 1695, 1695, 1682, 1702,
-  1702, 1702, 1703, 1703, 1703, 1705, 1705, 1705, 1706, 1706,
-  1706, 444, 1675, 1695, 441, 440, 1702, 438, 436, 1703,
-  433, 432, 1705, 1705, 429, 1706, 1706, 427, 1707, 1707,
-  1707, 424, 1707, 423, 421, 1707, 1708, 1708, 1708, 1709,
-
-  1709, 1709, 1702, 420, 419, 1703, 1707, 1714, 1714, 1714,
-  1715, 1715, 1715, 418, 1715, 417, 416, 1715, 1724, 1724,
-  1724, 1725, 1725, 1725, 1714, 1725, 413, 412, 1725, 1732,
-  1732, 1732, 411, 1733, 1733, 1733, 1724, 1733, 410, 409,
-  1733, 1736, 1736, 1736, 408, 407, 1732, 1747, 1747, 1747,
-  1755, 1755, 1755, 1756, 1756, 1756, 406, 1756, 1736, 405,
-  1756, 1757, 1757, 1757, 402, 1747, 401, 1755, 1758, 1758,
-  1758, 400, 1759, 1759, 1759, 399, 1759, 398, 1757, 1759,
-  1724, 1760, 1760, 1760, 392, 1758, 1762, 1762, 1762, 1763,
-  1763, 1763, 391, 1763, 389, 383, 1763, 379, 1760, 1767,
-
-  1767, 1767, 376, 1762, 1762, 375, 371, 1763, 370, 1764,
-  1764, 1764, 369, 1764, 368, 364, 1764, 1768, 1768, 1768,
-  358, 1773, 1773, 1773, 354, 1773, 1757, 1764, 1773, 1788,
-  1788, 1788, 351, 1788, 347, 346, 1788, 345, 1782, 1782,
-  1782, 344, 1787, 1787, 1787, 340, 1760, 1765, 1765, 1765,
-  1765, 1765, 1765, 1765, 1765, 1765, 1782, 337, 1765, 1787,
-  1789, 1789, 1789, 1765, 1765, 1765, 1765, 1765, 1790, 1790,
-  1790, 331, 1790, 330, 326, 1790, 323, 1789, 1805, 1805,
-  1805, 318, 1805, 317, 316, 1805, 1808, 1808, 1808, 1765,
-  1765, 1766, 1766, 1766, 1766, 1766, 1766, 1766, 1766, 1766,
-
-  312, 306, 1766, 1808, 1812, 1812, 1812, 1766, 1766, 1766,
-  1766, 1766, 1809, 1809, 1809, 302, 1809, 296, 295, 1809,
-  293, 1812, 1814, 1814, 1814, 292, 1814, 287, 281, 1814,
-  1829, 1829, 1829, 1766, 1766, 1835, 1835, 1835, 1808, 1835,
-  1814, 280, 1835, 1838, 1838, 1838, 276, 1838, 1829, 273,
-  1838, 269, 1853, 1853, 1853, 268, 1812, 1817, 1817, 1817,
-  1817, 1817, 1817, 1817, 1817, 1817, 267, 265, 1817, 1853,
-  1854, 1854, 1854, 1817, 1817, 1817, 1817, 1817, 1861, 1861,
-  1861, 1868, 1868, 1868, 1894, 1894, 1894, 1854, 1894, 261,
-  258, 1894, 255, 1869, 1869, 1869, 1861, 1861, 1868, 1817,
-
-  1817, 1818, 1818, 1818, 1818, 1818, 1818, 1818, 1818, 1818,
-  1869, 253, 1818, 249, 1853, 243, 242, 1818, 1818, 1818,
-  1818, 1818, 1870, 1870, 1870, 1871, 1871, 1871, 1884, 1884,
-  1884, 241, 1854, 1885, 1885, 1885, 1886, 1886, 1886, 1870,
-  240, 236, 1871, 1818, 1818, 1884, 1890, 1890, 1890, 230,
-  1885, 1893, 1893, 1893, 1886, 1895, 1895, 1895, 229, 1896,
-  1896, 1896, 228, 1896, 1890, 1870, 1896, 224, 1893, 1897,
-  1897, 1897, 1895, 1898, 1898, 1898, 221, 1898, 216, 1884,
-  1898, 1900, 1900, 1900, 1885, 214, 1897, 213, 1901, 1901,
-  1901, 209, 1901, 206, 1890, 1901, 204, 203, 1900, 1906,
-
-  1906, 1906, 1907, 1907, 1907, 1908, 1908, 1908, 1912, 1912,
-  1912, 202, 1912, 198, 192, 1912, 1906, 188, 184, 1907,
-  1915, 1915, 1915, 1908, 1915, 178, 177, 1915, 1918, 1918,
-  1918, 173, 1918, 169, 168, 1918, 1922, 1922, 1922, 167,
-  1922, 1908, 1906, 1922, 161, 1907, 1929, 1929, 1929, 1930,
-  1930, 1930, 1938, 1938, 1938, 1939, 1939, 1939, 1946, 1946,
-  1946, 160, 158, 1929, 155, 143, 1930, 0, 0, 1938,
-  0, 0, 1939, 0, 0, 1946, 1947, 1947, 1947, 1949,
-  1949, 1949, 1954, 1954, 1954, 1955, 1955, 1955, 1957, 1957,
-  1957, 0, 0, 1947, 0, 0, 1949, 0, 0, 1954,
-
-  0, 0, 1955, 1929, 0, 1957, 1930, 0, 0, 1946,
-  0, 1958, 1958, 1958, 1938, 1958, 0, 1939, 1958, 1963,
-  1963, 1963, 1964, 1964, 1964, 0, 0, 1947, 0, 0,
-  1954, 0, 0, 1955, 0, 0, 1963, 0, 0, 1964,
-  1966, 1966, 1966, 0, 1966, 0, 0, 1966, 1971, 1971,
-  1971, 1972, 1972, 1972, 1973, 1973, 1973, 1974, 1974, 1974,
-  1975, 1975, 1975, 0, 0, 1971, 0, 0, 1972, 1976,
-  1976, 1976, 1973, 1976, 1974, 0, 1976, 1975, 0, 1963,
-  0, 0, 1964, 1977, 1977, 1977, 0, 1976, 1978, 1978,
-  1978, 1971, 0, 0, 1972, 1981, 1981, 1981, 0, 0,
-
-  1977, 0, 1982, 1982, 1982, 1978, 1985, 1985, 1985, 1986,
-  1986, 1986, 1981, 1989, 1989, 1989, 0, 0, 1974, 1982,
-  1975, 0, 0, 1985, 0, 0, 1986, 1990, 1990, 1990,
-  1989, 1977, 1993, 1993, 1993, 0, 1978, 0, 1994, 1994,
-  1994, 0, 1994, 0, 1990, 1994, 0, 0, 1982, 1993,
-  0, 1981, 0, 1985, 1995, 1995, 1995, 1996, 1996, 1996,
-  0, 1996, 0, 0, 1996, 1999, 1999, 1999, 0, 1999,
-  0, 1995, 1999, 1986, 2002, 2002, 2002, 0, 2002, 0,
-  0, 2002, 2019, 2019, 2019, 2020, 2020, 2020, 0, 0,
-  0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-
-  2019, 0, 0, 2020, 2023, 2023, 2023, 2023, 2023, 2023,
-  2023, 2023, 2023, 2024, 2024, 2024, 2024, 2024, 2024, 2024,
-  2024, 2024, 2025, 2025, 2025, 2025, 2025, 2025, 2025, 2025,
-  2025, 2026, 2026, 2026, 2026, 2026, 2026, 2026, 2026, 2026,
-  2027, 2027, 2027, 2027, 2027, 2027, 2027, 2027, 2027, 2028,
-  2028, 2028, 2028, 2028, 2028, 2028, 2028, 2028, 2029, 2029,
-  2029, 2029, 2029, 2029, 2029, 2029, 2029, 2030, 2030, 2030,
-  2030, 2030, 2030, 2030, 2030, 2030, 2031, 2031, 2031, 2031,
-  2031, 2031, 2031, 2031, 2031, 2032, 2032, 2032, 2032, 2032,
-  2032, 2032, 2032, 2032, 2033, 2033, 2033, 2033, 2033, 2033,
-
-  2033, 2033, 2033, 2034, 2034, 2034, 2034, 2034, 2034, 2034,
-  2034, 2034, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
-  2035, 2036, 2036, 2036, 2036, 2036, 2036, 2036, 2036, 2036,
-  2037, 2037, 2037, 2037, 2037, 2037, 2037, 2037, 2037, 2038,
-  2038, 2038, 2038, 2038, 2038, 2038, 2038, 2038, 2039, 2039,
-  2039, 2039, 2039, 2039, 2039, 2039, 2039, 2040, 2040, 2040,
-  2040, 2040, 2040, 2040, 2040, 2040, 2041, 2041, 2041, 2041,
-  2041, 2041, 2041, 2041, 2041, 2042, 2042, 2042, 2042, 2042,
-  2042, 2042, 2042, 2042, 2043, 2043, 2043, 2043, 2043, 2043,
-  2043, 2043, 2043, 2044, 2044, 2044, 2044, 2044, 2044, 2044,
-
-  2044, 2044, 2045, 2045, 2045, 2045, 2045, 2045, 2045, 2045,
-  2045, 2046, 2046, 2046, 2046, 2046, 2046, 2046, 2046, 2046,
-  2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2048,
-  2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2049, 2049,
-  2049, 2049, 2049, 2049, 2049, 2049, 2049, 2050, 2050, 2050,
-  2050, 2050, 2050, 2050, 2050, 2050, 2051, 2051, 2051, 2051,
-  2051, 2051, 2051, 2051, 2051, 2052, 2052, 2052, 2052, 2052,
-  2052, 2052, 2052, 2052, 2053, 2053, 2053, 2053, 2053, 2053,
-  2053, 2053, 2053, 2054, 2054, 2054, 2054, 2054, 2054, 2054,
-  2054, 2054, 2055, 2055, 2055, 2055, 2055, 2055, 2055, 2055,
-
-  2055, 2056, 2056, 2056, 2056, 2056, 2056, 2056, 2056, 2056,
-  2057, 2057, 2057, 2057, 2057, 2057, 2057, 2057, 2057, 2058,
-  2058, 2058, 2058, 2058, 2058, 2058, 2058, 2058, 2059, 2059,
-  2059, 2059, 2059, 2059, 2059, 2059, 2059, 2060, 2060, 2060,
-  2060, 2060, 2060, 2060, 2060, 2060, 2061, 2061, 2061, 2061,
-  2061, 2061, 2061, 2061, 2061, 2062, 2062, 2062, 0, 0,
-  0, 2062, 2063, 2063, 2063, 0, 0, 0, 2063, 2064,
-  2064, 2064, 0, 0, 0, 2064, 2065, 2065, 2065, 0,
-  0, 0, 2065, 2066, 2066, 2066, 0, 0, 0, 2066,
-  2067, 2067, 2067, 0, 0, 0, 2067, 2068, 2068, 2068,
-
-  0, 0, 0, 2068, 2069, 2069, 2069, 0, 0, 0,
-  2069, 2070, 2070, 2070, 0, 0, 0, 2070, 2071, 2071,
-  2071, 0, 0, 0, 2071, 2072, 2072, 2072, 0, 0,
-  0, 2072, 2073, 2073, 2073, 0, 0, 0, 2073, 2074,
-  2074, 2074, 0, 0, 0, 2074, 2075, 2075, 2075, 0,
-  0, 0, 2075, 2076, 2076, 2076, 0, 0, 0, 2076,
-  2077, 2077, 2077, 0, 0, 0, 2077, 2078, 2078, 2078,
-  0, 0, 0, 2078, 2079, 2079, 2079, 2079, 2079, 2079,
-  2079, 0, 2079, 2080, 0, 0, 0, 2080, 2081, 0,
-  0, 0, 2081, 2082, 0, 0, 0, 2082, 2083, 0,
-
-  0, 0, 2083, 2084, 0, 0, 0, 2084, 2085, 0,
-  0, 0, 2085, 2086, 0, 0, 0, 2086, 2087, 0,
-  0, 0, 2087, 2088, 0, 0, 0, 2088, 2089, 2089,
-  2089, 0, 0, 0, 2089, 2090, 0, 0, 0, 2090,
-  2091, 2091, 2091, 0, 0, 0, 2091, 2092, 0, 0,
-  0, 2092, 2093, 2093, 2093, 0, 0, 0, 2093, 2094,
-  0, 0, 0, 2094, 2095, 2095, 2095, 0, 0, 0,
-  2095, 2096, 0, 0, 0, 2096, 2097, 2097, 2097, 0,
-  0, 0, 2097, 2098, 0, 0, 0, 2098, 2099, 2099,
-  2099, 0, 0, 0, 2099, 2100, 0, 0, 0, 2100,
-
-  2101, 2101, 2101, 0, 0, 0, 2101, 2102, 0, 0,
-  0, 2102, 2103, 2103, 2103, 0, 0, 0, 2103, 2104,
-  0, 0, 0, 2104, 2105, 2105, 2105, 2105, 2105, 2105,
-  2105, 2105, 2105, 2106, 0, 0, 0, 0, 2106, 2107,
-  2107, 2107, 0, 0, 0, 2107, 2108, 2108, 2108, 2108,
-  0, 0, 2108, 2108, 2109, 2109, 2109, 0, 0, 0,
-  2109, 2110, 2110, 2110, 2110, 0, 0, 2110, 2110, 2111,
-  2111, 2111, 0, 0, 0, 2111, 2112, 2112, 2112, 2112,
-  0, 0, 2112, 2112, 2113, 2113, 2113, 0, 0, 0,
-  2113, 2114, 2114, 2114, 2114, 0, 0, 2114, 2114, 2115,
-
-  2115, 2115, 0, 0, 0, 2115, 2116, 2116, 2116, 2116,
-  0, 0, 2116, 2116, 2117, 2117, 2117, 0, 0, 0,
-  2117, 2118, 2118, 2118, 2118, 0, 0, 2118, 2118, 2119,
-  2119, 2119, 0, 0, 0, 2119, 2120, 2120, 2120, 2120,
-  0, 0, 2120, 2120, 2121, 2121, 2121, 0, 0, 0,
-  2121, 2122, 2122, 2122, 2122, 0, 0, 2122, 2122, 2123,
-  2123, 2123, 0, 0, 0, 2123, 2124, 2124, 2124, 2124,
-  0, 0, 2124, 2124, 2125, 2125, 2125, 0, 0, 0,
-  2125, 2126, 2126, 2126, 2126, 0, 0, 2126, 2126, 2127,
-  2127, 2127, 2127, 0, 0, 2127, 2127, 2128, 2128, 2128,
-
-  0, 0, 0, 2128, 2129, 2129, 2129, 2129, 0, 0,
-  2129, 2129, 2130, 2130, 2130, 0, 0, 0, 2130, 2131,
-  2131, 2131, 2131, 0, 0, 2131, 2131, 2132, 2132, 2132,
-  0, 0, 0, 2132, 2133, 2133, 2133, 2133, 0, 0,
-  2133, 2133, 2134, 2134, 2134, 2134, 0, 0, 2134, 2134,
-  2135, 2135, 2135, 0, 0, 0, 2135, 2136, 2136, 2136,
-  2136, 0, 0, 2136, 2136, 2137, 2137, 2137, 0, 0,
-  0, 2137, 2138, 2138, 2138, 2138, 0, 0, 2138, 2138,
-  2139, 2139, 2139, 2139, 2139, 2139, 2139, 2139, 2139, 2140,
-  0, 2140, 0, 0, 2140, 2141, 2141, 2141, 0, 0,
-
-  0, 2141, 2142, 2142, 2142, 2142, 0, 0, 2142, 2142,
-  2143, 2143, 2143, 2143, 0, 2143, 0, 2143, 2144, 2144,
-  2144, 2144, 0, 0, 2144, 2144, 2145, 2145, 2145, 2145,
-  0, 2145, 0, 2145, 2146, 2146, 2146, 2146, 0, 0,
-  2146, 2146, 2147, 2147, 2147, 0, 0, 0, 2147, 2148,
-  2148, 2148, 2148, 0, 0, 2148, 2148, 2149, 2149, 2149,
-  0, 0, 0, 2149, 2150, 2150, 2150, 2150, 0, 0,
-  2150, 2150, 2151, 2151, 2151, 0, 0, 0, 2151, 2152,
-  2152, 2152, 2152, 0, 0, 2152, 2152, 2153, 2153, 2153,
-  0, 0, 0, 2153, 2154, 2154, 2154, 2154, 0, 0,
-
-  2154, 2154, 2155, 2155, 2155, 0, 0, 0, 2155, 2156,
-  2156, 2156, 2156, 0, 0, 2156, 2156, 2157, 2157, 2157,
-  0, 0, 0, 2157, 2158, 2158, 2158, 2158, 0, 0,
-  2158, 2158, 2159, 2159, 2159, 0, 0, 0, 2159, 2160,
-  2160, 2160, 2160, 0, 0, 2160, 2160, 2161, 2161, 2161,
-  2161, 0, 0, 2161, 2161, 2162, 2162, 2162, 0, 0,
-  0, 2162, 2163, 2163, 2163, 2163, 0, 0, 2163, 2163,
-  2164, 2164, 2164, 0, 0, 0, 2164, 2165, 2165, 2165,
-  2165, 0, 0, 2165, 2165, 2166, 2166, 2166, 0, 0,
-  0, 2166, 2167, 2167, 2167, 2167, 0, 0, 2167, 2167,
-
-  2168, 2168, 2168, 2168, 0, 0, 2168, 2168, 2169, 2169,
-  2169, 0, 0, 0, 2169, 2170, 2170, 2170, 2170, 0,
-  0, 2170, 2170, 2171, 2171, 2171, 0, 0, 0, 2171,
-  2172, 2172, 2172, 2172, 0, 0, 2172, 2172, 2173, 2173,
-  2173, 2173, 2173, 2173, 2173, 2173, 2173, 2174, 2174, 2174,
-  2174, 2174, 2174, 2174, 2174, 2174, 2175, 2175, 2175, 0,
-  0, 0, 2175, 2176, 2176, 2176, 2176, 0, 0, 2176,
-  2176, 2177, 2177, 2177, 2177, 0, 0, 2177, 2177, 2178,
-  2178, 2178, 0, 0, 0, 2178, 2179, 2179, 2179, 2179,
-  0, 0, 2179, 2179, 2180, 2180, 2180, 0, 0, 0,
-
-  2180, 2181, 2181, 2181, 2181, 0, 0, 2181, 2181, 2182,
-  2182, 2182, 0, 0, 0, 2182, 2183, 2183, 2183, 2183,
-  0, 0, 2183, 2183, 2184, 2184, 2184, 0, 0, 0,
-  2184, 2185, 2185, 2185, 2185, 0, 0, 2185, 2185, 2186,
-  2186, 2186, 0, 0, 0, 2186, 2187, 2187, 2187, 2187,
-  0, 0, 2187, 2187, 2188, 2188, 2188, 0, 0, 0,
-  2188, 2189, 2189, 2189, 2189, 0, 0, 2189, 2189, 2190,
-  2190, 2190, 2190, 0, 2190, 0, 2190, 2191, 2191, 2191,
-  2191, 0, 0, 2191, 2191, 2192, 2192, 2192, 2192, 0,
-  2192, 0, 2192, 2193, 2193, 2193, 2193, 0, 0, 2193,
-
-  2193, 2194, 2194, 2194, 2194, 0, 0, 2194, 2194, 2195,
-  2195, 2195, 0, 0, 0, 2195, 2196, 2196, 2196, 2196,
-  0, 0, 2196, 2196, 2197, 2197, 2197, 0, 0, 0,
-  2197, 2198, 2198, 2198, 2198, 0, 0, 2198, 2198, 2199,
-  2199, 2199, 0, 0, 0, 2199, 2200, 2200, 2200, 2200,
-  0, 0, 2200, 2200, 2201, 2201, 2201, 2201, 0, 0,
-  2201, 2201, 2202, 2202, 2202, 0, 0, 0, 2202, 2203,
-  2203, 2203, 2203, 0, 0, 2203, 2203, 2204, 2204, 2204,
-  2204, 0, 2204, 0, 2204, 2205, 2205, 2205, 2205, 0,
-  0, 2205, 2205, 2206, 2206, 2206, 2206, 2206, 2206, 2206,
-
-  2206, 2206, 2207, 2207, 2207, 2207, 2207, 2207, 2207, 2207,
-  2207, 2208, 2208, 2208, 0, 0, 0, 2208, 2209, 2209,
-  2209, 2209, 0, 0, 2209, 2209, 2210, 2210, 2210, 2210,
-  0, 0, 2210, 2210, 2211, 2211, 2211, 0, 0, 0,
-  2211, 2212, 2212, 2212, 2212, 0, 0, 2212, 2212, 2213,
-  2213, 2213, 0, 0, 0, 2213, 2214, 2214, 2214, 2214,
-  0, 0, 2214, 2214, 2215, 2215, 2215, 0, 0, 0,
-  2215, 2216, 2216, 2216, 2216, 0, 0, 2216, 2216, 2217,
-  2217, 2217, 2217, 0, 2217, 0, 2217, 2218, 2218, 2218,
-  2218, 0, 2218, 0, 2218, 2219, 2219, 2219, 2219, 0,
-
-  0, 2219, 2219, 2220, 2220, 2220, 0, 0, 0, 2220,
-  2221, 2221, 2221, 2221, 0, 0, 2221, 2221, 2222, 2222,
-  2222, 2222, 0, 0, 2222, 2222, 2223, 2223, 2223, 2223,
-  0, 2223, 0, 2223, 2224, 2224, 2224, 2224, 0, 0,
-  2224, 2224, 2225, 2225, 2225, 2225, 0, 0, 2225, 2225,
-  2226, 2226, 2226, 0, 0, 0, 2226, 2227, 2227, 2227,
-  2227, 0, 0, 2227, 2227, 2228, 2228, 2228, 2228, 0,
-  2228, 0, 2228, 2229, 2229, 2229, 2229, 0, 0, 2229,
-  2229, 2230, 2230, 2230, 2230, 0, 2230, 0, 2230, 2231,
-  2231, 2231, 2231, 0, 0, 2231, 2231, 2232, 2232, 2232,
-
-  2232, 0, 0, 2232, 2232, 2233, 2233, 2233, 0, 0,
-  0, 2233, 2234, 2234, 2234, 2234, 0, 0, 2234, 2234,
-  2235, 2235, 2235, 2235, 0, 0, 2235, 2235, 2236, 2236,
-  2236, 2236, 2236, 2236, 2236, 2236, 2236, 2237, 2237, 2237,
-  2237, 2237, 2237, 2237, 2237, 2237, 2238, 2238, 2238, 2238,
-  0, 2238, 0, 2238, 2239, 2239, 2239, 2239, 0, 0,
-  2239, 2239, 2240, 2240, 2240, 2240, 0, 0, 2240, 2240,
-  2241, 2241, 2241, 0, 0, 0, 2241, 2242, 2242, 2242,
-  2242, 0, 0, 2242, 2242, 2243, 2243, 2243, 0, 0,
-  0, 2243, 2244, 2244, 2244, 2244, 0, 0, 2244, 2244,
-
-  2245, 2245, 2245, 2245, 0, 2245, 0, 2245, 2246, 2246,
-  2246, 2246, 0, 0, 2246, 2246, 2247, 2247, 2247, 2247,
-  0, 2247, 0, 2247, 2248, 2248, 2248, 2248, 0, 0,
-  2248, 2248, 2249, 2249, 2249, 0, 0, 0, 2249, 2250,
-  2250, 2250, 2250, 2250, 2250, 2250, 2250, 2250, 2251, 2251,
-  2251, 2251, 2251, 2251, 2251, 2251, 2251, 2252, 2252, 2252,
-  2252, 2252, 2252, 2252, 2252, 2252, 2253, 2253, 2253, 2253,
-  2253, 2253, 2253, 2253, 2253, 2254, 2254, 2254, 2254, 2254,
-  2254, 2254, 2254, 2254, 2255, 2255, 2255, 2255, 2255, 2255,
-  2255, 2255, 2255, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022, 2022,
-  2022, 2022, 2022
-};
+struct yy_trans_info
+       {
+       flex_int32_t yy_verify;
+       flex_int32_t yy_nxt;
+       };
+static yyconst flex_int16_t yy_accept[2036] =
+    {   0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,  354,  352,   15,   10,   10,   15,   15,  332,
+       10,  332,    5,    6,    5,    8,    9,    8,  348,  340,
+      341,  349,  346,  349,  347,  351,  340,  341,  351,  352,
+       26,   10,   26,   26,   26,   24,   26,   26,   30,   10,
+       30,   30,  352,  352,   30,   37,   10,   37,   37,   37,
+       35,   37,   41,   10,   41,   54,   10,   54,   54,   54,
+
+       52,   54,   54,   54,   54,  349,  348,   76,   10,   76,
+       76,   76,   74,   76,   76,   76,   76,   80,   10,   80,
+      352,   80,   99,   10,   99,   99,   99,   97,   99,   99,
+       99,  103,   10,  103,  116,   10,  116,  116,  116,  114,
+      116,  116,  116,  116,  120,   10,  120,  127,   10,  127,
+      127,  127,  125,  127,  352,  352,  131,   10,  131,  158,
+       10,  158,  158,  158,  156,  158,  158,  158,  158,  158,
+      162,   10,  162,  162,  171,   10,  171,  171,  171,  169,
+      171,  171,  175,   10,  175,  198,   10,  198,  198,  198,
+      196,  198,  198,  198,  198,  198,  198,  202,   10,  202,
+
+      209,   10,  209,  209,  209,  207,  209,  213,   10,  213,
+      238,   10,  238,  238,  238,  236,  238,  238,  238,  238,
+      242,   10,  242,  242,  261,   10,  261,  261,  261,  259,
+      261,  261,  261,  352,  265,   10,  265,  265,  288,   10,
+      288,  288,  288,  286,  288,  288,  288,  288,  292,   10,
+      292,  292,  299,   10,  299,  299,  299,  297,  299,  303,
+       10,  303,  316,   10,  316,  316,  316,  314,  316,  316,
+      316,  316,  320,   10,  320,  352,  320,  327,   10,  327,
+      327,  327,  325,  327,  331,   10,  331,   10,    0,    2,
+        2,    0,    4,    7,  343,  342,    0,    0,    0,    0,
+
+        0,    0,    0,   25,   27,   27,   27,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+       36,   38,   38,    0,   53,   55,   55,   55,   55,   55,
+        0,    0,    0,   75,   77,   77,   77,   77,   77,   77,
+       77,    0,    0,   98,  100,  100,  100,  100,    0,  115,
+      117,  117,  117,  117,  117,    0,  126,  128,  128,    0,
+      157,  159,  159,  159,  159,  159,  159,  159,    0,  170,
+      172,  172,  172,    0,  197,  199,  199,  199,  199,  199,
+      199,  199,  199,  199,    0,  208,  210,  210,    0,  237,
+
+      239,  239,  239,  239,  239,  239,    0,  260,  262,  262,
+      262,  262,  262,    0,    0,  287,  289,  289,  289,  289,
+      289,    0,  298,  300,  300,    0,  315,  317,  317,  317,
+      317,  317,    0,    0,  326,  328,  328,    0,    0,    0,
+        0,    0,    3,    0,    0,    0,    0,    0,    0,    0,
+      350,    0,   27,   27,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,   38,    0,    0,   55,    0,    0,   55,   55,    0,
+        0,    0,  345,   77,    0,    0,   77,   77,   77,   77,
+
+        0,    0,    0,  100,  100,  100,    0,    0,    0,    0,
+      117,  117,  117,    0,    0,  128,    0,    0,  159,    0,
+        0,  159,  159,  159,  159,    0,    0,    0,    0,  172,
+        0,    0,  199,    0,    0,    0,    0,  199,  199,  199,
+      199,  199,    0,    0,    0,    0,    0,    0,  239,    0,
+        0,  239,  239,  239,    0,    0,  262,  262,  262,  262,
+        0,    0,    0,  289,  289,  289,  289,    0,    0,    0,
+        0,    0,    0,  317,  317,  317,  317,    0,    0,    0,
+      328,    0,    0,    0,   14,    1,    0,    0,  338,    0,
+        0,    0,  335,  334,    0,    0,   27,   27,    0,    0,
+
+       29,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,  105,    0,    0,    0,    0,    0,    0,    0,
+      104,    0,    0,    0,    0,    0,    0,   38,    0,    0,
+       40,    0,   55,    0,   45,   44,   55,   55,    0,    0,
+        0,   57,    0,   77,    0,   61,   60,    0,    0,   77,
+        0,    0,   77,    0,    0,   79,    0,    0,  100,  100,
+      100,    0,    0,  102,    0,    0,  107,  106,  117,  117,
+      117,    0,    0,  119,    0,  128,    0,    0,  130,    0,
+      159,    0,  135,  134,  159,  159,  159,  159,    0,    0,
+      161,    0,    0,  166,  165,  172,    0,    0,  174,    0,
+
+      199,  199,    0,  189,  188,    0,  179,  178,    0,    0,
+      199,  199,  199,  199,    0,    0,  201,    0,    0,  206,
+      205,    0,    0,  212,    0,  239,    0,  217,  216,  239,
+      239,  239,    0,    0,  241,    0,  262,    0,    0,    0,
+        0,  262,    0,    0,    0,  264,    0,  289,    0,    0,
+      289,    0,    0,    0,    0,  291,    0,    0,  296,  295,
+        0,    0,  302,    0,  317,  317,  317,  317,    0,    0,
+      319,    0,    0,  328,    0,    0,  330,    0,    0,    0,
+      339,  333,    0,    0,    0,   27,   27,    0,    0,    0,
+        0,  133,    0,  215,    0,    0,  163,    0,    0,  105,
+
+        0,    0,    0,  132,  214,    0,    0,  104,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,   55,
+       55,    0,    0,   77,    0,   65,   64,    0,    0,    0,
+       63,   62,   77,    0,  164,  100,    0,    0,  100,    0,
+      117,  117,  117,    0,  128,    0,  159,  159,  159,  159,
+      159,    0,  172,    0,  199,  199,    0,  191,  190,  199,
+      199,  199,  199,    0,    0,  239,  239,  239,  239,    0,
+      262,    0,  248,  247,    0,  246,  245,  262,  214,    0,
+      289,    0,  271,  270,  289,    0,  269,  268,    0,    0,
+      317,    0,    0,  317,  317,    0,    0,  328,    0,    0,
+
+        0,    0,   12,    0,  336,  337,    0,   27,   27,    0,
+        0,    0,    0,  133,    0,  215,    0,    0,    0,  163,
+        0,  267,   43,    0,    0,  132,  214,    0,  267,   42,
+        0,  266,    0,  266,   42,    0,   34,   33,    0,    0,
+       47,   46,   55,   55,    0,    0,   77,    0,   67,   66,
+       77,    0,  164,  100,    0,    0,    0,    0,    0,    0,
+      117,  117,  117,    0,  118,  128,    0,  159,  159,  159,
+        0,    0,    0,    0,  159,    0,    0,    0,    0,    0,
+        0,  199,    0,    0,  199,  199,  199,    0,    0,  239,
+      239,  239,    0,    0,  239,    0,  262,  262,    0,    0,
+
+      289,  289,    0,    0,  317,    0,  307,  306,  317,  317,
+        0,    0,    0,    0,    0,    0,    0,    0,   11,    0,
+       27,   27,   27,    0,    0,    0,    0,    0,    0,    0,
+        0,   59,  267,    0,  204,   43,    0,    0,    0,   58,
+      203,   42,    0,  266,    0,    0,    0,    0,   55,   55,
+        0,    0,   77,   77,    0,  100,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,   94,   93,    0,    0,    0,
+      117,    0,    0,    0,    0,    0,  159,  159,  159,    0,
+      137,  136,    0,    0,    0,  159,    0,  160,    0,  168,
+      167,    0,  173,    0,  193,  192,    0,    0,    0,  187,
+
+      186,    0,    0,  199,    0,    0,    0,    0,  239,  239,
+      239,    0,    0,    0,  239,    0,  240,    0,    0,  262,
+        0,    0,    0,    0,  289,    0,    0,  317,  317,  317,
+        0,    0,    0,  324,  323,    0,    0,    0,    0,    0,
+        0,    0,   27,   27,    0,    0,  177,  122,   32,    0,
+        0,  305,   59,    0,  204,    0,  176,  121,   58,  203,
+      304,    0,   31,    0,    0,   55,   55,    0,    0,   56,
+       77,   77,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,  109,  108,    0,
+        0,    0,  111,  110,    0,  124,  123,    0,  159,  159,
+
+      159,    0,    0,  159,    0,  195,  194,    0,  181,  180,
+        0,    0,    0,  183,  182,    0,    0,  239,    0,    0,
+      239,  239,    0,    0,  239,    0,    0,    0,  262,    0,
+        0,    0,    0,    0,  289,    0,  290,    0,  317,  317,
+      317,    0,    0,    0,    0,    0,    0,   17,    0,   19,
+       18,   27,   27,    0,  321,  177,  122,   32,  293,   16,
+      305,    0,    0,  176,  121,  304,    0,   31,    0,    0,
+       55,    0,    0,  344,   77,   77,    0,   78,    0,   96,
+       95,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,  113,  112,    0,  159,  159,  159,    0,
+
+        0,    0,    0,  159,    0,  185,  184,    0,    0,  211,
+      239,    0,  223,  222,  239,  239,    0,    0,    0,    0,
+      239,    0,    0,    0,    0,  262,  294,    0,    0,    0,
+        0,    0,  289,    0,    0,    0,  317,  317,    0,  322,
+        0,    0,    0,    0,   17,   27,   27,    0,  321,  293,
+       16,    0,    0,    0,    0,    0,   39,   55,    0,   51,
+       50,    0,    0,   77,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,  129,  159,  159,  159,
+        0,  143,    0,  142,  159,    0,  200,    0,    0,  239,
+      239,  239,    0,  227,    0,  226,  239,    0,    0,    0,
+
+        0,    0,    0,    0,    0,  294,    0,    0,    0,    0,
+        0,    0,    0,  289,    0,    0,  309,  308,    0,    0,
+      317,    0,  318,  322,    0,    0,    0,    0,    0,    0,
+       27,    0,   28,    0,    0,    0,    0,   55,    0,    0,
+        0,   77,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,  159,  159,  159,  145,  144,    0,    0,
+        0,  219,  218,  239,  239,  239,  229,  228,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,  289,  289,    0,  301,
+        0,  313,  312,    0,    0,    0,  329,    0,    0,    0,
+
+        0,   21,   20,    0,    0,  244,    0,  243,    0,    0,
+        0,    0,    0,    0,    0,   77,    0,    0,    0,    0,
+       86,    0,    0,    0,    0,   85,    0,  159,  159,  159,
+        0,  147,  146,  239,  239,  239,    0,  231,  230,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,  289,  289,    0,  311,
+      310,    0,    0,    0,    0,   23,   22,  244,    0,  243,
+        0,    0,   49,   48,    0,    0,    0,    0,   77,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+      159,  159,  159,  239,    0,    0,  239,    0,    0,    0,
+
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,    0,  289,  289,    0,    0,    0,    0,
+       82,   81,    0,    0,    0,    0,    0,    0,    0,    0,
+       92,    0,    0,    0,   91,    0,    0,    0,  139,  138,
+      159,  159,  159,  159,  239,    0,  225,  224,  239,    0,
+        0,    0,    0,    0,    0,  258,    0,  257,    0,    0,
+      263,    0,    0,    0,    0,    0,    0,    0,    0,  289,
+        0,    0,  289,    0,    0,    0,    0,    0,    0,   82,
+       81,    0,    0,    0,    0,    0,   69,   68,    0,    0,
+        0,    0,    0,    0,    0,  159,  159,  159,  159,    0,
+
+        0,    0,    0,    0,    0,    0,    0,    0,    0,  256,
+      255,    0,    0,    0,    0,    0,    0,    0,  275,  274,
+      289,    0,  273,  272,  289,    0,    0,    0,    0,    0,
+        0,    0,   73,    0,   72,   90,    0,    0,   89,    0,
+        0,    0,  101,  159,  159,  159,  159,    0,  221,  220,
+        0,    0,    0,    0,    0,  252,    0,    0,  251,    0,
+        0,  283,    0,    0,  282,  289,  289,    0,    0,    0,
+       12,    0,   12,    0,    0,    0,   84,   88,   83,   87,
+      159,  159,  159,  159,    0,    0,    0,    0,  254,  250,
+      253,  249,  285,  281,  284,  280,  289,  289,    0,    0,
+
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,  159,    0,    0,    0,    0,    0,    0,  289,  289,
+        0,    0,   71,   70,    0,  141,  140,    0,  151,  150,
+        0,  149,  148,  159,    0,  155,  154,    0,    0,    0,
+        0,  289,  289,    0,   11,  159,    0,    0,    0,    0,
+      289,  289,    0,  159,    0,    0,    0,    0,  289,  289,
+        0,  159,    0,    0,    0,    0,  289,  289,    0,    0,
+        0,    0,  233,    0,  232,  289,  289,    0,    0,  153,
+      152,  235,  234,  289,  289,    0,  289,  289,    0,  289,
+      289,    0,    0,  289,  289,    0,    0,  289,  289,    0,
+
+        0,  289,  289,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,  279,  278,    0,  277,  276,    0,    0,    0,
+        0,    0,    0,    0,    0,    0,    0,    0,    0,    0,
+        0,    0,    0,   13,    0
+    } ;
+
+static yyconst flex_int32_t yy_ec[256] =
+    {   0,
+        1,    1,    1,    1,    1,    1,    1,    1,    2,    3,
+        1,    2,    4,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    2,    5,    6,    7,    1,    1,    8,    9,    1,
+        1,    1,    1,    1,   10,   11,   12,   13,   13,   13,
+       13,   14,   13,   13,   13,   15,   13,   16,   17,   18,
+       19,   20,   21,    1,   22,   23,   24,   25,   26,   27,
+       28,   29,   30,   28,   31,   32,   33,   34,   35,   36,
+       28,   37,   38,   39,   28,   40,   41,   28,   42,   28,
+       43,    1,   44,    1,   45,    1,   46,   47,   48,   49,
+
+       50,   51,   52,   53,   54,   28,   55,   56,   57,   58,
+       59,   60,   61,   62,   63,   64,   65,   66,   67,   68,
+       69,   28,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
+        1,    1,    1,    1,    1
+    } ;
+
+static yyconst flex_int32_t yy_meta[70] =
+    {   0,
+        1,    2,    2,    2,    1,    1,    1,    1,    1,    3,
+        3,    1,    4,    4,    4,    5,    6,    1,    7,    8,
+        1,    9,    9,    9,    9,    9,    9,    5,    5,    5,
+        5,    5,    5,    5,    5,    5,    5,    5,    5,    5,
+        5,    5,    1,    1,    5,    9,    9,    9,    9,    9,
+        9,    5,    5,    5,    5,    5,    5,    5,    5,    5,
+        5,    5,    5,    5,    5,    5,    5,    5,    5
+    } ;
+
+static yyconst flex_int16_t yy_base[2269] =
+    {   0,
+        0,    0,    0,    3,    6,    9,   12,   29,   16,   19,
+       14,   17,   33,   36,   49,   55,   45,   61,   66,   72,
+      105,  173,   75,   78,   83,  125,  128,  132,  135,  138,
+      193,  196,  200,  203,  206,  224,  242,  293,  262,  265,
+      344,  408,  271,  273,  472,  535,  269,  316,  320,  323,
+      364,  367,  371,  374,  598,  662,  428,  431,  726,  789,
+      435,  438,  852,  915,  492,  495,  499,  502,  505,  555,
+      978, 1041,  558,  562,  565,  568,  618,  621,  625,  628,
+     1104, 1170,  631,  682, 1236,    0,  685,  689, 1305, 1359,
+      692,  695, 1413, 1476,  746,  749,  753,  756,  759,  809,
+
+      812,  816, 1539, 1602,  819,  822,  872,  875,  879,  882,
+      885,  935, 1665, 1728,  938,  942,  945,  948,  998, 1001,
+     1005, 1008, 1791, 1845, 1011, 1061, 1899, 1962, 1064, 1068,
+     1071, 1074, 1124, 1127, 1131, 1134, 2025, 2091, 1137, 1190,
+        0,    0, 5045, 7142, 7142,   95,  100,   29,   41, 7142,
+      155,   51, 7142, 7142, 5032, 7142, 7142, 5020, 7142, 5032,
+     5031, 1149, 7142, 7142, 7142, 7142, 5023, 5022, 4972,  210,
+     7142,  158, 4991,    0,  142, 7142, 4957, 4941, 7142,  162,
+     2153, 2213,  160, 4978,  176, 7142,  165, 4969,    0,  149,
+     7142, 4926, 7142,  230,  378, 7142,  326, 4945,    0,  208,
+
+     7142, 4910, 4913, 4910, 4887,  379, 4895, 7142,  329, 4918,
+        0,  214, 7142, 4866, 4866,  238, 4840, 7142,  377,   11,
+       31, 4888, 7142,  399, 4878,    0,  439, 7142, 4839, 4836,
+     4815, 7142,  403,  442, 7142,  462, 4856,    0,  440, 7142,
+     4825, 4807, 4821, 4801, 7142,  467,  506, 7142,  528, 4844,
+        0,  507, 7142, 4800,  521, 4796, 7142,  591, 4821, 7142,
+      648, 4812,    0,  570, 7142, 4764,   34, 4779, 4764, 4758,
+     7142,  652,  177, 4808, 7142,  655, 4786,    0,  576, 7142,
+     4745, 4744, 7142,  712,  697, 7142,  717, 4766,    0,  639,
+     7142,  211, 4735, 4737,   93, 4735, 4708, 7142,  720,  760,
+
+     7142,  780, 4749,    0,  640, 7142, 4715, 7142,  842,  826,
+     7142,  902, 4743,    0,  886, 7142, 4715, 4708, 4709,   80,
+     7142,  906,  522, 4742, 7142,  909, 4731,    0,  893, 7142,
+     4698, 4681,   26,  304, 7142,  965,  330, 4731, 7142,  968,
+     4721,    0,  952, 7142, 4685, 4663, 4667, 4658, 7142,  972,
+      507, 4703, 7142, 1157, 4693,    0,  956, 7142, 4659, 7142,
+     1160, 1013, 7142, 1163, 4685,    0, 1012, 7142, 4629, 4634,
+     4634, 4623, 7142, 1194, 1108, 4669, 4664, 7142, 1200, 4655,
+        0, 1015, 7142, 4619, 7142, 1213, 1076, 1216,  433, 4596,
+     7142, 4652, 4633, 7142, 7142, 7142, 1314,  283, 4588, 4579,
+
+     4577, 4620, 4580, 7142,    0, 4571, 4574, 4569, 4565, 4570,
+     4565, 4564, 4562, 4548,    4,  166, 4551, 4537, 4538, 4528,
+     4527, 4514,  720, 4517, 4503,   38,  782, 4499,  783, 4494,
+     7142,    0, 4498, 4492, 7142,    0, 4485, 1328, 4478, 4481,
+      329, 4470, 4496, 7142,    0, 4457, 1331, 4445, 4462, 4444,
+     4452, 4437,   89, 7142,    0, 4437, 4428, 4438, 4405, 7142,
+        0, 1334, 4417, 4416, 4412, 4399, 7142,    0, 4388, 4400,
+     7142,    0, 4403, 1337, 4376, 4371, 4370, 4386, 4378, 7142,
+        0, 1381, 4369, 4358, 7142,    0, 4368, 1385, 1388, 4337,
+     4332, 4344, 4344, 4340, 4335, 7142,    0, 1391, 4318, 7142,
+
+        0, 4316, 1433, 4309, 4325, 4317, 4305, 7142,    0, 4291,
+     4289, 4294, 4277, 4275, 4260, 7142,    0, 4257, 4246, 4246,
+     4256, 4241, 7142,    0, 1436, 4245, 7142,    0, 4234, 4228,
+     4232, 4240, 4222, 4212, 7142,    0, 4213, 4222, 4242, 4251,
+      815, 4202, 7142, 1208,    0, 4188, 4187, 4227, 4219, 4176,
+     7142, 4171, 4153, 4156, 1439, 1442, 4157, 4143, 4141, 4139,
+     4152, 4140, 4151, 4136, 4136, 4127, 4120, 4137, 4113, 4115,
+     4097, 4101, 4096, 4088, 4083, 4100, 4082, 4075, 4081, 4051,
+     4063, 4046, 1445, 1497, 4044, 1502, 1224, 4034, 4036, 4051,
+     1505, 1508, 7142, 4024, 1512, 1559, 1570, 4011, 1573, 4023,
+
+     1576, 1635, 4007, 4004, 4007, 4007, 1622, 1627, 1630, 1591,
+     4002, 3994, 3996, 1690, 1700, 3997, 1693, 1696, 3986, 1703,
+     1650, 3989, 3992, 3979, 3960, 1749, 1755, 1759, 1764, 3957,
+     1813, 1816,  401, 1819, 1777, 1822, 1865, 1825, 3971, 3968,
+     3956, 3932, 1873, 1877, 1919, 1881, 1924, 1927, 3933, 1932,
+     1985, 3923, 3906, 3902, 1937, 1994, 3911, 1997, 2000, 3906,
+     3904, 2047, 2054, 3900, 2005, 3907, 2051, 2057, 2060, 2069,
+     2080, 2112, 2118, 3897, 3878, 3880, 3864, 2121, 2124, 3868,
+     3850, 2127, 2146, 3894, 7142, 7142,  373, 3841, 7142, 3879,
+     3877, 3820, 7142, 7142, 3818, 3816, 3821, 3810, 2149, 2157,
+
+     7142, 2176, 3807, 3807, 3818, 3803, 3794, 3793, 3779,  261,
+     3793, 3776, 1340, 3783, 3766, 3775, 3759, 3767, 3771, 3748,
+     1394, 3762,  376, 3745, 3751, 3738, 3753, 2152, 2180, 2185,
+     7142, 2190, 2217, 2224, 7142, 7142, 2237, 2241, 3774, 2245,
+     2248, 7142, 2251, 3732, 2276, 7142, 7142, 2284, 2289, 2297,
+     2303, 2306, 3743, 2315, 2321, 7142, 2324,  407, 3741, 2327,
+     3739, 2330, 2334, 7142, 2345, 2349, 7142, 7142, 3730, 3735,
+     3727, 2357, 2360, 7142, 2364, 3722, 2367, 2370, 7142, 2390,
+     3719, 2393, 7142, 7142, 3711, 3706, 3702, 3711, 2401, 2404,
+     7142, 2409, 2413, 7142, 7142, 3710, 2423, 2428, 7142, 2431,
+
+     3686, 3697, 2435, 7142, 7142, 2451, 7142, 7142, 2443, 2461,
+     3667, 3633, 3637, 3630, 2471, 2474, 7142, 2477, 2480, 7142,
+     7142, 2496, 2499, 7142, 2502, 3611, 2505, 7142, 7142, 3614,
+     3617, 3619, 2521, 2524, 7142, 2527, 3598, 2530, 2534, 2549,
+     2552, 3605, 3598, 2560, 2567, 7142, 2570, 3593, 2573, 2580,
+     3602, 2591, 2594, 2602, 2605, 7142, 2609, 2612, 7142, 7142,
+     2624, 2628, 7142, 2634, 3573, 2637, 3591, 3556, 2643, 2647,
+     7142, 2655, 3554, 3559, 2658, 2662, 7142, 2666,  734, 2669,
+     7142, 7142, 3590, 3585, 3550, 3540, 3572, 2677, 3529, 3521,
+     3537, 1468, 3516, 2160, 3529, 3528, 1471, 3505, 3513, 1531,
+
+     3511, 3496, 3512, 1534, 2691, 3498, 3505, 1658, 3493, 3492,
+     3490, 3467, 3481, 3479, 2681, 2699, 2707, 2713, 2717, 3475,
+     3459, 3499, 2726, 3474, 2731, 7142, 7142, 2740, 2745, 2758,
+     7142, 7142, 3468, 2753, 1721, 3455, 2766, 2773, 2784, 2787,
+     3444, 3460, 3437, 2790, 3450, 2793, 3448, 3442, 3426, 2796,
+     2802, 2814, 2820, 2824, 2827, 2834, 2846, 7142, 7142, 2838,
+     2856, 2860, 2863, 2866, 2869, 3428, 3432, 3418, 2889, 2892,
+     3416, 2898, 7142, 7142, 2907, 7142, 7142, 3409, 2916, 2919,
+     3405, 2934, 7142, 7142, 3398, 2942, 7142, 7142, 2950, 2953,
+     3406, 2923, 2956, 3388, 3406, 2964, 3392, 2972, 2975,  181,
+
+     3428, 2978, 7142, 3426, 7142, 7142, 3386, 3381,  528, 2983,
+     3381, 3379, 3380, 1785, 3374, 1828, 3371, 3359, 3348, 1892,
+     3352, 2986, 2990, 3352, 3353, 1956, 2008, 3342, 2997, 3007,
+     3334, 3013, 3345, 3016, 3022, 3033, 7142, 7142, 3043, 3047,
+     7142, 7142, 3332, 3335, 3315, 3062, 3289, 3065, 7142, 7142,
+     3284, 3077, 2018, 3284, 3081, 1067, 1121, 3058, 3089, 3097,
+     3100, 3103, 3107, 3111, 7142, 3121, 3125, 3283, 3279, 3260,
+     3130, 3135, 3148, 3151, 3271, 3159, 3162, 3166, 3174, 3180,
+     3183, 3193, 3198, 3201, 3211, 3216, 3219, 3222, 3225, 3271,
+     3250, 3265, 3229, 3237, 3263, 3247, 3250, 3254, 3252, 3257,
+
+     3260, 3278, 3281, 3286, 3240, 3289, 7142, 7142, 3242, 3230,
+     3301, 3237, 3306, 3309, 3324, 1430,  430,  501, 7142, 3216,
+     3330, 3333, 3336, 3339, 3218, 3212, 3218, 3220, 3204, 3204,
+     3202, 3343, 3354, 3198, 3358, 3361, 3199, 3182, 3184, 3364,
+     3367, 3370, 3173, 3373, 3177, 3166, 3163, 3376, 3161, 3148,
+     3184, 3380, 3139, 3139, 3386, 3389, 3169, 3155,  260, 3153,
+     3158, 3139,  492, 3138, 3401, 7142, 7142, 3410, 3413, 3418,
+     3431, 3434, 3438, 3452, 3455, 3463, 3104, 3094, 3096, 3466,
+     7142, 7142, 3475, 3111, 3108, 3088, 3483, 7142, 3486, 7142,
+     7142, 3494, 7142, 3498, 7142, 7142, 3506, 3513, 3524, 7142,
+
+     7142, 3532, 3535, 3543, 3546, 3550, 3564, 3567, 3071, 3570,
+     3085, 3573, 3086, 3085, 3064, 3588, 7142, 3591, 3594, 3602,
+     3052, 3614, 3609, 3629, 3620, 3623, 3638, 3038, 3037, 3035,
+     3642, 3030, 3645, 7142, 7142, 3657, 1011, 1186,  576, 3029,
+     3661, 3664, 3672, 3679, 3686, 3012, 3690, 3693, 3697, 3015,
+     3015, 3700, 3706, 3005, 3709, 2999, 3712, 3715, 3718, 3721,
+     3724, 2992, 3729, 2996, 3732, 3000, 3735, 3009, 3738, 7142,
+     2981, 2995, 3743, 3747, 3753, 2999, 2993, 2991, 2993, 2981,
+     2987, 2969, 2966, 2970, 2956, 3765, 3768, 7142, 7142, 3776,
+     3784, 3794, 7142, 7142, 3802, 7142, 7142, 3812, 2940, 2922,
+
+     2912,  613,  674, 2913, 3815, 7142, 7142, 3824, 7142, 7142,
+     3832, 3835, 3843, 7142, 7142, 3851, 3854, 2911, 3857, 3860,
+     2912, 2901,  677,  741, 2894, 3875,  866,  919, 3883, 2891,
+     3886, 3889,  929,  992, 3897, 3901, 7142, 3905, 3908, 2891,
+     2878, 3915, 2866, 3926, 3920,  758,  722, 3930, 3935, 7142,
+     7142, 3945, 3948, 3954, 3957, 3968, 3973, 3977, 3983, 3986,
+     3989, 2872, 2859, 3992, 3995, 3999, 2859, 4002, 2856, 4005,
+     2841, 4011, 4014, 7142, 4024, 2839, 4029, 7142, 4032, 7142,
+     7142, 2874, 2858, 2864, 2857, 2861, 2858, 2842, 2851, 2843,
+     2835, 4042, 4048, 7142, 7142, 4056, 2779, 2726, 2724, 2731,
+
+     2747, 2718, 2695, 2646, 4061, 7142, 7142, 4069, 4075, 7142,
+     4078, 4081, 7142, 7142, 2570,   62,  308,  388,  369,  491,
+      475,  545,  857,  548, 1056, 4089, 4096, 4100,  574, 1065,
+      586, 1172, 4103, 4108, 4111, 4115, 4123,  587, 4129, 4132,
+     4135, 4141,  756,  986, 4148, 4154, 4160, 4165, 4168, 4172,
+     4178,  614,  632,  661,  729, 4184, 7142,  767, 4187, 7142,
+     7142, 4203, 4209,  785,  807,  823,  846,  854,  894,  902,
+      917,  960,  985, 1002, 4217, 4221, 7142,  993, 1021, 1022,
+     1077, 7142, 1085, 7142, 4224, 4227, 7142, 4230, 4236, 1081,
+     1087, 1090, 1145, 7142, 1160, 7142, 4248, 1160, 1161, 1174,
+
+     1185, 1174, 1203, 4251, 4254, 4262, 4269, 1205, 1194, 1209,
+     1295, 1307, 1320, 4274, 4277, 4281, 7142, 7142, 4292, 4296,
+     4305, 4310, 7142, 4313, 4316, 1355, 1332, 1392, 4324, 4329,
+     4337, 4342, 7142, 1297, 1304, 1301, 1307, 4345, 4348, 1544,
+     1561, 1299, 1351, 1377, 1377, 1383, 1400, 1378, 1387, 1405,
+     1431, 1445, 4356, 1389, 1411, 1411, 7142, 7142, 4363, 4366,
+     4375, 7142, 7142, 1410, 1418, 1438, 7142, 7142, 4383, 4386,
+     1465, 1464, 1477, 1481, 1483, 1488, 4394, 1557, 1593, 4402,
+     1489, 1488, 1493, 1527, 1527, 1531, 4405, 4408, 4413, 7142,
+     4417, 7142, 7142, 4426, 4432, 4440, 7142, 1598, 1570, 1630,
+
+     4444, 7142, 7142, 4452, 4455, 4470, 1523, 4473, 1536, 4476,
+     4479, 1550, 1579, 1599, 1618, 1583, 1618, 1617, 1616, 1623,
+     7142, 1639, 1647, 1648, 1651, 7142, 4487, 4490, 1656, 1667,
+     4494, 7142, 7142, 1659, 4502, 1669, 4508, 7142, 7142, 1681,
+     1685, 1700, 1690, 1708, 1728, 1721, 1734, 1729, 1739, 4516,
+     1739, 1748, 1759, 1753, 1771, 1787, 4520, 4523, 4541, 7142,
+     7142, 1822, 1820, 4529, 4549, 7142, 7142, 4526, 1773, 4557,
+     1775, 4560, 7142, 7142, 1821, 1827, 1848, 1839, 4570, 1843,
+     1869, 1886, 1876, 1876, 1902, 1916, 1910, 4573, 4576, 4579,
+     1886, 1883, 1886, 1899, 4588, 4594, 1884, 1925, 1930, 1927,
+
+     1948, 1958, 1951, 1984, 1954, 1984, 1957, 4602, 1988, 1997,
+     2007, 2017, 2026, 2031, 4606, 4609, 2056, 4612, 4615, 4635,
+     4643, 4646, 2032, 2050, 2044, 2054, 4654, 4657, 2052, 2055,
+     7142, 2057, 2061, 2087, 7142, 2088, 4665, 4668, 7142, 7142,
+     2079, 2086, 2087, 2093, 4676, 4680, 7142, 7142, 4688, 2115,
+     2108, 2118, 2120, 2112, 2142, 7142, 2162, 7142, 2161, 4694,
+     7142, 2148, 2141, 2156, 2160, 2156, 2166, 4697, 4700, 4708,
+     4715, 4719, 4728, 2178, 4733, 4736, 4756, 4795, 4839, 4746,
+     4764, 2170, 2191, 2177, 2194, 4768, 7142, 7142, 2205, 2180,
+     2182, 2214, 2192, 2197, 4785, 2175, 2184, 2177, 2178, 4789,
+
+     4776, 4807, 4815, 2220, 2232, 2252, 2236, 2238, 2261, 7142,
+     7142, 2246, 2249, 2275, 2257, 2259, 2280, 4825, 7142, 7142,
+     4833, 4859, 7142, 7142, 4851, 2294, 4869, 2337, 2293, 4905,
+     4949, 2276, 7142, 2280, 7142, 7142, 2305, 2314, 7142, 2312,
+     2330, 4877, 7142, 2290, 2276, 2296, 2325, 4882, 7142, 7142,
+     4890, 2351, 2371, 2370, 2373, 7142, 2372, 2374, 7142, 2379,
+     2380, 7142, 2379, 2391, 7142, 4899, 4917, 2430, 2436, 2438,
+     2395, 2476, 2405, 4925, 2403, 2405, 7142, 7142, 7142, 7142,
+     4928, 4940, 4969, 4972, 2401, 2407, 2418, 2420, 7142, 7142,
+     7142, 7142, 7142, 7142, 7142, 7142, 4975, 4980, 4983, 2455,
+
+     2445, 2459, 4993, 2463, 2462, 4998, 4931, 5002, 5006, 5016,
+     5020, 2426, 5028, 5035, 2453, 2471, 2456, 2488, 5046, 5049,
+     5052, 2492, 7142, 7142, 5055, 7142, 7142, 5067, 7142, 7142,
+     5075, 7142, 7142, 2463, 5083, 7142, 7142, 2479, 2480, 2482,
+     2483, 5093, 5096, 2515, 7142, 2473, 2509, 2519, 2516, 2522,
+     5099, 5102, 2540, 2484, 2523, 2540, 2530, 2554, 5105, 5123,
+     2581, 5126, 2555, 2582, 2565, 2590, 5129, 5132, 2597, 5135,
+     5158, 2596, 7142, 2610, 7142, 5166, 5169, 2622, 5187, 7142,
+     7142, 7142, 7142, 5195, 5198, 5201, 5204, 5207, 5216, 5230,
+     5235, 2613, 2614, 5242, 5249, 2633, 2668, 5253, 5256, 2679,
+
+     2693, 5260, 5274, 2686, 2719, 5279, 5285, 5301, 5304, 2704,
+     2752, 5312, 7142, 7142, 5321, 7142, 7142, 2671, 2711, 2732,
+     2760, 2632, 2800, 2763, 2805, 2781, 2812, 2831, 2836, 2692,
+     2799, 5329, 5332, 7142, 7142, 5352, 5361, 5370, 5379, 5388,
+     5397, 5406, 5415, 5424, 5433, 5442, 5451, 5460, 5469, 5478,
+     5487, 5496, 5505, 5514, 5523, 5532, 5541, 5550, 5559, 5568,
+     5577, 5586, 5595, 5604, 5613, 5622, 5631, 5640, 5649, 5658,
+     5667, 5676, 5685, 5694, 5701, 5708, 5715, 5722, 5729, 5736,
+     5743, 5750, 5757, 5764, 5771, 5778, 5785, 5792, 5799, 5806,
+     5813, 5822, 5827, 5832, 5837, 5842, 5847, 5852, 5857, 5862,
+
+     5867, 5874, 5879, 5886, 5891, 5898, 5903, 5910, 5915, 5922,
+     5927, 5934, 5939, 5946, 5951, 5958, 5963, 5972, 5978, 5985,
+     5993, 6000, 6008, 6015, 6023, 6030, 6038, 6045, 6053, 6060,
+     6068, 6075, 6083, 6090, 6098, 6105, 6113, 6120, 6128, 6136,
+     6143, 6151, 6158, 6166, 6173, 6181, 6189, 6196, 6204, 6211,
+     6219, 6228, 6234, 6241, 6249, 6257, 6265, 6273, 6281, 6288,
+     6296, 6303, 6311, 6318, 6326, 6333, 6341, 6348, 6356, 6363,
+     6371, 6378, 6386, 6394, 6401, 6409, 6416, 6424, 6431, 6439,
+     6447, 6454, 6462, 6469, 6477, 6486, 6495, 6502, 6510, 6518,
+     6525, 6533, 6540, 6548, 6555, 6563, 6570, 6578, 6585, 6593,
+
+     6600, 6608, 6616, 6624, 6632, 6640, 6648, 6655, 6663, 6670,
+     6678, 6685, 6693, 6701, 6708, 6716, 6724, 6732, 6741, 6750,
+     6757, 6765, 6773, 6780, 6788, 6795, 6803, 6810, 6818, 6826,
+     6834, 6842, 6849, 6857, 6865, 6873, 6881, 6889, 6896, 6904,
+     6912, 6920, 6928, 6936, 6944, 6951, 6959, 6967, 6976, 6985,
+     6993, 7001, 7009, 7016, 7024, 7031, 7039, 7047, 7055, 7063,
+     7071, 7078, 7087, 7096, 7105, 7114, 7123, 7132
+    } ;
+
+static yyconst flex_int16_t yy_def[2269] =
+    {   0,
+     2036, 2036, 2037, 2037, 2037, 2037, 2038, 2038, 2039, 2039,
+     2040, 2040, 2041, 2041, 2041, 2041, 2042, 2042, 2036, 2036,
+     2043, 2043, 2044, 2044, 2044, 2044, 2036, 2036, 2044, 2044,
+     2036, 2036, 2044, 2044, 2044, 2044, 2045, 2045, 2046, 2046,
+     2047, 2047, 2041, 2041, 2048, 2048, 2049, 2049, 2036, 2036,
+     2049, 2049, 2049, 2049, 2050, 2050, 2051, 2051, 2052, 2052,
+     2053, 2053, 2054, 2054, 2036, 2036, 2036, 2036, 2055, 2055,
+     2056, 2056, 2057, 2057, 2036, 2036, 2057, 2057, 2057, 2057,
+     2058, 2058, 2059, 2059, 2035,   85, 2060, 2060, 2061, 2061,
+     2062, 2062, 2063, 2063, 2064, 2064, 2036, 2036, 2064, 2064,
+
+     2064, 2064, 2065, 2065, 2036, 2036, 2036, 2036, 2066, 2066,
+     2066, 2066, 2067, 2067, 2068, 2068, 2036, 2036, 2068, 2068,
+     2068, 2068, 2069, 2069, 2070, 2070, 2071, 2071, 2072, 2072,
+     2036, 2036, 2072, 2072, 2072, 2072, 2073, 2073, 2074, 2074,
+     2036, 2036, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2075, 2035, 2035, 2075, 2075, 2035, 2035,
+     2035, 2035,  181,  182,  182, 2035, 2035, 2035, 2076, 2035,
+     2035, 2076, 2035, 2035, 2035, 2035, 2035, 2035, 2077, 2035,
+
+     2035, 2077, 2077, 2077, 2077, 2035, 2035, 2035, 2035, 2035,
+     2078, 2035, 2035, 2078, 2078, 2078, 2078, 2035, 2035,  185,
+      185,  185, 2035, 2035, 2035, 2079, 2035, 2035, 2079, 2079,
+     2079, 2035, 2035, 2035, 2035, 2035, 2035, 2080, 2035, 2035,
+     2080, 2080, 2080, 2080, 2035, 2035, 2035, 2035, 2035, 2035,
+     2081, 2035, 2035, 2081,  185,  255, 2035, 2035,  185, 2035,
+     2035, 2035, 2082, 2035, 2035, 2082, 2082, 2082, 2082, 2082,
+     2035, 2035,  185,  185, 2035, 2035, 2035, 2083, 2035, 2035,
+     2083, 2083, 2035, 2035, 2035, 2035, 2035, 2035, 2084, 2035,
+     2035, 2084, 2084, 2084, 2084, 2084, 2084, 2035, 2035, 2035,
+
+     2035, 2035, 2035, 2085, 2035, 2035, 2085, 2035, 2035, 2035,
+     2035, 2035, 2035, 2086, 2035, 2035, 2086, 2086, 2086, 2086,
+     2035, 2035,  185,  185, 2035, 2035, 2035, 2087, 2035, 2035,
+     2087, 2087, 2087,  185, 2035, 2035,  185,  185, 2035, 2035,
+     2035, 2088, 2035, 2035, 2088, 2088, 2088, 2088, 2035, 2035,
+      185,  185, 2035, 2035, 2035, 2089, 2035, 2035, 2089, 2035,
+     2035, 2035, 2035, 2035, 2035, 2090, 2035, 2035, 2090, 2090,
+     2090, 2090, 2035, 2035,  185,  375,  185, 2035, 2035, 2035,
+     2091, 2035, 2035, 2091, 2035, 2035, 2035, 2035, 2092, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+
+     2035, 2035, 2035, 2035, 2075, 2075, 2075, 2093, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2076, 2076, 2094, 2035, 2077, 2077, 2077, 2077, 2077,
+     2035, 2095, 2035, 2035, 2078, 2078, 2078, 2078, 2078, 2078,
+     2078, 2096, 2035, 2035, 2079, 2079, 2079, 2079, 2097, 2035,
+     2080, 2080, 2080, 2080, 2080, 2098, 2035, 2081, 2081, 2099,
+     2035, 2082, 2082, 2082, 2082, 2082, 2082, 2082, 2100, 2035,
+     2083, 2083, 2083, 2101, 2035, 2102, 2102, 2102, 2102, 2102,
+     2102, 2102, 2102, 2102, 2103, 2035, 2104, 2104, 2105, 2035,
+
+     2106, 2106, 2106, 2106, 2106, 2106, 2107, 2035, 2108, 2108,
+     2108, 2108, 2108, 2035, 2109, 2035, 2110, 2110, 2110, 2110,
+     2110, 2111, 2035, 2112, 2112, 2113, 2035, 2114, 2114, 2114,
+     2114, 2114, 2115, 2035, 2035, 2116, 2116, 2117, 2118, 2035,
+     2118, 2035, 2035, 2035, 2119, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2120, 2120, 2121, 2121, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2122, 2123, 2123, 2124, 2035, 2035, 2124, 2124, 2035,
+     2125, 2125, 2035, 2126, 2035, 2035, 2126, 2126, 2126, 2126,
+
+     2127, 2127, 2035, 2128, 2128, 2128, 2129, 2129, 2035, 2035,
+     2130, 2130, 2130, 2131, 2131, 2132, 2133, 2133, 2134, 2035,
+     2035, 2134, 2134, 2134, 2134, 2135, 2135, 2035, 2035, 2136,
+     2137, 2137, 2138, 2035, 2035, 2035, 2035, 2138, 2138, 2138,
+     2138, 2138, 2139, 2139, 2035, 2035, 2140, 2140, 2141, 2035,
+     2035, 2141, 2141, 2141, 2142, 2142, 2143, 2143, 2143, 2143,
+     2035, 2144, 2144, 2145, 2145, 2145, 2145, 2146, 2146, 2035,
+     2035, 2147, 2147, 2148, 2148, 2148, 2148, 2149, 2149, 2035,
+     2150, 2151, 2151, 2152, 2035, 2035, 2152, 2035, 2035, 2153,
+     2035, 2035, 2035, 2035, 2035, 2035, 2154, 2154, 2035, 2155,
+
+     2035, 2155, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2156, 2035, 2157,
+     2035, 2157, 2158, 2035, 2035, 2035, 2158, 2158, 2035, 2035,
+     2159, 2035, 2159, 2160, 2035, 2035, 2035, 2035, 2035, 2160,
+     2035, 2035, 2160, 2035, 2161, 2035, 2161, 2035, 2162, 2162,
+     2162, 2035, 2163, 2035, 2163, 2035, 2035, 2035, 2164, 2164,
+     2164, 2035, 2165, 2035, 2165, 2166, 2035, 2167, 2035, 2167,
+     2168, 2035, 2035, 2035, 2168, 2168, 2168, 2168, 2035, 2169,
+     2035, 2169, 2035, 2035, 2035, 2170, 2035, 2171, 2035, 2171,
+
+     2172, 2172, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2172, 2172, 2172, 2172, 2035, 2173, 2035, 2173, 2035, 2035,
+     2035, 2035, 2174, 2035, 2174, 2175, 2035, 2035, 2035, 2175,
+     2175, 2175, 2035, 2176, 2035, 2176, 2177, 2035, 2035, 2035,
+     2035, 2177, 2035, 2035, 2178, 2035, 2178, 2179, 2035, 2035,
+     2179, 2035, 2035, 2035, 2180, 2035, 2180, 2035, 2035, 2035,
+     2035, 2181, 2035, 2181, 2182, 2182, 2182, 2182, 2035, 2183,
+     2035, 2183, 2035, 2184, 2035, 2185, 2035, 2185, 2186, 2187,
+     2035, 2035, 2035, 2035, 2035, 2188, 2188, 2189, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2190, 2035, 2035, 2191,
+     2191, 2035, 2192, 2193, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2193, 2194, 2035, 2195, 2035, 2035, 2195, 2196,
+     2197, 2197, 2197, 2198, 2199, 2200, 2201, 2201, 2201, 2201,
+     2201, 2202, 2203, 2204, 2205, 2205, 2035, 2035, 2035, 2205,
+     2205, 2205, 2205, 2206, 2207, 2208, 2208, 2208, 2208, 2209,
+     2210, 2035, 2035, 2035, 2035, 2035, 2035, 2210, 2035, 2211,
+     2212, 2035, 2035, 2035, 2212, 2035, 2035, 2035, 2213, 2214,
+     2215, 2035, 2035, 2215, 2215, 2216, 2035, 2217, 2218, 2219,
+
+     2220, 2220, 2035, 2220, 2035, 2035, 2035, 2221, 2221, 2222,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2223, 2035,
+     2035, 2035, 2224, 2224, 2035, 2225, 2226, 2035, 2035, 2035,
+     2226, 2227, 2035, 2228, 2035, 2035, 2035, 2035, 2035, 2229,
+     2230, 2230, 2230, 2035, 2035, 2231, 2232, 2233, 2233, 2233,
+     2035, 2035, 2035, 2035, 2233, 2234, 2035, 2035, 2235, 2035,
+     2035, 2236, 2035, 2035, 2236, 2236, 2236, 2237, 2238, 2239,
+     2239, 2239, 2035, 2035, 2239, 2240, 2241, 2241, 2035, 2242,
+
+     2243, 2243, 2244, 2245, 2246, 2035, 2035, 2035, 2246, 2246,
+     2247, 2035, 2035, 2035, 2248, 2249, 2250, 2250, 2035, 2035,
+     2251, 2251, 2251, 2252, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2253, 2254, 2254,
+     2035, 2255, 2256, 2256, 2257, 2258, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2259, 2035, 2035,
+     2260, 2035, 2035, 2035, 2035, 2261, 2262, 2262, 2262, 2035,
+     2035, 2035, 2035, 2035, 2035, 2262, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+
+     2035, 2035, 2035, 2236, 2035, 2035, 2237, 2238, 2239, 2239,
+     2239, 2035, 2035, 2035, 2239, 2035, 2035, 2035, 2035, 2241,
+     2035, 2242, 2035, 2035, 2243, 2244, 2245, 2246, 2246, 2246,
+     2247, 2035, 2035, 2035, 2035, 2248, 2249, 2250, 2250, 2035,
+     2035, 2035, 2251, 2251, 2252, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2253, 2254, 2254, 2035, 2035, 2035,
+     2256, 2256, 2257, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2259, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2261, 2262, 2262,
+
+     2262, 2035, 2035, 2262, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2237, 2238, 2239, 2035, 2035,
+     2239, 2239, 2035, 2035, 2239, 2035, 2035, 2035, 2241, 2035,
+     2242, 2035, 2035, 2035, 2243, 2035, 2035, 2245, 2246, 2246,
+     2246, 2247, 2035, 2248, 2249, 2250, 2250, 2035, 2035, 2035,
+     2035, 2251, 2251, 2252, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2253,
+     2254, 2035, 2035, 2035, 2256, 2256, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2259, 2035, 2035, 2035, 2261, 2262, 2262, 2262, 2035,
+
+     2035, 2035, 2035, 2262, 2035, 2035, 2035, 2237, 2035, 2035,
+     2239, 2035, 2035, 2035, 2239, 2239, 2035, 2035, 2035, 2035,
+     2239, 2035, 2035, 2035, 2035, 2241, 2035, 2242, 2035, 2035,
+     2035, 2035, 2243, 2245, 2035, 2035, 2246, 2246, 2247, 2035,
+     2248, 2249, 2250, 2250, 2035, 2251, 2251, 2252, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2254, 2035, 2035,
+     2035, 2035, 2035, 2256, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2259, 2035, 2035, 2262, 2262, 2262,
+     2035, 2035, 2035, 2035, 2262, 2035, 2035, 2035, 2035, 2239,
+     2239, 2239, 2035, 2035, 2035, 2035, 2239, 2035, 2035, 2035,
+
+     2035, 2035, 2035, 2035, 2035, 2035, 2242, 2035, 2035, 2035,
+     2035, 2035, 2035, 2243, 2245, 2035, 2035, 2035, 2035, 2035,
+     2246, 2035, 2035, 2035, 2248, 2249, 2250, 2250, 2035, 2035,
+     2251, 2035, 2035, 2035, 2035, 2035, 2035, 2254, 2035, 2035,
+     2035, 2256, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2259, 2262, 2262, 2262, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2239, 2239, 2239, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2242,
+     2035, 2035, 2035, 2035, 2035, 2035, 2243, 2243, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2249, 2250, 2250,
+
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2256, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2259, 2262, 2262, 2262,
+     2035, 2035, 2035, 2239, 2239, 2239, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2242,
+     2035, 2035, 2035, 2035, 2035, 2035, 2243, 2243, 2035, 2035,
+     2035, 2249, 2250, 2250, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2256, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2259, 2035, 2035,
+     2262, 2262, 2262, 2239, 2035, 2035, 2239, 2035, 2035, 2035,
+
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2242, 2035, 2035,
+     2035, 2035, 2035, 2035, 2243, 2243, 2249, 2250, 2250, 2250,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2259, 2035, 2035, 2035,
+     2262, 2262, 2262, 2262, 2239, 2035, 2035, 2035, 2239, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2243,
+     2035, 2035, 2243, 2249, 2250, 2250, 2250, 2263, 2264, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2259, 2262, 2262, 2262, 2262, 2035,
+
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2243, 2035, 2035, 2035, 2243, 2249, 2250, 2265, 2266, 2263,
+     2264, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2262, 2262, 2262, 2262, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2243, 2243, 2249, 2265, 2250,
+     2267, 2266, 2268, 2250, 2035, 2035, 2035, 2035, 2035, 2035,
+     2262, 2262, 2262, 2262, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2243, 2243, 2249, 2267,
+
+     2035, 2268, 2250, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2262, 2035, 2035, 2035, 2035, 2035, 2035, 2243, 2243,
+     2249, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2262, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2243, 2243, 2249, 2035, 2262, 2035, 2035, 2035, 2035,
+     2243, 2243, 2249, 2262, 2035, 2035, 2035, 2035, 2243, 2243,
+     2249, 2262, 2035, 2035, 2035, 2035, 2243, 2243, 2249, 2035,
+     2035, 2035, 2035, 2035, 2035, 2243, 2243, 2249, 2035, 2035,
+     2035, 2035, 2035, 2243, 2243, 2249, 2243, 2243, 2249, 2243,
+     2243, 2249, 2249, 2243, 2243, 2249, 2249, 2243, 2243, 2249,
+
+     2249, 2243, 2243, 2249, 2249, 2035, 2035, 2035, 2035, 2249,
+     2249, 2035, 2035, 2035, 2035, 2035, 2035, 2249, 2249, 2249,
+     2249, 2249, 2249, 2249, 2249, 2249, 2249, 2249, 2249, 2249,
+     2249, 2249, 2249, 2035,    0, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035,
+     2035, 2035, 2035, 2035, 2035, 2035, 2035, 2035
+    } ;
+
+static yyconst flex_int16_t yy_nxt[7212] =
+    {   0,
+     2035,  146,  147,  146,  146,  147,  146,  146,  147,  146,
+      146,  147,  146,  151,  147,  151,  157,  148,  154,  157,
+      148,  154,  452,  149, 2035,  155,  149, 2035,  155,  152,
+      151,  147,  151,  389,  158,  160,  161,  158,  160,  161,
+      162,  163, 2035,  162,  163,  389,  152,  167,  168,  390,
+      164,  160,  161,  164,  165,  392,  162,  160,  161,  563,
+      165,  391,  162,  167,  168,  564,  164,  147,  147,  147,
+      453,  391,  164,  147,  147,  147,  180,  147,  180,  180,
+      147,  180,  474,  170,  180,  147,  180,  512,  169,  170,
+      453,  475,  181,  563,  513,  181,  388,  388,  388,  577,
+
+      182,  388,  388,  388,  169,  171,  172,  147,  172,  171,
+      171,  171,  171,  171,  171,  171,  173,  171,  171,  171,
+     1492,  171,  175,  171,  176,  171,  180,  147,  180,  147,
+      147,  147,  505,  147,  147,  147,  180,  147,  180,  180,
+      147,  180,  182,  506,  563,  183,  392,  171,  171,  183,
+      603,  491,  181,  392,  492,  181,  388,  388,  388,  388,
+      388,  388,  391,  388,  388,  388,  388,  388,  388,  391,
+      177, 2035,  178,  171,  172,  147,  172,  171,  171,  171,
+      171,  171,  171,  171,  173,  171,  171,  171,  479,  171,
+      175,  171,  176,  171,  147,  147,  147,  147,  147,  147,
+
+      685,  180,  147,  180,  180,  147,  180,  180,  147,  180,
+      184,  565,  392,  184,  392,  171,  171,  182,  392,  426,
+      182,  427, 1116,  185,  566,  180,  147,  180,  391,  428,
+      391,  388,  388,  388,  391,  426,  453,  429,  177,  430,
+      178,  185,  186,  187,  147,  187,  186,  186,  186,  186,
+      186,  186,  186,  188,  186,  186,  186,  487,  186,  190,
+      186,  191,  186,  194,  147,  194,  194,  147,  194,  403,
+      219,  147,  219,  160,  161,  160,  161,  488,  162,  195,
+      162, 1278,  195,  448,  186,  186,  220,  449,  206, 1279,
+      206,  450,  192,  186,  187,  147,  187,  186,  186,  186,
+
+      186,  186,  186,  186,  188,  186,  186,  186,  896,  186,
+      190,  186,  191,  186,  207, 2035,  207,  219,  147,  219,
+      897,  147,  147,  147,  147,  147,  147,  388,  388,  388,
+      388,  388,  388,  220, 1493,  186,  186,  221,  540,  546,
+      221,  515,  547,  192,  196,  197,  147,  197,  196,  196,
+      196,  196,  196,  196,  196,  198,  196,  196,  196,  514,
+      196,  200,  196,  201,  196,  219,  147,  219,  219,  147,
+      219,  590,  219,  147,  219,  219,  147,  219,  388,  388,
+      388,  220,  392,  441,  220,  514,  196,  196,  222,  434,
+      442,  222,  685, 1494,  202, 1495,  879,  203,  391,  391,
+
+      388,  388,  388,  204,  388,  388,  388,  205,  196,  197,
+      147,  197,  196,  196,  196,  196,  196,  196,  196,  198,
+      196,  196,  196,  910,  196,  200,  196,  201,  196,  233,
+      147,  233,  233,  147,  233,  897,  246,  147,  246,  246,
+      147,  246,  540,  392,  392,  234,  392,  801,  234, 1003,
+      196,  196,  247,  459,  910,  247,  802,  541,  202,  391,
+      391,  203,  391,  388,  388,  388,  935,  204,  388,  388,
+      388,  205,  208,  209,  147,  209,  208,  208,  208,  208,
+      208,  208,  208,  210,  208,  208,  208, 1238,  208,  212,
+      208,  213,  208,  147,  147,  147,  147,  147,  147, 1496,
+
+      147,  147,  147,  147,  147,  147,  258,  147,  258,  255,
+      392,  392,  255, 1283,  208,  208,  256,  466,  522,  256,
+     1003, 1284,  259,  214, 1497,  215,  391,  391,  216,  388,
+      388,  388, 2035,  507,  217,  208,  209,  147,  209,  208,
+      208,  208,  208,  208,  208,  208,  210,  208,  208,  208,
+     1239,  208,  212,  208,  213,  208,  258,  147,  258,  272,
+      147,  272,  514,  272,  147,  272,  147,  147,  147,  147,
+      147,  147,  259,  412,  392,  273,  414,  208,  208,  273,
+      392,  453,  221, 1122, 1498,  221,  214, 1501,  215, 1123,
+      391,  216,  388,  388,  388, 1003,  391,  217,  223,  224,
+
+      147,  224,  223,  223,  223,  223,  223,  223,  223,  225,
+      223,  223,  223, 1508,  223,  227,  223,  228,  223,  272,
+      147,  272,  272,  147,  272, 1511,  272,  147,  272,  272,
+      147,  272,  284,  147,  284,  273, 1521, 1347,  273, 1400,
+      223,  223,  274,  392,  392,  274, 1401,  229,  285,  388,
+      388,  388,  230,  388,  388,  388,  388,  388,  388,  391,
+      391,  231,  223,  224,  147,  224,  223,  223,  223,  223,
+      223,  223,  223,  225,  223,  223,  223, 1534,  223,  227,
+      223,  228,  223,  284,  147,  284,  299,  147,  299, 1535,
+      299,  147,  299,  309,  147,  309,  309,  147,  309,  285,
+
+     1402,  392,  300, 1417,  223,  223,  300, 1403,  484,  310,
+     1418,  229,  310,  388,  388,  388,  230,  391,  388,  388,
+      388,  388,  388,  388, 1536,  231,  235,  236,  147,  236,
+      235,  235,  235,  235,  235,  235,  235,  237,  235,  235,
+      235, 1003,  235,  239,  235,  240,  235,  322,  147,  322,
+      322,  147,  322,  685,  147,  147,  147,  147,  147,  147,
+      322,  147,  322,  323,  392,  573,  323, 1419,  235,  235,
+      221,  495, 1000,  221, 1420, 1003,  323, 1003,  574,  241,
+      391,  388,  388,  388, 1444,  242, 1537,  243,  244,  235,
+      236,  147,  236,  235,  235,  235,  235,  235,  235,  235,
+
+      237,  235,  235,  235, 1527,  235,  239,  235,  240,  235,
+      322,  147,  322,  322,  147,  322, 1443,  322,  147,  322,
+      147,  147,  147,  147,  147,  147,  323,  565,  573,  324,
+      392,  235,  235,  324,  685, 1538,  334,  499, 1542,  334,
+      578,  580,  241,  388,  388,  388,  391, 1543,  242,  687,
+      243,  244,  248,  249,  147,  249,  248,  248,  248,  248,
+      248,  248,  248,  250,  248,  248,  248, 1544,  248,  252,
+      248,  253,  248,  147,  147,  147,  147,  147,  147, 1545,
+      336,  147,  336,  336,  147,  336,  336,  147,  336,  334,
+      392, 1499,  334, 1500,  248,  248,  337,  392, 1546,  337,
+
+     1422, 1423,  338,  388,  388,  388,  391,  388,  388,  388,
+      388,  388,  388,  391,  254,  248,  249,  147,  249,  248,
+      248,  248,  248,  248,  248,  248,  250,  248,  248,  248,
+     1547,  248,  252,  248,  253,  248,  336,  147,  336,  350,
+      147,  350, 1548,  350,  147,  350,  147,  147,  147,  147,
+      147,  147,  338, 1424, 1425,  351,  392,  248,  248,  351,
+      392, 1549,  334, 1429, 1430,  334,  388,  388,  388,  388,
+      388,  388,  391,  388,  388,  388,  391,  254,  260,  261,
+      147,  261,  260,  260,  260,  260,  260,  260,  260,  262,
+      260,  260,  260, 1550,  260,  264,  260,  265,  260,  350,
+
+      147,  350,  350,  147,  350, 1003,  350,  147,  350,  350,
+      147,  350,  361,  147,  361,  351,  392,  392,  351,  392,
+      260,  260,  352,  266,  526,  352, 1431, 1432,  362, 1551,
+      685,  267,  391,  391,  268,  391, 1345,  269, 1552, 1528,
+      270,  260,  261,  147,  261,  260,  260,  260,  260,  260,
+      260,  260,  262,  260,  260,  260, 1554,  260,  264,  260,
+      265,  260,  361,  147,  361,  374,  147,  374, 1555,  374,
+      147,  374,  147,  147,  147,  147,  147,  147,  362, 1556,
+      392,  375, 1557,  260,  260,  375,  266,  538,  376, 1157,
+     1502,  376, 1503, 1558,  267, 1158,  391,  268, 1159, 1509,
+
+      269, 1510, 1160,  270,  275,  276,  147,  276,  275,  275,
+      275,  275,  275,  275,  275,  277,  275,  275,  275,  533,
+      275,  279,  275,  280,  275,  374,  147,  374,  374,  147,
+      374, 1564,  374,  147,  374,  374,  147,  374,  386,  147,
+      386,  375, 1565, 1161,  375, 1566,  275,  275,  377, 1162,
+     1567,  377, 1163,  534,  387,  397, 1164,  281,  388,  388,
+      388,  388,  388,  388,  388,  388,  388,  453, 1568,  282,
+      275,  276,  147,  276,  275,  275,  275,  275,  275,  275,
+      275,  277,  275,  275,  275, 1571,  275,  279,  275,  280,
+      275,  386,  147,  386,  398,  388,  388,  388, 1572, 1573,
+
+      399,  388,  388,  388,  400, 1003, 1512,  387, 1513,  401,
+     1574, 1575,  275,  275,  388,  388,  388,  388,  388,  388,
+      544,  544,  544,  281,  689,  734,  734,  734, 1576,  735,
+     1581, 1582,  736, 1346, 1583,  282,  286,  287,  147,  287,
+      286,  286,  286,  286,  286,  286,  286,  288,  286,  286,
+      286,  289,  286,  290,  286,  291,  286,  289,  289,  289,
+      289,  289,  289,  289,  289,  289,  289,  289,  289,  289,
+      289,  289,  289,  289,  289,  289,  289,  289,  286,  286,
+      289,  289,  292,  289,  289,  289,  289,  289,  289,  293,
+      289,  294,  289,  289,  289,  295,  289,  296,  297,  289,
+
+      289,  289,  289,  289,  289,  301,  302,  147,  302,  301,
+      301,  301,  301,  301,  301,  301,  303,  301,  301,  301,
+     1584,  301,  305,  301,  306,  301,  544,  544,  544,  586,
+      586,  586,  595,  595,  595,  609,  609,  609,  620,  620,
+      620,  900,  900,  900, 1585, 1586,  587,  301,  301,  596,
+     1606, 1003,  610, 1607, 1608,  621, 1609, 1616,  307,  301,
+      302,  147,  302,  301,  301,  301,  301,  301,  301,  301,
+      303,  301,  301,  301,  685,  301,  305,  301,  306,  301,
+     1617,  545,  628,  628,  628, 1599,  634,  634,  634,  636,
+      636,  636,  645,  645,  645,  908,  908,  908, 1618,  629,
+
+     1619,  301,  301,  635, 1620, 1621,  637, 1622, 1623,  646,
+     1598, 1003,  307,  311,  312,  147,  312,  311,  311,  311,
+      311,  311,  311,  311,  313,  311,  311,  311, 1624,  311,
+      315,  311,  316,  311,  650,  650,  650,  670,  670,  670,
+      699,  699,  699,  699,  699,  699,  729,  729,  729,  685,
+     1600,  651, 1625, 1626,  671,  311,  311, 1628,  701,  317,
+     1629,  701, 1630, 1634,  731, 1237,  318, 1635,  319, 1014,
+     1014, 1014, 1020, 1020, 1020,  320,  311,  312,  147,  312,
+      311,  311,  311,  311,  311,  311,  311,  313,  311,  311,
+      311, 1636,  311,  315,  311,  316,  311,  702,  729,  729,
+
+      729, 1640, 1641,  586,  586,  586,  740,  740,  740,  740,
+      740,  740, 1642,  595,  595,  595,  731, 1643,  311,  311,
+      587, 1644,  317, 1645,  742, 1651, 1652,  742, 1653,  318,
+      596,  319,  900,  900,  900, 1026, 1026, 1026,  320,  325,
+      326,  147,  326,  325,  325,  325,  325,  325,  325,  325,
+      327,  325,  325,  325,  732,  325,  329,  325,  330,  325,
+      745,  745,  745, 1654,  746, 1655, 1656,  747, 1612,  743,
+     1669,  748,  748,  748,  751,  751,  751,  754,  754,  754,
+     1613,  325,  325, 1671,  331, 1614, 1675,  332,  749, 1003,
+     1646,  752,  766,  766,  766,  756,  767, 1615, 1647,  768,
+
+     1676,  333,  325,  326,  147,  326,  325,  325,  325,  325,
+      325,  325,  325,  327,  325,  325,  325,  685,  325,  329,
+      325,  330,  325,  762,  762,  762, 1648, 1663,  762,  762,
+      762,  609,  609,  609, 1649, 1677,  754,  754,  754, 1678,
+     1679,  764, 1680, 1662,  325,  325,  764,  331,  610, 1003,
+      332,  782,  782,  782,  756,  783, 1681, 1682,  784,  908,
+      908,  908, 1683, 1684,  333,  339,  340,  147,  340,  339,
+      339,  339,  339,  339,  339,  339,  341,  339,  339,  339,
+      757,  339,  343,  339,  344,  339, 1685, 1664,  765, 1686,
+     1687,  772,  772,  772,  777,  777,  777,  777,  777,  777,
+
+     1692,  772,  772,  772,  620,  620,  620,  339,  339,  774,
+      345, 1693,  779,  346, 1694,  779, 1697, 1698,  347,  774,
+     1699,  621, 1053, 1053, 1053, 1700, 1701,  348,  339,  340,
+      147,  340,  339,  339,  339,  339,  339,  339,  339,  341,
+      339,  339,  339, 1702,  339,  343,  339,  344,  339,  775,
+      789,  789,  789, 1703,  780, 1704,  789,  789,  789, 1705,
+      628,  628,  628, 1706, 1707,  793,  793,  793,  791,  794,
+      339,  339,  795,  345,  791, 1709,  346,  629,  803,  803,
+      803,  347,  804, 1710, 1711,  805, 1014, 1014, 1014, 1712,
+      348,  353,  354,  147,  354,  353,  353,  353,  353,  353,
+
+      353,  353,  355,  353,  353,  353, 1713,  353,  357,  353,
+      358,  353, 1714,  792,  797,  797,  797,  797,  797,  797,
+      634,  634,  634,  636,  636,  636,  809,  809,  809, 1016,
+     1016, 1016,  799,  353,  353,  799, 1721,  635, 1722, 1003,
+      637,  685, 1723,  810,  359,  353,  354,  147,  354,  353,
+      353,  353,  353,  353,  353,  353,  355,  353,  353,  353,
+     1724,  353,  357,  353,  358,  353,  806,  806,  806, 1725,
+      807, 1718, 1726,  808,  815,  815,  815,  800,  815,  815,
+      815, 1729,  819,  819,  819, 1717,  820,  353,  353,  821,
+     1730, 1731,  817, 1020, 1020, 1020,  817, 1732,  359,  363,
+
+      364,  147,  364,  363,  363,  363,  363,  363,  363,  363,
+      365,  363,  363,  363, 1733,  363,  367,  363,  368,  363,
+      645,  645,  645, 1734, 1735,  822,  822,  822,  822,  822,
+      822, 1736,  818,  650,  650,  650, 1741,  646,  833,  833,
+      833,  363,  363,  824, 1742, 1743,  824, 1744, 1745,  369,
+      651,  370, 1749,  371, 1750, 1751,  835, 1026, 1026, 1026,
+     1752,  372,  363,  364,  147,  364,  363,  363,  363,  363,
+      363,  363,  363,  365,  363,  363,  363, 1753,  363,  367,
+      363,  368,  363, 1754, 1755,  825,  827,  827,  827, 1756,
+      828, 1757, 1758,  829, 1759,  833,  833,  833,  838,  838,
+
+      838,  840,  840,  840,  363,  363,  849,  849,  849, 1027,
+     1027, 1027,  369,  835,  370,  839,  371, 1762,  841, 1053,
+     1053, 1053, 1763,  850,  372,  378,  379,  147,  379,  378,
+      378,  378,  378,  378,  378,  378,  380,  378,  378,  378,
+     1764,  378,  382,  378,  383,  378, 1765,  836,  844,  844,
+      844, 1766,  852,  852,  852,  844,  844,  844,  854,  854,
+      854,  854,  854,  854, 1767, 1782,  846,  378,  378,  853,
+      670,  670,  670,  846, 1783,  685,  856, 1784, 1785,  856,
+     1789,  858,  858,  858, 1790,  859, 1791,  671,  860, 1792,
+      384,  378,  379,  147,  379,  378,  378,  378,  378,  378,
+
+      378,  378,  380,  378,  378,  378, 1774,  378,  382,  378,
+      383,  378,  847,  861,  861,  861, 1793, 1794,  857,  861,
+      861,  861,  869,  869,  869,  869,  869,  869,  875,  875,
+      875,  863, 1796,  378,  378, 1797, 1798,  863, 1799, 1804,
+      871, 1805, 1806,  871, 1807, 1808,  877,  875,  875,  875,
+      699,  699,  699,  915,  915,  915,  384,  392,  699,  699,
+      699, 1016, 1016, 1016,  408,  877, 1809, 1810,  701, 1811,
+      916,  864, 1812,  391, 1813, 1017,  701,  699,  699,  699,
+     1814,  729,  729,  729, 1815,  872,  729,  729,  729, 1816,
+     1817,  729,  729,  729, 1832,  701, 1833,  685,  409,  731,
+
+      410, 1834, 1835,  411,  731,  412,  413,  878,  414,  731,
+     1836, 1837,  415, 1838,  416,  417,  418,  392,  918,  918,
+      918,  888, 1839, 1840,  408,  734,  734,  734, 1841,  735,
+     1844, 1845,  736,  391, 1846,  919, 1826,  917, 2035, 2035,
+     2035, 1847, 2035, 2035, 2035, 1854,  740,  740,  740,  740,
+      740,  740,  740,  740,  740, 2035, 1855, 1856,  409, 2035,
+      419, 1857, 1858,  420,  742,  421,  413,  742,  422, 1859,
+      742, 1860,  415, 1861,  423,  424,  425,  745,  745,  745,
+     1862,  746, 1863, 1864,  747,  748,&