diff --git a/Box/Main.cpp b/Box/Main.cpp index bc8147c09769726f3846ce5b4b685558cc469a6b..eddadc9c618c2c413c1140817f3efb30862c3297 100644 --- a/Box/Main.cpp +++ b/Box/Main.cpp @@ -1,4 +1,4 @@ -// $Id: Main.cpp,v 1.30 2003-06-14 04:37:41 geuzaine Exp $ +// $Id: Main.cpp,v 1.31 2003-11-21 07:56:28 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -113,7 +113,7 @@ int main(int argc, char *argv[]) signal(SIGFPE, Signal); if(CTX.default_plugins) - GMSH_PluginManager::Instance()->RegisterDefaultPlugins(); + GMSH_PluginManager::instance()->registerDefaultPlugins(); check_gsl(); diff --git a/Common/Views.cpp b/Common/Views.cpp index 8de5cd0606e2be1a3d0329694086874b1e193954..b38bbfe79be2bdfad3342b394e4e6536f4b5d3c3 100644 --- a/Common/Views.cpp +++ b/Common/Views.cpp @@ -1,4 +1,4 @@ -// $Id: Views.cpp,v 1.100 2003-11-12 21:42:10 geuzaine Exp $ +// $Id: Views.cpp,v 1.101 2003-11-21 07:56:28 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -30,8 +30,8 @@ extern Context_T CTX; #if defined(HAVE_FLTK) -extern int AddViewInUI(int, char *, int); -extern int RemoveViewInUI(int); +void AddViewInUI(); +void RemoveViewInUI(); #endif #define VAL_INF 1.e200 @@ -356,7 +356,7 @@ void EndView(Post_View * v, int add_in_gui, char *file_name, char *name) #if defined(HAVE_FLTK) if(!CTX.post.force_num && add_in_gui) - AddViewInUI(List_Nbr(CTX.post.list), v->Name, v->Num); + AddViewInUI(); #endif v->Dirty = 0; //the view is complete, we may draw it @@ -448,31 +448,38 @@ void DuplicateView(Post_View * v1, int withoptions) CopyViewOptions(v1, v2); #if defined(HAVE_FLTK) - AddViewInUI(List_Nbr(CTX.post.list), v2->Name, v2->Num); + AddViewInUI(); #endif } -bool FreeView(int num) +bool RemoveViewByIndex(int index) { Post_View *v; - Msg(DEBUG, "Trying to free view %d", num); - - if(num < 0 || num >= List_Nbr(CTX.post.list)) { + if(index < 0 || index >= List_Nbr(CTX.post.list)) { return false; } - v = (Post_View *) List_Pointer(CTX.post.list, num); + v = (Post_View *) List_Pointer(CTX.post.list, index); FreeView(v); - List_PSuppress(CTX.post.list, num); + List_PSuppress(CTX.post.list, index); #if defined(HAVE_FLTK) - RemoveViewInUI(num); + RemoveViewInUI(); #endif - Msg(INFO, "View %d deleted (%d views left)", num, List_Nbr(CTX.post.list)); + Msg(INFO, "View %d removed (%d views left)", index, List_Nbr(CTX.post.list)); return true; } +bool RemoveViewByNumber(int num) +{ + Post_View vv; + + vv.Num = num; + int i = List_ISearch(CTX.post.list, &vv, fcmpPostViewNum); + + return RemoveViewByIndex(i); +} void FreeView(Post_View * v) { @@ -1462,3 +1469,18 @@ void Post_View::add_val(int list, int node, int timestep, double value) { ; } + +int Post_View::empty(){ + if(NbSP || NbVP || NbTP || + NbSL || NbVL || NbTL || + NbST || NbVT || NbTT || + NbSQ || NbVQ || NbTQ || + NbSS || NbVS || NbTS || + NbSH || NbVH || NbTH || + NbSI || NbVI || NbTI || + NbSY || NbVY || NbTY || + NbT2 || NbT3) + return 0; + else + return 1; +} diff --git a/Common/Views.h b/Common/Views.h index d80ae746d2fe906ccbacfe87e59a3073d5af81c7..f3f01da20e366bd29c3e9c1a5c8eba4564a96e6f 100644 --- a/Common/Views.h +++ b/Common/Views.h @@ -21,6 +21,7 @@ // Please report all bugs and problems to "gmsh@geuz.org". #include "ColorTable.h" +#include "List.h" #define VIEW_NB_ELEMENT_TYPES (8*3) #define VIEW_MAX_ELEMENT_NODES 8 @@ -95,6 +96,7 @@ class Post_View{ // some generic access functions int get_val(int list, int node, int timestep, double *value); void add_val(int list, int node, int timestep, double value); + int empty(); }; // Type @@ -144,7 +146,8 @@ void EndView (Post_View *v, int AddInUI, char *FileName, char *Name); void DuplicateView(Post_View *v1, int withoptions); void DuplicateView(int num, int withoptions); void FreeView(Post_View *v); -bool FreeView(int num); +bool RemoveViewByIndex(int index); +bool RemoveViewByNumber(int num); void ReadView(FILE *file, char *filename); void WriteView(int Flag_BIN, Post_View *v, char *filename); void CopyViewOptions(Post_View *src, Post_View *dest); diff --git a/Fltk/Callbacks.cpp b/Fltk/Callbacks.cpp index 57318d4301496d2e742b26085ac0cbf1b57e0cad..414a95f3e11a537d47039d1ddde33697b6b405f1 100644 --- a/Fltk/Callbacks.cpp +++ b/Fltk/Callbacks.cpp @@ -1,4 +1,4 @@ -// $Id: Callbacks.cpp,v 1.185 2003-11-12 21:42:10 geuzaine Exp $ +// $Id: Callbacks.cpp,v 1.186 2003-11-21 07:56:29 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -140,29 +140,23 @@ int file_chooser_get_filter() // Compatibility/local routines -int AddViewInUI(int i, char *Name, int Num) +void AddViewInUI() { - if(i > NB_BUTT_MAX - 1) - return 1; if(WID) { if(WID->get_context() == 3) WID->set_context(menu_post, 0); WID->reset_option_browser(); } - return 0; } -int RemoveViewInUI(int i) +void RemoveViewInUI() { - if(i > NB_BUTT_MAX - 1) - return 1; if(WID) { WID->check_anim_buttons(); if(WID->get_context() == 3) WID->set_context(menu_post, 0); WID->reset_option_browser(); } - return 0; } int SetGlobalShortcut(int event) @@ -2777,7 +2771,7 @@ void view_remove_invisible_cb(CALLBACK_ARGS) void view_remove_cb(CALLBACK_ARGS) { - FreeView((long int)data); + RemoveViewByIndex((long int)data); if(!REMOVE_ALL_VIEWS) Draw(); @@ -2875,7 +2869,7 @@ void view_plugin_cb(CALLBACK_ARGS) Msg(GERROR, "Plugin has too many parameters"); for(int i = 0; i < n; i++) { StringXNumber *sxn; - sxn = p->GetOption(i); + sxn = p->getOption(i); sxn->def = p->dialogBox->view_value[i]->value(); } } @@ -2886,7 +2880,7 @@ void view_plugin_cb(CALLBACK_ARGS) Draw(); } catch(GMSH_Plugin * err) { - p->CatchErrorMessage(name); + p->catchErrorMessage(name); Msg(WARNING, "%s", name); } } diff --git a/Fltk/GUI.cpp b/Fltk/GUI.cpp index 043038421cb1c881b415c7099716f4e74b4211e0..ba168a45977b574b5cac0ba6998604bdc4f9672d 100644 --- a/Fltk/GUI.cpp +++ b/Fltk/GUI.cpp @@ -1,4 +1,4 @@ -// $Id: GUI.cpp,v 1.251 2003-11-18 05:29:24 geuzaine Exp $ +// $Id: GUI.cpp,v 1.252 2003-11-21 07:56:29 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -762,8 +762,8 @@ void GUI::wait() void GUI::add_post_plugins(Fl_Menu_Button * button, int iView) { char name[256], menuname[256]; - for(GMSH_PluginManager::iter it = GMSH_PluginManager::Instance()->begin(); - it != GMSH_PluginManager::Instance()->end(); ++it) { + for(GMSH_PluginManager::iter it = GMSH_PluginManager::instance()->begin(); + it != GMSH_PluginManager::instance()->end(); ++it) { GMSH_Plugin *p = (*it).second; if(p->getType() == GMSH_Plugin::GMSH_POST_PLUGIN) { p->getName(name); @@ -2623,7 +2623,7 @@ PluginDialogBox *GUI::create_plugin_window(GMSH_Plugin * p) for(int i = 0; i < n; i++) { StringXNumber *sxn; - sxn = p->GetOption(i); + sxn = p->getOption(i); pdb->view_value[i] = new Fl_Value_Input(2 * WB, 2 * WB + (i + 1) * BH, IW, BH, sxn->str); pdb->view_value[i]->align(FL_ALIGN_RIGHT); pdb->view_value[i]->value(sxn->def); diff --git a/Fltk/Main.cpp b/Fltk/Main.cpp index 48bc1142ec10c54ca1896babb7c775d9e00cba99..9f0af72ca56584073d10b13ef58514ba7aa78c77 100644 --- a/Fltk/Main.cpp +++ b/Fltk/Main.cpp @@ -1,4 +1,4 @@ -// $Id: Main.cpp,v 1.49 2003-06-17 19:26:59 geuzaine Exp $ +// $Id: Main.cpp,v 1.50 2003-11-21 07:56:29 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -101,7 +101,7 @@ int main(int argc, char *argv[]) // Register Default Plugins (in test ...) if(CTX.default_plugins) - GMSH_PluginManager::Instance()->RegisterDefaultPlugins(); + GMSH_PluginManager::instance()->registerDefaultPlugins(); // Initialize the static Mesh diff --git a/Parser/Gmsh.tab.cpp b/Parser/Gmsh.tab.cpp index 83c5b3467529aad6d042163362b4310cfd5f06d8..38f50a71317dc04407c5e6ee88d43541c051f378 100644 --- a/Parser/Gmsh.tab.cpp +++ b/Parser/Gmsh.tab.cpp @@ -189,7 +189,7 @@ #line 1 "Gmsh.y" -// $Id: Gmsh.tab.cpp,v 1.165 2003-10-29 22:24:24 geuzaine Exp $ +// $Id: Gmsh.tab.cpp,v 1.166 2003-11-21 07:56:29 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -290,7 +290,7 @@ typedef union { -#define YYFINAL 2293 +#define YYFINAL 2299 #define YYFLAG -32768 #define YYNTBASE 203 @@ -372,25 +372,25 @@ static const short yyprhs[] = { 0, 1924, 1932, 1940, 1952, 1961, 1974, 1983, 1998, 2021, 2042, 2051, 2060, 2069, 2077, 2086, 2092, 2104, 2110, 2120, 2122, 2124, 2126, 2127, 2130, 2137, 2144, 2151, 2156, 2163, 2168, - 2175, 2179, 2185, 2189, 2193, 2201, 2204, 2207, 2214, 2223, - 2232, 2243, 2245, 2248, 2250, 2254, 2259, 2261, 2270, 2283, - 2298, 2299, 2312, 2313, 2330, 2331, 2350, 2359, 2372, 2387, - 2388, 2401, 2402, 2419, 2420, 2439, 2448, 2461, 2476, 2477, - 2490, 2491, 2508, 2509, 2528, 2530, 2533, 2543, 2551, 2554, - 2561, 2571, 2581, 2590, 2599, 2608, 2615, 2620, 2623, 2626, - 2628, 2630, 2632, 2634, 2636, 2638, 2642, 2645, 2648, 2651, - 2655, 2659, 2663, 2667, 2671, 2675, 2679, 2683, 2687, 2691, - 2695, 2699, 2703, 2707, 2713, 2718, 2723, 2728, 2733, 2738, - 2743, 2748, 2753, 2758, 2763, 2770, 2775, 2780, 2785, 2790, - 2795, 2800, 2807, 2814, 2821, 2826, 2831, 2836, 2841, 2846, - 2851, 2856, 2861, 2866, 2871, 2876, 2883, 2888, 2893, 2898, - 2903, 2908, 2913, 2920, 2927, 2934, 2939, 2941, 2943, 2945, - 2947, 2949, 2954, 2957, 2963, 2967, 2974, 2979, 2987, 2989, - 2992, 2995, 2999, 3003, 3015, 3025, 3033, 3041, 3042, 3046, - 3048, 3052, 3053, 3057, 3061, 3063, 3067, 3069, 3071, 3075, - 3080, 3084, 3090, 3095, 3097, 3099, 3101, 3105, 3110, 3117, - 3125, 3127, 3129, 3133, 3137, 3147, 3155, 3157, 3163, 3167, - 3174, 3176, 3180, 3182, 3189, 3194, 3199, 3206, 3213 + 2175, 2179, 2185, 2189, 2197, 2201, 2209, 2212, 2215, 2222, + 2231, 2240, 2251, 2253, 2256, 2258, 2262, 2267, 2269, 2278, + 2291, 2306, 2307, 2320, 2321, 2338, 2339, 2358, 2367, 2380, + 2395, 2396, 2409, 2410, 2427, 2428, 2447, 2456, 2469, 2484, + 2485, 2498, 2499, 2516, 2517, 2536, 2538, 2541, 2551, 2559, + 2562, 2569, 2579, 2589, 2598, 2607, 2616, 2623, 2628, 2631, + 2634, 2636, 2638, 2640, 2642, 2644, 2646, 2650, 2653, 2656, + 2659, 2663, 2667, 2671, 2675, 2679, 2683, 2687, 2691, 2695, + 2699, 2703, 2707, 2711, 2715, 2721, 2726, 2731, 2736, 2741, + 2746, 2751, 2756, 2761, 2766, 2771, 2778, 2783, 2788, 2793, + 2798, 2803, 2808, 2815, 2822, 2829, 2834, 2839, 2844, 2849, + 2854, 2859, 2864, 2869, 2874, 2879, 2884, 2891, 2896, 2901, + 2906, 2911, 2916, 2921, 2928, 2935, 2942, 2947, 2949, 2951, + 2953, 2955, 2957, 2962, 2965, 2971, 2975, 2982, 2987, 2995, + 2997, 3000, 3003, 3007, 3011, 3023, 3033, 3041, 3049, 3050, + 3054, 3056, 3060, 3061, 3065, 3069, 3071, 3075, 3077, 3079, + 3083, 3088, 3092, 3098, 3103, 3105, 3107, 3109, 3113, 3118, + 3125, 3133, 3135, 3137, 3141, 3145, 3155, 3163, 3165, 3171, + 3175, 3182, 3184, 3188, 3190, 3197, 3202, 3207, 3214, 3221 }; static const short yyrhs[] = { 206, @@ -612,111 +612,111 @@ static const short yyrhs[] = { 206, 64, 201, 300, 202, 0, 64, 4, 197, 321, 198, 6, 0, 67, 201, 300, 202, 0, 67, 4, 197, 321, 198, 6, 0, 67, 116, 6, 0, 105, 332, - 201, 300, 202, 0, 4, 335, 6, 0, 4, 321, - 6, 0, 58, 195, 4, 196, 199, 4, 6, 0, - 112, 6, 0, 37, 6, 0, 107, 195, 321, 8, - 321, 196, 0, 107, 195, 321, 8, 321, 8, 321, - 196, 0, 107, 4, 108, 201, 321, 8, 321, 202, - 0, 107, 4, 108, 201, 321, 8, 321, 8, 321, - 202, 0, 109, 0, 115, 4, 0, 113, 0, 114, - 4, 6, 0, 110, 195, 321, 196, 0, 111, 0, - 63, 38, 201, 321, 200, 323, 202, 6, 0, 63, - 38, 201, 321, 200, 323, 200, 323, 200, 321, 202, - 6, 0, 63, 38, 201, 321, 200, 323, 200, 323, - 200, 323, 200, 321, 202, 6, 0, 0, 63, 38, - 201, 321, 200, 323, 202, 307, 201, 316, 202, 6, - 0, 0, 63, 38, 201, 321, 200, 323, 200, 323, - 200, 321, 202, 308, 201, 316, 202, 6, 0, 0, + 201, 300, 202, 0, 4, 335, 6, 0, 4, 4, + 197, 321, 198, 335, 6, 0, 4, 321, 6, 0, + 58, 195, 4, 196, 199, 4, 6, 0, 112, 6, + 0, 37, 6, 0, 107, 195, 321, 8, 321, 196, + 0, 107, 195, 321, 8, 321, 8, 321, 196, 0, + 107, 4, 108, 201, 321, 8, 321, 202, 0, 107, + 4, 108, 201, 321, 8, 321, 8, 321, 202, 0, + 109, 0, 115, 4, 0, 113, 0, 114, 4, 6, + 0, 110, 195, 321, 196, 0, 111, 0, 63, 38, + 201, 321, 200, 323, 202, 6, 0, 63, 38, 201, + 321, 200, 323, 200, 323, 200, 321, 202, 6, 0, 63, 38, 201, 321, 200, 323, 200, 323, 200, 323, - 200, 321, 202, 309, 201, 316, 202, 6, 0, 63, - 41, 201, 321, 200, 323, 202, 6, 0, 63, 41, - 201, 321, 200, 323, 200, 323, 200, 321, 202, 6, - 0, 63, 41, 201, 321, 200, 323, 200, 323, 200, - 323, 200, 321, 202, 6, 0, 0, 63, 41, 201, - 321, 200, 323, 202, 310, 201, 316, 202, 6, 0, - 0, 63, 41, 201, 321, 200, 323, 200, 323, 200, - 321, 202, 311, 201, 316, 202, 6, 0, 0, 63, + 200, 321, 202, 6, 0, 0, 63, 38, 201, 321, + 200, 323, 202, 307, 201, 316, 202, 6, 0, 0, + 63, 38, 201, 321, 200, 323, 200, 323, 200, 321, + 202, 308, 201, 316, 202, 6, 0, 0, 63, 38, + 201, 321, 200, 323, 200, 323, 200, 323, 200, 321, + 202, 309, 201, 316, 202, 6, 0, 63, 41, 201, + 321, 200, 323, 202, 6, 0, 63, 41, 201, 321, + 200, 323, 200, 323, 200, 321, 202, 6, 0, 63, 41, 201, 321, 200, 323, 200, 323, 200, 323, 200, - 321, 202, 312, 201, 316, 202, 6, 0, 63, 42, - 201, 321, 200, 323, 202, 6, 0, 63, 42, 201, - 321, 200, 323, 200, 323, 200, 321, 202, 6, 0, - 63, 42, 201, 321, 200, 323, 200, 323, 200, 323, - 200, 321, 202, 6, 0, 0, 63, 42, 201, 321, - 200, 323, 202, 313, 201, 316, 202, 6, 0, 0, - 63, 42, 201, 321, 200, 323, 200, 323, 200, 321, - 202, 314, 201, 316, 202, 6, 0, 0, 63, 42, + 321, 202, 6, 0, 0, 63, 41, 201, 321, 200, + 323, 202, 310, 201, 316, 202, 6, 0, 0, 63, + 41, 201, 321, 200, 323, 200, 323, 200, 321, 202, + 311, 201, 316, 202, 6, 0, 0, 63, 41, 201, + 321, 200, 323, 200, 323, 200, 323, 200, 321, 202, + 312, 201, 316, 202, 6, 0, 63, 42, 201, 321, + 200, 323, 202, 6, 0, 63, 42, 201, 321, 200, + 323, 200, 323, 200, 321, 202, 6, 0, 63, 42, 201, 321, 200, 323, 200, 323, 200, 323, 200, 321, - 202, 315, 201, 316, 202, 6, 0, 317, 0, 316, - 317, 0, 71, 201, 329, 200, 329, 200, 329, 202, - 6, 0, 71, 201, 329, 200, 329, 202, 6, 0, - 66, 6, 0, 52, 41, 329, 7, 321, 6, 0, - 52, 41, 329, 7, 321, 55, 57, 321, 6, 0, - 52, 41, 329, 7, 321, 55, 56, 321, 6, 0, - 52, 42, 201, 321, 202, 7, 329, 6, 0, 48, - 42, 201, 321, 202, 7, 329, 6, 0, 52, 44, - 201, 321, 202, 7, 329, 6, 0, 66, 42, 329, - 7, 321, 6, 0, 66, 42, 329, 6, 0, 68, - 6, 0, 69, 6, 0, 121, 0, 122, 0, 123, - 0, 124, 0, 125, 0, 322, 0, 195, 321, 196, - 0, 185, 321, 0, 184, 321, 0, 190, 321, 0, - 321, 185, 321, 0, 321, 184, 321, 0, 321, 186, - 321, 0, 321, 187, 321, 0, 321, 188, 321, 0, - 321, 194, 321, 0, 321, 180, 321, 0, 321, 182, - 321, 0, 321, 181, 321, 0, 321, 183, 321, 0, - 321, 177, 321, 0, 321, 178, 321, 0, 321, 176, - 321, 0, 321, 175, 321, 0, 321, 174, 321, 8, - 321, 0, 12, 195, 321, 196, 0, 13, 195, 321, - 196, 0, 14, 195, 321, 196, 0, 15, 195, 321, - 196, 0, 16, 195, 321, 196, 0, 17, 195, 321, - 196, 0, 18, 195, 321, 196, 0, 19, 195, 321, - 196, 0, 20, 195, 321, 196, 0, 22, 195, 321, - 196, 0, 23, 195, 321, 200, 321, 196, 0, 24, - 195, 321, 196, 0, 25, 195, 321, 196, 0, 26, - 195, 321, 196, 0, 27, 195, 321, 196, 0, 28, - 195, 321, 196, 0, 29, 195, 321, 196, 0, 30, - 195, 321, 200, 321, 196, 0, 31, 195, 321, 200, - 321, 196, 0, 32, 195, 321, 200, 321, 196, 0, - 21, 195, 321, 196, 0, 12, 197, 321, 198, 0, - 13, 197, 321, 198, 0, 14, 197, 321, 198, 0, - 15, 197, 321, 198, 0, 16, 197, 321, 198, 0, - 17, 197, 321, 198, 0, 18, 197, 321, 198, 0, - 19, 197, 321, 198, 0, 20, 197, 321, 198, 0, - 22, 197, 321, 198, 0, 23, 197, 321, 200, 321, - 198, 0, 24, 197, 321, 198, 0, 25, 197, 321, - 198, 0, 26, 197, 321, 198, 0, 27, 197, 321, - 198, 0, 28, 197, 321, 198, 0, 29, 197, 321, - 198, 0, 30, 197, 321, 200, 321, 198, 0, 31, - 197, 321, 200, 321, 198, 0, 32, 197, 321, 200, - 321, 198, 0, 21, 197, 321, 198, 0, 3, 0, - 9, 0, 10, 0, 11, 0, 4, 0, 4, 197, - 321, 198, 0, 4, 295, 0, 4, 197, 321, 198, - 295, 0, 4, 199, 4, 0, 4, 197, 321, 198, - 199, 4, 0, 4, 199, 4, 295, 0, 4, 197, - 321, 198, 199, 4, 295, 0, 324, 0, 185, 323, - 0, 184, 323, 0, 323, 185, 323, 0, 323, 184, - 323, 0, 201, 321, 200, 321, 200, 321, 200, 321, - 200, 321, 202, 0, 201, 321, 200, 321, 200, 321, + 202, 6, 0, 0, 63, 42, 201, 321, 200, 323, + 202, 313, 201, 316, 202, 6, 0, 0, 63, 42, + 201, 321, 200, 323, 200, 323, 200, 321, 202, 314, + 201, 316, 202, 6, 0, 0, 63, 42, 201, 321, + 200, 323, 200, 323, 200, 323, 200, 321, 202, 315, + 201, 316, 202, 6, 0, 317, 0, 316, 317, 0, + 71, 201, 329, 200, 329, 200, 329, 202, 6, 0, + 71, 201, 329, 200, 329, 202, 6, 0, 66, 6, + 0, 52, 41, 329, 7, 321, 6, 0, 52, 41, + 329, 7, 321, 55, 57, 321, 6, 0, 52, 41, + 329, 7, 321, 55, 56, 321, 6, 0, 52, 42, + 201, 321, 202, 7, 329, 6, 0, 48, 42, 201, + 321, 202, 7, 329, 6, 0, 52, 44, 201, 321, + 202, 7, 329, 6, 0, 66, 42, 329, 7, 321, + 6, 0, 66, 42, 329, 6, 0, 68, 6, 0, + 69, 6, 0, 121, 0, 122, 0, 123, 0, 124, + 0, 125, 0, 322, 0, 195, 321, 196, 0, 185, + 321, 0, 184, 321, 0, 190, 321, 0, 321, 185, + 321, 0, 321, 184, 321, 0, 321, 186, 321, 0, + 321, 187, 321, 0, 321, 188, 321, 0, 321, 194, + 321, 0, 321, 180, 321, 0, 321, 182, 321, 0, + 321, 181, 321, 0, 321, 183, 321, 0, 321, 177, + 321, 0, 321, 178, 321, 0, 321, 176, 321, 0, + 321, 175, 321, 0, 321, 174, 321, 8, 321, 0, + 12, 195, 321, 196, 0, 13, 195, 321, 196, 0, + 14, 195, 321, 196, 0, 15, 195, 321, 196, 0, + 16, 195, 321, 196, 0, 17, 195, 321, 196, 0, + 18, 195, 321, 196, 0, 19, 195, 321, 196, 0, + 20, 195, 321, 196, 0, 22, 195, 321, 196, 0, + 23, 195, 321, 200, 321, 196, 0, 24, 195, 321, + 196, 0, 25, 195, 321, 196, 0, 26, 195, 321, + 196, 0, 27, 195, 321, 196, 0, 28, 195, 321, + 196, 0, 29, 195, 321, 196, 0, 30, 195, 321, + 200, 321, 196, 0, 31, 195, 321, 200, 321, 196, + 0, 32, 195, 321, 200, 321, 196, 0, 21, 195, + 321, 196, 0, 12, 197, 321, 198, 0, 13, 197, + 321, 198, 0, 14, 197, 321, 198, 0, 15, 197, + 321, 198, 0, 16, 197, 321, 198, 0, 17, 197, + 321, 198, 0, 18, 197, 321, 198, 0, 19, 197, + 321, 198, 0, 20, 197, 321, 198, 0, 22, 197, + 321, 198, 0, 23, 197, 321, 200, 321, 198, 0, + 24, 197, 321, 198, 0, 25, 197, 321, 198, 0, + 26, 197, 321, 198, 0, 27, 197, 321, 198, 0, + 28, 197, 321, 198, 0, 29, 197, 321, 198, 0, + 30, 197, 321, 200, 321, 198, 0, 31, 197, 321, + 200, 321, 198, 0, 32, 197, 321, 200, 321, 198, + 0, 21, 197, 321, 198, 0, 3, 0, 9, 0, + 10, 0, 11, 0, 4, 0, 4, 197, 321, 198, + 0, 4, 295, 0, 4, 197, 321, 198, 295, 0, + 4, 199, 4, 0, 4, 197, 321, 198, 199, 4, + 0, 4, 199, 4, 295, 0, 4, 197, 321, 198, + 199, 4, 295, 0, 324, 0, 185, 323, 0, 184, + 323, 0, 323, 185, 323, 0, 323, 184, 323, 0, + 201, 321, 200, 321, 200, 321, 200, 321, 200, 321, + 202, 0, 201, 321, 200, 321, 200, 321, 200, 321, + 202, 0, 201, 321, 200, 321, 200, 321, 202, 0, + 195, 321, 200, 321, 200, 321, 196, 0, 0, 195, + 326, 196, 0, 5, 0, 326, 200, 5, 0, 0, + 201, 328, 202, 0, 195, 328, 196, 0, 329, 0, + 328, 200, 329, 0, 321, 0, 330, 0, 201, 331, + 202, 0, 185, 201, 331, 202, 0, 321, 8, 321, + 0, 321, 8, 321, 8, 321, 0, 38, 201, 321, + 202, 0, 298, 0, 301, 0, 306, 0, 4, 197, + 198, 0, 185, 4, 197, 198, 0, 4, 197, 201, + 331, 202, 198, 0, 185, 4, 197, 201, 331, 202, + 198, 0, 321, 0, 330, 0, 331, 200, 321, 0, + 331, 200, 330, 0, 201, 321, 200, 321, 200, 321, 200, 321, 202, 0, 201, 321, 200, 321, 200, 321, - 202, 0, 195, 321, 200, 321, 200, 321, 196, 0, - 0, 195, 326, 196, 0, 5, 0, 326, 200, 5, - 0, 0, 201, 328, 202, 0, 195, 328, 196, 0, - 329, 0, 328, 200, 329, 0, 321, 0, 330, 0, - 201, 331, 202, 0, 185, 201, 331, 202, 0, 321, - 8, 321, 0, 321, 8, 321, 8, 321, 0, 38, - 201, 321, 202, 0, 298, 0, 301, 0, 306, 0, - 4, 197, 198, 0, 185, 4, 197, 198, 0, 4, - 197, 201, 331, 202, 198, 0, 185, 4, 197, 201, - 331, 202, 198, 0, 321, 0, 330, 0, 331, 200, - 321, 0, 331, 200, 330, 0, 201, 321, 200, 321, - 200, 321, 200, 321, 202, 0, 201, 321, 200, 321, - 200, 321, 202, 0, 4, 0, 4, 199, 105, 199, - 4, 0, 201, 334, 202, 0, 4, 197, 321, 198, - 199, 106, 0, 332, 0, 334, 200, 332, 0, 5, - 0, 35, 195, 335, 200, 335, 196, 0, 36, 195, - 335, 196, 0, 34, 195, 335, 196, 0, 34, 195, - 335, 200, 331, 196, 0, 34, 195, 4, 199, 4, - 196, 0, 34, 195, 4, 197, 321, 198, 199, 4, - 196, 0 + 202, 0, 4, 0, 4, 199, 105, 199, 4, 0, + 201, 334, 202, 0, 4, 197, 321, 198, 199, 106, + 0, 332, 0, 334, 200, 332, 0, 5, 0, 35, + 195, 335, 200, 335, 196, 0, 36, 195, 335, 196, + 0, 34, 195, 335, 196, 0, 34, 195, 335, 200, + 331, 196, 0, 34, 195, 4, 199, 4, 196, 0, + 34, 195, 4, 197, 321, 198, 199, 4, 196, 0 }; #endif @@ -750,25 +750,25 @@ static const short yyrline[] = { 0, 1663, 1674, 1685, 1710, 1716, 1735, 1757, 1763, 1771, 1777, 1783, 1792, 1798, 1804, 1814, 1820, 1825, 1830, 1837, 1839, 1840, 1843, 1848, 1852, 1866, 1880, 1898, 1909, 1919, 1927, - 1931, 1939, 1951, 2034, 2054, 2059, 2063, 2083, 2095, 2105, - 2126, 2147, 2168, 2174, 2179, 2184, 2188, 2196, 2209, 2219, - 2229, 2234, 2244, 2249, 2259, 2264, 2276, 2293, 2310, 2327, - 2332, 2349, 2354, 2371, 2376, 2396, 2412, 2428, 2444, 2449, - 2466, 2472, 2489, 2495, 2514, 2518, 2523, 2550, 2574, 2582, - 2601, 2619, 2637, 2659, 2680, 2701, 2715, 2734, 2739, 2748, - 2750, 2751, 2752, 2753, 2756, 2758, 2759, 2760, 2761, 2762, - 2763, 2764, 2765, 2772, 2773, 2774, 2775, 2776, 2777, 2778, - 2779, 2780, 2781, 2782, 2783, 2784, 2785, 2786, 2787, 2788, - 2789, 2790, 2791, 2792, 2793, 2794, 2795, 2796, 2797, 2798, - 2799, 2800, 2801, 2802, 2803, 2805, 2806, 2807, 2808, 2809, - 2810, 2811, 2812, 2813, 2814, 2815, 2816, 2817, 2818, 2819, - 2820, 2821, 2822, 2823, 2824, 2825, 2830, 2835, 2836, 2837, - 2841, 2852, 2869, 2880, 2899, 2915, 2931, 2947, 2964, 2969, - 2973, 2977, 2981, 2987, 2992, 2996, 3000, 3006, 3010, 3015, - 3019, 3024, 3028, 3032, 3038, 3044, 3051, 3057, 3061, 3065, - 3075, 3082, 3093, 3113, 3122, 3131, 3142, 3156, 3172, 3192, - 3216, 3222, 3226, 3230, 3241, 3246, 3257, 3262, 3280, 3285, - 3298, 3304, 3310, 3315, 3323, 3336, 3340, 3358, 3372 + 1931, 1939, 1951, 2025, 2037, 2057, 2062, 2066, 2086, 2098, + 2108, 2129, 2150, 2171, 2177, 2182, 2187, 2191, 2199, 2212, + 2222, 2232, 2237, 2247, 2252, 2262, 2267, 2279, 2296, 2313, + 2330, 2335, 2352, 2357, 2374, 2379, 2399, 2415, 2431, 2447, + 2452, 2469, 2475, 2492, 2498, 2517, 2521, 2526, 2553, 2577, + 2585, 2604, 2622, 2640, 2662, 2683, 2704, 2718, 2737, 2742, + 2751, 2753, 2754, 2755, 2756, 2759, 2761, 2762, 2763, 2764, + 2765, 2766, 2767, 2768, 2775, 2776, 2777, 2778, 2779, 2780, + 2781, 2782, 2783, 2784, 2785, 2786, 2787, 2788, 2789, 2790, + 2791, 2792, 2793, 2794, 2795, 2796, 2797, 2798, 2799, 2800, + 2801, 2802, 2803, 2804, 2805, 2806, 2808, 2809, 2810, 2811, + 2812, 2813, 2814, 2815, 2816, 2817, 2818, 2819, 2820, 2821, + 2822, 2823, 2824, 2825, 2826, 2827, 2828, 2833, 2838, 2839, + 2840, 2844, 2855, 2872, 2883, 2902, 2918, 2934, 2950, 2967, + 2972, 2976, 2980, 2984, 2990, 2995, 2999, 3003, 3009, 3013, + 3018, 3022, 3027, 3031, 3035, 3041, 3047, 3054, 3060, 3064, + 3068, 3078, 3085, 3096, 3116, 3125, 3134, 3145, 3159, 3175, + 3195, 3219, 3225, 3229, 3233, 3244, 3249, 3260, 3265, 3283, + 3288, 3301, 3307, 3313, 3318, 3326, 3339, 3343, 3361, 3375 }; #endif @@ -859,25 +859,25 @@ static const short yyr1[] = { 0, 297, 297, 297, 297, 297, 297, 297, 297, 297, 297, 297, 297, 297, 297, 298, 298, 298, 298, 299, 299, 299, 300, 300, 300, 300, 300, 301, 301, 302, 302, - 302, 303, 304, 304, 304, 304, 304, 305, 305, 305, - 305, 305, 305, 305, 305, 305, 305, 306, 306, 306, - 307, 306, 308, 306, 309, 306, 306, 306, 306, 310, - 306, 311, 306, 312, 306, 306, 306, 306, 313, 306, - 314, 306, 315, 306, 316, 316, 317, 317, 317, 318, - 318, 318, 318, 318, 318, 318, 318, 319, 319, 320, - 320, 320, 320, 320, 321, 321, 321, 321, 321, 321, + 302, 303, 304, 304, 304, 304, 304, 304, 305, 305, + 305, 305, 305, 305, 305, 305, 305, 305, 306, 306, + 306, 307, 306, 308, 306, 309, 306, 306, 306, 306, + 310, 306, 311, 306, 312, 306, 306, 306, 306, 313, + 306, 314, 306, 315, 306, 316, 316, 317, 317, 317, + 318, 318, 318, 318, 318, 318, 318, 318, 319, 319, + 320, 320, 320, 320, 320, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, 321, - 321, 321, 321, 321, 321, 321, 322, 322, 322, 322, - 322, 322, 322, 322, 322, 322, 322, 322, 323, 323, - 323, 323, 323, 324, 324, 324, 324, 325, 325, 326, - 326, 327, 327, 327, 328, 328, 329, 329, 329, 329, - 330, 330, 330, 330, 330, 330, 330, 330, 330, 330, - 331, 331, 331, 331, 332, 332, 332, 332, 333, 333, - 334, 334, 335, 335, 335, 335, 335, 335, 335 + 321, 321, 321, 321, 321, 321, 321, 322, 322, 322, + 322, 322, 322, 322, 322, 322, 322, 322, 322, 323, + 323, 323, 323, 323, 324, 324, 324, 324, 325, 325, + 326, 326, 327, 327, 327, 328, 328, 329, 329, 329, + 329, 330, 330, 330, 330, 330, 330, 330, 330, 330, + 330, 331, 331, 331, 331, 332, 332, 332, 332, 333, + 333, 334, 334, 335, 335, 335, 335, 335, 335, 335 }; static const short yyr2[] = { 0, @@ -908,25 +908,25 @@ static const short yyr2[] = { 0, 7, 7, 11, 8, 12, 8, 14, 22, 20, 8, 8, 8, 7, 8, 5, 11, 5, 9, 1, 1, 1, 0, 2, 6, 6, 6, 4, 6, 4, 6, - 3, 5, 3, 3, 7, 2, 2, 6, 8, 8, - 10, 1, 2, 1, 3, 4, 1, 8, 12, 14, + 3, 5, 3, 7, 3, 7, 2, 2, 6, 8, + 8, 10, 1, 2, 1, 3, 4, 1, 8, 12, + 14, 0, 12, 0, 16, 0, 18, 8, 12, 14, 0, 12, 0, 16, 0, 18, 8, 12, 14, 0, - 12, 0, 16, 0, 18, 8, 12, 14, 0, 12, - 0, 16, 0, 18, 1, 2, 9, 7, 2, 6, - 9, 9, 8, 8, 8, 6, 4, 2, 2, 1, - 1, 1, 1, 1, 1, 3, 2, 2, 2, 3, + 12, 0, 16, 0, 18, 1, 2, 9, 7, 2, + 6, 9, 9, 8, 8, 8, 6, 4, 2, 2, + 1, 1, 1, 1, 1, 1, 3, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 3, 3, 3, 5, 4, 4, 4, 4, 4, 4, - 4, 4, 4, 4, 6, 4, 4, 4, 4, 4, - 4, 6, 6, 6, 4, 4, 4, 4, 4, 4, + 3, 3, 3, 3, 5, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 6, 4, 4, 4, 4, - 4, 4, 6, 6, 6, 4, 1, 1, 1, 1, - 1, 4, 2, 5, 3, 6, 4, 7, 1, 2, - 2, 3, 3, 11, 9, 7, 7, 0, 3, 1, - 3, 0, 3, 3, 1, 3, 1, 1, 3, 4, - 3, 5, 4, 1, 1, 1, 3, 4, 6, 7, - 1, 1, 3, 3, 9, 7, 1, 5, 3, 6, - 1, 3, 1, 6, 4, 4, 6, 6, 9 + 4, 4, 6, 6, 6, 4, 4, 4, 4, 4, + 4, 4, 4, 4, 4, 4, 6, 4, 4, 4, + 4, 4, 4, 6, 6, 6, 4, 1, 1, 1, + 1, 1, 4, 2, 5, 3, 6, 4, 7, 1, + 2, 2, 3, 3, 11, 9, 7, 7, 0, 3, + 1, 3, 0, 3, 3, 1, 3, 1, 1, 3, + 4, 3, 5, 4, 1, 1, 1, 3, 4, 6, + 7, 1, 1, 3, 3, 9, 7, 1, 5, 3, + 6, 1, 3, 1, 6, 4, 4, 6, 6, 9 }; static const short yydefact[] = { 0, @@ -935,486 +935,486 @@ static const short yydefact[] = { 0, 14, 13, 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, 282, 0, - 287, 0, 284, 0, 0, 0, 54, 56, 55, 57, + 0, 0, 0, 0, 0, 0, 0, 0, 283, 0, + 288, 0, 285, 0, 0, 0, 54, 56, 55, 57, 58, 59, 60, 61, 62, 67, 66, 63, 64, 65, - 5, 0, 0, 0, 15, 16, 18, 17, 19, 418, - 418, 0, 397, 401, 453, 203, 398, 399, 400, 0, + 5, 0, 0, 0, 15, 16, 18, 17, 19, 419, + 419, 0, 398, 402, 454, 203, 399, 400, 401, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 204, 205, 206, 207, 0, 0, 0, - 208, 209, 0, 0, 0, 0, 0, 0, 335, 0, - 0, 277, 0, 0, 0, 0, 0, 0, 0, 0, + 208, 209, 0, 0, 0, 0, 0, 0, 336, 0, + 0, 278, 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, 409, 0, 0, 0, 0, 0, 0, 262, 0, - 0, 0, 262, 328, 329, 0, 0, 0, 0, 0, - 0, 447, 0, 0, 0, 0, 0, 276, 0, 283, + 0, 410, 0, 0, 0, 0, 0, 0, 262, 0, + 0, 0, 262, 329, 330, 0, 0, 0, 0, 0, + 0, 448, 0, 0, 0, 0, 0, 277, 0, 284, 0, 6, 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, 403, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 404, 0, 72, 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, 338, 337, 339, - 0, 0, 0, 0, 0, 0, 0, 0, 214, 274, + 0, 0, 0, 0, 0, 0, 0, 402, 339, 338, + 340, 0, 0, 0, 0, 0, 0, 0, 0, 214, + 275, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 273, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 402, 0, 0, 0, + 435, 436, 437, 428, 0, 429, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 273, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 401, 0, 0, 0, 434, - 435, 436, 427, 0, 428, 0, 0, 0, 0, 0, + 0, 412, 411, 0, 0, 0, 0, 262, 262, 0, + 0, 0, 0, 0, 0, 0, 0, 271, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 262, 0, + 0, 0, 286, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 411, 410, 0, 0, 0, 0, 262, 262, 0, 0, - 0, 0, 0, 0, 0, 0, 271, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 262, 0, 0, - 0, 285, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 421, 0, 0, 0, 0, + 0, 406, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 420, 0, 0, 0, 0, 0, - 405, 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, 454, 0, 0, + 0, 0, 337, 0, 0, 442, 443, 0, 0, 203, + 0, 0, 0, 0, 210, 0, 354, 353, 351, 352, + 347, 349, 348, 350, 342, 341, 343, 344, 345, 346, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 453, 0, 0, 0, - 336, 0, 0, 441, 442, 0, 0, 203, 0, 0, - 0, 0, 210, 0, 353, 352, 350, 351, 346, 348, - 347, 349, 341, 340, 342, 343, 344, 345, 0, 0, + 0, 0, 402, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 401, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 414, 413, 261, 0, 260, 259, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 267, + 263, 328, 0, 0, 269, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 287, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 413, 412, 261, 0, 260, 259, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 267, 263, 327, - 0, 0, 269, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 286, 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, 419, 0, - 0, 21, 0, 402, 407, 72, 0, 0, 0, 0, + 420, 0, 0, 21, 0, 403, 408, 72, 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, 73, 74, 75, 76, 77, 78, 79, - 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, - 90, 91, 92, 93, 94, 95, 96, 97, 98, 355, - 376, 356, 377, 357, 378, 358, 379, 359, 380, 360, - 381, 361, 382, 362, 383, 363, 384, 375, 396, 364, - 385, 0, 0, 366, 387, 367, 388, 368, 389, 369, - 390, 370, 391, 371, 392, 0, 0, 0, 0, 0, - 0, 0, 0, 456, 0, 0, 455, 0, 0, 0, - 0, 0, 0, 0, 0, 220, 0, 0, 0, 0, - 0, 68, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 437, 0, 0, 0, 0, 429, 431, 0, 0, + 0, 0, 0, 0, 0, 73, 74, 75, 76, 77, + 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, + 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, + 98, 356, 377, 357, 378, 358, 379, 359, 380, 360, + 381, 361, 382, 362, 383, 363, 384, 364, 385, 376, + 397, 365, 386, 0, 0, 367, 388, 368, 389, 369, + 390, 370, 391, 371, 392, 372, 393, 0, 0, 0, + 0, 0, 0, 0, 0, 457, 0, 0, 456, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 220, 0, + 0, 0, 0, 0, 68, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 438, 0, 0, 0, 0, 430, + 432, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 255, + 257, 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, 255, 257, 0, 0, + 272, 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, 272, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 422, 0, 419, 0, 405, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 421, 0, 418, 0, 404, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 70, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 403, 213, 444, 445, 0, 0, 0, 0, 0, + 215, 216, 218, 0, 0, 452, 0, 224, 355, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 434, + 439, 0, 431, 0, 231, 0, 0, 0, 0, 0, + 321, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 268, 0, 0, + 0, 327, 270, 0, 0, 0, 0, 0, 423, 0, + 449, 0, 0, 0, 279, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 70, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 213, 443, 444, - 0, 0, 0, 0, 0, 215, 216, 218, 0, 0, - 451, 0, 224, 354, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 433, 438, 0, 430, 0, 231, - 0, 0, 0, 0, 0, 320, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 268, 0, 0, 0, 326, 270, 0, 0, - 0, 0, 0, 422, 0, 448, 0, 0, 0, 278, + 331, 332, 333, 334, 335, 0, 0, 0, 0, 0, + 0, 0, 20, 0, 407, 274, 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, 330, 331, 332, 333, 334, - 0, 0, 0, 0, 0, 0, 0, 20, 0, 406, + 0, 0, 0, 366, 387, 373, 394, 374, 395, 375, + 396, 0, 459, 458, 455, 0, 203, 0, 0, 0, + 0, 211, 0, 0, 0, 450, 69, 228, 235, 0, + 236, 0, 232, 0, 233, 253, 0, 0, 433, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 276, 0, 0, 0, 0, 262, 0, + 292, 0, 301, 0, 310, 0, 0, 0, 0, 0, + 241, 242, 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, 365, 386, 372, - 393, 373, 394, 374, 395, 0, 458, 457, 454, 0, - 203, 0, 0, 0, 0, 211, 0, 0, 0, 449, - 69, 228, 235, 0, 236, 0, 232, 0, 233, 253, - 0, 0, 432, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 275, 0, 0, - 0, 0, 262, 0, 291, 0, 300, 0, 309, 0, - 0, 0, 0, 0, 241, 242, 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, 419, 409, 71, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 418, 408, 71, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 221, 0, 0, 222, 0, + 453, 0, 240, 251, 440, 0, 0, 325, 244, 246, + 0, 0, 0, 324, 326, 252, 229, 239, 250, 254, + 0, 0, 0, 418, 0, 417, 0, 0, 289, 0, + 0, 298, 0, 0, 307, 0, 264, 265, 266, 0, + 0, 423, 0, 426, 0, 0, 0, 0, 447, 0, + 281, 280, 0, 0, 0, 0, 0, 23, 0, 32, + 0, 36, 0, 30, 0, 0, 35, 0, 40, 38, + 0, 0, 0, 0, 0, 0, 47, 0, 0, 0, + 0, 0, 52, 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, 221, - 0, 0, 222, 0, 452, 0, 240, 251, 439, 0, - 0, 324, 244, 246, 0, 0, 0, 323, 325, 252, - 229, 239, 250, 254, 0, 0, 0, 417, 0, 416, - 0, 0, 288, 0, 0, 297, 0, 0, 306, 0, - 264, 265, 266, 0, 0, 422, 0, 425, 0, 0, - 0, 0, 446, 0, 280, 279, 0, 0, 0, 0, - 0, 23, 0, 32, 0, 36, 0, 30, 0, 0, - 35, 0, 40, 38, 0, 0, 0, 0, 0, 0, - 47, 0, 0, 0, 0, 0, 52, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 212, 217, 219, 0, 225, 0, 237, 441, + 0, 0, 323, 322, 226, 227, 262, 0, 258, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 425, 0, + 424, 0, 0, 0, 0, 0, 0, 0, 423, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 212, 217, 219, 0, - 225, 0, 237, 440, 0, 0, 322, 321, 226, 227, - 262, 0, 258, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 424, 0, 423, 0, 0, 0, 0, 0, - 0, 0, 422, 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, 459, - 0, 450, 0, 0, 0, 0, 415, 0, 0, 0, - 0, 0, 0, 0, 0, 315, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 426, 0, 0, 445, 281, - 0, 0, 37, 0, 0, 0, 0, 27, 0, 33, - 0, 39, 28, 41, 0, 44, 0, 48, 49, 0, - 0, 51, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 460, 0, 451, 0, 0, + 0, 0, 416, 0, 0, 0, 0, 0, 0, 0, + 0, 316, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 427, 0, 0, 446, 282, 0, 0, 37, 0, + 0, 0, 0, 27, 0, 33, 0, 39, 28, 41, + 0, 44, 0, 48, 49, 0, 0, 51, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 223, 0, 0, 256, 0, 0, 293, 0, 319, 0, - 0, 316, 302, 0, 0, 311, 0, 0, 0, 0, - 0, 0, 243, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 101, 105, 109, + 0, 0, 0, 0, 0, 0, 223, 0, 0, 256, + 0, 0, 294, 0, 320, 0, 0, 317, 303, 0, + 0, 312, 0, 0, 0, 0, 0, 0, 243, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 101, 105, 109, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 197, 0, 0, 0, 414, 289, 0, 0, 0, - 292, 298, 0, 0, 301, 307, 0, 0, 310, 230, - 234, 0, 0, 245, 0, 0, 0, 0, 0, 31, - 34, 42, 0, 43, 50, 45, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 197, 0, 0, + 0, 415, 290, 0, 0, 0, 293, 299, 0, 0, + 302, 308, 0, 0, 311, 230, 234, 0, 0, 245, + 0, 0, 0, 0, 0, 31, 34, 42, 0, 43, + 50, 45, 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, 295, 0, 0, 304, - 0, 313, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 296, 0, 0, 305, 0, 314, 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, 201, 0, 247, 0, - 290, 0, 0, 0, 299, 0, 0, 308, 0, 0, - 0, 0, 0, 0, 26, 29, 0, 0, 0, 99, - 0, 103, 0, 107, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 195, 0, 0, 0, + 0, 0, 201, 0, 247, 0, 291, 0, 0, 0, + 300, 0, 0, 309, 0, 0, 0, 0, 0, 0, + 26, 29, 0, 0, 0, 99, 0, 103, 0, 107, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 195, 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, 294, 0, 0, 318, 303, - 0, 312, 0, 0, 0, 0, 0, 0, 46, 22, - 100, 102, 104, 106, 108, 110, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 196, 198, 0, - 199, 238, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 113, 117, 121, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 296, 317, 305, 314, 0, 0, + 0, 295, 0, 0, 319, 304, 0, 313, 0, 0, + 0, 0, 0, 0, 46, 22, 100, 102, 104, 106, + 108, 110, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 196, 198, 0, 199, 238, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 113, 117, 121, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 200, 202, 0, 0, 8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 297, 318, 306, 315, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 249, 0, 0, 0, 111, 0, 115, - 0, 119, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 200, 202, 0, 0, 8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 249, + 0, 0, 0, 111, 0, 115, 0, 119, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 248, 0, 24, - 112, 114, 116, 118, 120, 122, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 125, 129, 133, 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, 248, 0, 24, 112, 114, 116, 118, + 120, 122, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 125, 129, 133, 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, 123, 0, 127, 0, 131, 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, 123, + 0, 127, 0, 131, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 124, 126, 128, 130, - 132, 134, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 137, 141, - 145, 149, 153, 157, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 25, 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, 135, 0, 139, 0, 143, - 0, 147, 0, 151, 0, 155, 0, 0, 0, 0, + 0, 0, 124, 126, 128, 130, 132, 134, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 137, 141, 145, 149, 153, 157, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 25, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 136, 138, 140, 142, - 144, 146, 148, 150, 152, 154, 156, 158, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 185, 189, 193, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 135, 0, 139, 0, 143, 0, 147, 0, 151, + 0, 155, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 183, 0, 187, 0, 191, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 184, 186, 188, 190, 192, 194, - 0, 0, 0, 173, 177, 181, 0, 0, 0, 0, + 0, 0, 136, 138, 140, 142, 144, 146, 148, 150, + 152, 154, 156, 158, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 185, + 189, 193, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 171, 0, 175, 0, 179, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 172, - 174, 176, 178, 180, 182, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 183, 0, 187, + 0, 191, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 161, 165, 169, 0, 0, 0, 0, - 0, 0, 0, 159, 0, 163, 0, 167, 0, 0, - 0, 0, 0, 0, 160, 162, 164, 166, 168, 170, - 0, 0, 0 + 184, 186, 188, 190, 192, 194, 0, 0, 0, 173, + 177, 181, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 171, 0, + 175, 0, 179, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 172, 174, 176, 178, 180, + 182, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 161, + 165, 169, 0, 0, 0, 0, 0, 0, 0, 159, + 0, 163, 0, 167, 0, 0, 0, 0, 0, 0, + 160, 162, 164, 166, 168, 170, 0, 0, 0 }; -static const short yydefgoto[] = { 2291, +static const short yydefgoto[] = { 2297, 83, 5, 6, 19, 20, 21, 22, 7, 67, 68, - 69, 423, 1609, 634, 1518, 1611, 635, 1519, 1613, 636, - 1520, 1827, 637, 1774, 1829, 638, 1775, 1831, 639, 1776, - 1963, 640, 1925, 1965, 641, 1926, 1967, 642, 1927, 2075, - 643, 2045, 2077, 644, 2046, 2079, 645, 2047, 2081, 646, - 2048, 2083, 647, 2049, 2085, 648, 2050, 2273, 649, 2267, - 2275, 650, 2268, 2277, 651, 2269, 2222, 652, 2210, 2224, - 653, 2211, 2226, 654, 2212, 2171, 655, 2153, 2173, 656, - 2154, 2175, 657, 2155, 1636, 658, 1542, 1730, 659, 1638, - 136, 240, 70, 549, 330, 536, 537, 331, 74, 75, - 76, 77, 332, 1174, 1488, 1592, 1177, 1493, 1596, 1180, - 1497, 1599, 1355, 1356, 79, 80, 961, 333, 139, 351, - 172, 235, 416, 1070, 1187, 1188, 335, 476, 194, 720, - 872, 140 + 69, 424, 1615, 636, 1524, 1617, 637, 1525, 1619, 638, + 1526, 1833, 639, 1780, 1835, 640, 1781, 1837, 641, 1782, + 1969, 642, 1931, 1971, 643, 1932, 1973, 644, 1933, 2081, + 645, 2051, 2083, 646, 2052, 2085, 647, 2053, 2087, 648, + 2054, 2089, 649, 2055, 2091, 650, 2056, 2279, 651, 2273, + 2281, 652, 2274, 2283, 653, 2275, 2228, 654, 2216, 2230, + 655, 2217, 2232, 656, 2218, 2177, 657, 2159, 2179, 658, + 2160, 2181, 659, 2161, 1642, 660, 1548, 1736, 661, 1644, + 136, 240, 70, 551, 331, 538, 539, 332, 74, 75, + 76, 77, 333, 1180, 1494, 1598, 1183, 1499, 1602, 1186, + 1503, 1605, 1361, 1362, 79, 80, 966, 334, 139, 352, + 172, 235, 417, 1076, 1193, 1194, 336, 478, 194, 723, + 877, 140 }; -static const short yypact[] = { 2645, - 58,-32768,-32768, -92,-32768, 269, 2925,-32768, 19, 77, - 108, 122, 130, 145, 173, 14, 24, 67,-32768,-32768, --32768,-32768, 2312, 98, 188, 101, 117, 141, -37, 280, - 161, 171, 313, 178, 345, 362, 406, 410, 566, 428, - 148, 263, 279, -76, -76, 284, 433, 5, 446, 7, - 498, 512, 74, 329, 332, -19, 9, 10,-32768, 350, --32768, 548,-32768, 560, 614, 528,-32768,-32768,-32768,-32768, +static const short yypact[] = { 2657, + 47,-32768,-32768, -107,-32768, 265, 3018,-32768, 9, 61, + 57, 65, 70, 75, 89, -91, -28, -15,-32768,-32768, +-32768,-32768, 2357, 72, 122, 77, 115, 135, -45, 128, + 141, 156, 313, 195, 159, 353, 357, 391, 52, 399, + 409, 259, 281, -98, -98, 298, 100, 6, 444, 7, + 502, 515, 154, 330, 331, -18, 10, 18,-32768, 334, +-32768, 536,-32768, 501, 550, 503,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, --32768, 659, 19, 2760,-32768,-32768,-32768,-32768,-32768, 380, - 380, 575,-32768, -36, 13,-32768,-32768,-32768,-32768, -93, - 197, 241, 349, 379, 384, 414, 418, 419, 422, 426, - 427, 430, 431, 434, 435, 468, 469, 472, 473, 488, - 451, 476, 477,-32768,-32768,-32768,-32768, 2547, 2547, 2547, --32768,-32768, 2547, 946, 26, 2547, 674, 650,-32768, 678, - 682,-32768, 2547, 2547, 2547, 544, 2547, 561, 2547, 2547, - 574, 2547, 517, 565, 573, 628, 574, 529, 547, 634, - 647, 676, 686, 687, 725, -76, -76, -76, 2547, 2547, - -106,-32768, -32, -76, 579, 653, 669, 570,-32768, 574, - 690, 887,-32768,-32768,-32768, 574, 574, 2547, 2547, -57, - 2547, 704, 2547, 708, 802, 2547, 2547,-32768, 905,-32768, - 717,-32768, 19, 733, 734, 735, 736, 737, 740, 741, - 742, 743, 744, 745, 746, 747, 748, 749, 751, 752, - 756, 757, 759, 784, 786, 787, 788, 789, 790, 791, - 792, 793, 810, 929, 806, 811, 808, 2547, 1005,-32768, - -76,-32768, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 57, 54, 54, 817, 817, 817, - 10646, 1006, 2359, 9971, 25, 813, 1007, 675,-32768,-32768, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547,-32768, -125, 10669, 10692, 10715, - 2547, 10738, 2547, 10761, 10784, 252, 819, 1488, 2359,-32768, --32768,-32768, 1765, 1011,-32768, 10807, 2547, 2547, 2547, 2547, - 1014, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 826, 0, --32768,-32768, 3419, 3440, -76, -76, 471, 471, 144, 2547, - 2547, 2547, 2547, -1, 270, 2547,-32768, 2014, 1016, 1017, - 10830, 10853, 925, 2547, 10876, 926, 3461,-32768, 829, 1812, - 10899,-32768, 2547, 866, 1028, 1029, 1030, 1031, 1032, 1033, - 1034, 1037, 1038, 1039, 1040, 1041, 1042, 1044, 1048, 1049, - 1051, 1052, 1053, 1054, 1055, 1056, 1057, 909, 1059, 1061, - 1062, 1063, 1066, 1065,-32768, -120, 1070, 1071, 1073, 9996, - 346, -2, 2754, 10922, 10021, 10945, 10046, 10968, 10071, 10991, - 10096, 11014, 10121, 11037, 10146, 11060, 10171, 11083, 10196, 11106, - 10221, 11129, 10246, 11152, 10271, 3482, 3503, 11175, 10296, 11198, - 10321, 11221, 10346, 11244, 10371, 11267, 10396, 11290, 10421, 3524, - 3545, 3566, 3587, 3608, 3629, 204,-32768, 320, 871, 880, --32768, 574, 2610, 1765,-32768, 490, 262, 54, 2547, 1074, - 1077, 17,-32768, 2087, 243, 282, 692, 692, 327, 327, - 327, 327, -44, -44, 817, 817, 817, 817, 1076, 2359, - 1078, 1079, 1111, 11313, 1122, 11336, 1125, 1127, 1171, 2547, - 308, 2359, 491, 2547, 2547, 1128, 2896, 11359, 11382, 11405, - 2547, 2932, 2955, 11428, 11451, 11474, 11497, 11520, 885, -76, - 2547, 2547,-32768,-32768,-32768, 935, 3005,-32768, 936, 2547, - 3650, 3671, 3692, 10446, -127, -41, -30,-32768,-32768,-32768, - 2547, 10471,-32768, 938, 941, 1133, 1136, 950, 11543, 1146, - 965, 2547, 2621, 2547, 2547,-32768, 11566, 998, 966, 967, - 970, 972, 976, 977, 978, 979, 1008, 1009, 1035, 1036, - 1046, 1050, 1060, 1067, 1069, 1072, 1075, 1080, 1082, 1083, - 1084, 1085, 1087, 1088, 1090, 1117, 1118, 1121,-32768, 1202, - 1010,-32768, 1124, 111,-32768,-32768, 1043, 1045, 1047, 1064, - 1068, 1081, 1134, 1135, 1141, 1151, 1153, 1154, 1155, 1158, - 1159, 1162, 1163, 1164, 1165, 1167, 1168, 1169, 1170, 1172, - 1173, 1175, 1228,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768, 568, 9, 2886,-32768,-32768,-32768,-32768,-32768, 380, + 380, 573,-32768, 310, 13,-32768,-32768,-32768,-32768, 140, + 217, 230, 286, 295, 309, 327, 373, 377, 386, 468, + 473, 474, 477, 488, 493, 496, 499, 500, 505, 509, + 398, 411, 417,-32768,-32768,-32768,-32768, 2558, 2558, 2558, +-32768,-32768, 2558, 1170, 25, 2558, 580, 449,-32768, 601, + 615,-32768, 2558, 2558, 2558, 433, 2558, 450, 2558, 2558, + 947, 2558, 443, 456, 469, 478, 947, 466, 481, 492, + 504, 522, 533, 553, 699, -98, -98, -98, 2558, 2558, + -139,-32768, -76, -98, 546, 561, 562, 535,-32768, 947, + 554, 752,-32768,-32768,-32768, 947, 947, 2558, 2558, -62, + 2558, 571, 2558, 570, 659, 2558, 2558,-32768, 772,-32768, + 604,-32768, 9, 643, 648, 655, 664, 677, 685, 688, + 690, 691, 692, 696, 697, 698, 700, 701, 702, 703, + 704, 705, 706, 707, 708, 709, 711, 712, 713, 717, + 718, 719, 720, 825, 694, 721, 716, 2558, 914,-32768, + -98,-32768, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 56, 43, 43, 321, 725, 725, + 725, 2220, 913, 2408, 10051, 26, 722, 915, 599,-32768, +-32768, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558,-32768, -81, 10751, 10774, + 10797, 2558, 10820, 2558, 10843, 10866, 388, 728, 2265, 2408, +-32768,-32768,-32768, 472, 932,-32768, 10889, 2558, 2558, 2558, + 2558, 933, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 745, + -111,-32768,-32768, 3499, 3520, -98, -98, 557, 557, -36, + 2558, 2558, 2558, 2558, 2020, 155, 2558,-32768, 2763, 935, + 936, 10912, 10935, 842, 2558, 10958, 841, 3541,-32768, 746, + 1633, 10981,-32768, 2558, 782, 944, 949, 975, 976, 977, + 978, 979, 981, 984, 985, 986, 987, 988, 989, 991, + 992, 993, 994, 995, 997, 998, 999, 1000, 798, 1007, + 1008, 1009, 1010, 1013, 1012,-32768, 98, 1014, 1018, 1015, + 10076, 174, -67, 2557, 11004, 10101, 11027, 10126, 11050, 10151, + 11073, 10176, 11096, 10201, 11119, 10226, 11142, 10251, 11165, 10276, + 11188, 10301, 11211, 10326, 11234, 10351, 3562, 3583, 11257, 10376, + 11280, 10401, 11303, 10426, 11326, 10451, 11349, 10476, 11372, 10501, + 3604, 3625, 3646, 3667, 3688, 3709, 192,-32768, 109, 787, + 822, 2558,-32768, 947, 2596, 472,-32768, 285, 11, 43, + 2558, 1020, 1023, 15,-32768, 1688, 194, 379, 352, 352, + 275, 275, 275, 275, 361, 361, 725, 725, 725, 725, + 1022, 2408, 1027, 1029, 1030, 11395, 1031, 11418, 1032, 1033, + 1200, 2558, 412, 2408, 507, 2558, 2558, 1034, 1300, 11441, + 11464, 11487, 2558, 3026, 3049, 11510, 11533, 11556, 11579, 11602, + 830, -98, 2558, 2558,-32768,-32768,-32768, 828, 3099,-32768, + 840, 2558, 3730, 3751, 3772, 10526, -152, -44, -42,-32768, +-32768,-32768, 2558, 10551,-32768, 843, 844, 1036, 1041, 854, + 11625, 1044, 853, 2558, 2800, 2558, 2558,-32768, 11648, 886, + 855, 857, 859, 860, 862, 863, 864, 865, 867, 868, + 869, 870, 872, 873, 874, 875, 876, 877, 881, 882, + 883, 884, 887, 888, 890, 891, 892, 919, 920, 921, +-32768, 1081, 926,-32768, 923, 151,-32768,-32768, 929, 930, + 931, 934, 938, 940, 941, 943, 945, 946, 948, 950, + 951, 952, 954, 955, 956, 958, 959, 960, 966, 983, + 1011, 1038, 1055, 1057, 1121,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, --32768, 2547, 2547,-32768,-32768,-32768,-32768,-32768,-32768,-32768, --32768,-32768,-32768,-32768,-32768, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 1233,-32768, 2359, 54,-32768, 1235, 2359, 1058, - 43, 2547, 1238, 1242, 714,-32768, 1232, 1131, 9, 1246, - 2547,-32768, 323, -76, 574, 574, 1247, 574, 1254, 574, - 574,-32768, 2359, 2986, 1201, 494,-32768, 2115, 739, 1174, - 1255, 1258, 1263, 1264, 467, 1267, 1270, 1271, 1272, 1315, - 1345, 1364, 1369, 150, 3713, 3734,-32768,-32768, 3009, -76, - -76, -76, 1368, 2359, 2359, 2359, 816, 1370, 2547, 2547, - 574, 574, 2547, 1371, 574, 1373, 3755,-32768, 2286, 375, - 1372, 1217, 1378, 2547, 2547, -76, 1379, 1380, 1198, 1384, - 1385, 574, 574, 1386, -76, 1387, 1389, 574, 574, 1390, - 1391, 1392, 1394, 1395, 574, 372, 574, 1397, 1396, 1398, - 1401, 1403,-32768, 1402, 380, 1405,-32768, 2780, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547,-32768, 11589, 10496, 11612, 10521, 11635, - 10546, 11658, 10571, 10596, 1211, 340, 1214,-32768, 1765,-32768, - 160, 311, 1213, 1406, 939,-32768,-32768,-32768, 9, 2547, --32768, 497,-32768, 12509, 1410, 81, 51, 1412, 574, 1413, - 574, 1415, 1416, 501,-32768,-32768, 2359,-32768, 2547,-32768, - 2547, 574, 574, 574, 1229,-32768, 583, 574, 574, 574, - 574, 574, 574, 574, 651, 2547, 2547, 2547, 1222, -119, - -99, -67,-32768, 502, 505, 506,-32768,-32768, 3776, 3797, - 1419, 1420, 11681, -61, 1323,-32768, 2547, 2547, 2547,-32768, - 1227, 19, 1230, 3818, 3839, 206, 1231, 1236, 1237, 1239, - 1259, 1240, 1266, 1276, 294, 1277, 1282, 1283, 1284, 1285, - 1286, 1288, 1290, 1293, 1298,-32768,-32768,-32768,-32768,-32768, - 1295, 1321, 1322, 1324, 1325, 1327, 1326,-32768, 1328, 346, - 1423, 3860, 3881, 3902, 3923, 3944, 3965, 3986, 4007, 4028, - 4049, 4070, 4091, 4112, 4133, 4154, 4175, 4196, 4217, 4238, - 4259, 4280, 4301, 4322, 4343, 4364, 4385,-32768,-32768,-32768, --32768,-32768,-32768,-32768,-32768, 1234,-32768,-32768,-32768, 574, - 54, 2547, 1476, 1479, 17,-32768, 1521, 10621, 9,-32768, --32768,-32768,-32768, -76,-32768, 1523,-32768, 1524,-32768,-32768, - 1333, 511, 12509, 4406, 1526, 1527, 1528, 2547, 2547, 2547, - 1529, 1530, 1531, 1532, 1557, 1558, 1559,-32768, 2422, 3032, - 11704, 1287, 471, -76, 1560, -76, 1561, -76, 1562, 1563, - 1564, 1565, 2547, 2547,-32768,-32768, 1567, 574, 574, 1471, - 574, 2353, 194, 11727, 2547, 19, 1573, 2547, 574, 1601, - 1614, 1612, 1433, 1615, 372, 1617, 1621, 2547, 1622, 1624, - 1623, 1625, 1632, 372, 2547, 2547, 2547, 574, 1631, 1656, - 372, 2547, 1657, 1658, 1659, 2547, 380,-32768,-32768, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 1616, 1660, 1661, 974,-32768, - 1655, 1662,-32768, 1431,-32768, 90,-32768,-32768,-32768, 1465, - 2547,-32768,-32768,-32768, 4427, 1157, 1428,-32768,-32768,-32768, --32768,-32768,-32768,-32768, 1627, 1663, 1473,-32768, 2547,-32768, - 1474, 157,-32768, 1478, 162,-32768, 1480, 164,-32768, 1481, --32768,-32768,-32768, 4448, 4469, -61, 347,-32768, 514, 1483, - 1574, 2547,-32768, 2547,-32768,-32768, 4490, 19, 1484, 4511, - 1477,-32768, 1485,-32768, 1486,-32768, 1492,-32768, 1490, 11750, --32768, 1491,-32768,-32768, 1496, 1498, 11773, 4532, 11796, 1495, --32768, 1500, 1501, 4553, 1502, 1505,-32768, 4574, 1503, 4595, - 4616, 4637, 4658, 4679, 4700, 4721, 4742, 4763, 4784, 4805, - 4826, 4847, 4868, 4889, 4910, 4931, 4952, 4973, 4994, 5015, - 5036, 5057, 5078, 5099, 5120, 1508,-32768,-32768,-32768, 9, --32768, 1592,-32768,-32768, 5141, 2547,-32768,-32768,-32768,-32768, - 471, 2826,-32768, 1569, 292, 1569, 292, 1569, 292, 2547, - 2547, 1602,-32768, 574,-32768, 574, 2547, 3055, 3084, 574, - 1542, 1701, -61, 372, 1705, 2547, 1703, 372, 1704, 1708, - 1706, 1707, 1710, 2547, 1711, 574, 1712, 1713, 2547, 1717, - 1715, 2547, 1735, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547,-32768, - 1736,-32768, 1738, 11819, 1539, 2547,-32768, 1569, 1569, 2547, - 3107, 200, 1739, 1543, -40,-32768, 3140, 213, -15, 3169, - 257, -11, 3192, 3215, 1545,-32768, 1547, 1681,-32768,-32768, - 1546, 19,-32768, 1549, 1550, 1551, 5162,-32768, 1556,-32768, - 1566,-32768,-32768,-32768, 11842,-32768, 1555,-32768,-32768, 11865, - 1570,-32768, 11888, 1568, 11911, 11934, 11957, 5183, 5204, 5225, - 5246, 5267, 5288, 5309, 5330, 5351, 5372, 5393, 5414, 5435, - 5456, 5477, 5498, 5519, 5540, 5561, 5582, 5603, 11980, 5624, --32768, 1571, 574,-32768, 3245, 3392, 1750, 2547,-32768, 574, - 1751,-32768, 1752, 2547, 1754, 1755, 2547, 1757, 1759, 1761, - 574, 574,-32768, 1763, 19, 372, 372, 372, 372, 1766, - 1769, 1770, 372, 1771, 1772, 1794, 1801,-32768,-32768,-32768, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547,-32768, 2547, 1811, 574,-32768,-32768, 1618, 3277, 1626, --32768,-32768, 1628, 3300,-32768,-32768, 1629, 3323,-32768,-32768, --32768, 1634, 1620,-32768, 19, 1636, 1670, 1664, 1675,-32768, --32768,-32768, 1672,-32768,-32768,-32768, 1673, 1676, 1677, 1678, - 5645, 5666, 5687, 5708, 5729, 5750, 5771, 5792, 5813, 5834, - 5855, 5876, 5897, 5918, 5939, 5960, 5981, 6002, 6023, 6044, - 6065, 1679, 12003, 1674, 1817, 292, 1818, 574, 292, 1819, - 292, 1821, 574, 1716, 1665, 372, 372, 1826, 1870, 372, - 1813, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 54,-32768, 1876,-32768, 1, --32768, 1682, 515, 11,-32768, 1683, 93,-32768, 1684, 1680, - 1700, 19, 1702, 1709,-32768,-32768, 1714, 1718, 519, 12509, - 522, 12509, 523, 12509, 6086, 6107, 6128, 6149, 6170, 6191, - 6212, 6233, 6254, 6275, 6296, 6317, 6338, 6359, 6380, 6401, - 6422, 6443, 6464, 6485, 6506, 526,-32768, 1719, 1742, 1897, - 292, 574, 1898, 1899, 292, 1900, 292, 1806, 2547, 19, - 372, 574, 1902, 1905, 2547, 1906, 2547, 1907, 2547, 1909, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 54, 1910, 54, 1911,-32768, 106, 1753,-32768,-32768, - 109,-32768, 238, 1756, 6527, 19, 1758, 1760,-32768,-32768, - 12509,-32768, 12509,-32768, 12509,-32768, 12026, 12049, 12072, 6548, - 6569, 6590, 6611, 6632, 6653, 6674, 6695, 6716, 6737, 6758, - 6779, 6800, 6821, 6842, 6863, 6884, 6905,-32768,-32768, 534, --32768,-32768, 1912, 1913, 1948, 1950, 2547, 2547, 1793, 372, - 574,-32768,-32768,-32768, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 54, 1957,-32768,-32768,-32768,-32768, 6926, 3346, - 1796, 1767, 1783, 1790, 1800, 1802, 6947, 6968, 6989, 7010, - 7031, 7052, 7073, 7094, 7115, 7136, 7157, 7178, 7199, 7220, - 7241, 7262, 7283, 7304,-32768,-32768, 2547, 1978,-32768, 574, - 372, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 3369,-32768, 1804, 1809, 535, 12509, 538, 12509, - 549, 12509, 7325, 7346, 7367, 7388, 7409, 7430, 7451, 7472, - 7493, 7514, 7535, 7556, 7577, 7598, 7619, 7640, 7661, 7682, - 1996, 574, 2001, 2547, 2002, 2547, 2003, 2547, 2004, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547,-32768, 1822,-32768, - 12509,-32768, 12509,-32768, 12509,-32768, 12095, 12118, 12141, 7703, - 7724, 7745, 7766, 7787, 7808, 7829, 7850, 7871, 7892, 7913, - 7934, 7955, 7976, 7997, 574,-32768,-32768,-32768, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 1823, 1810, 1820, 1824, 8018, 8039, 8060, - 8081, 8102, 8123, 8144, 8165, 8186, 8207, 8228, 8249, 8270, - 8291, 8312, 574, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 1827, 552, 12509, 553, 12509, 563, 12509, 8333, 8354, - 8375, 8396, 8417, 8438, 8459, 8480, 8501, 8522, 8543, 8564, - 8585, 8606, 8627, 372, 2547, 2018, 2547, 2020, 2547, 2022, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 1833, 12509,-32768, 12509,-32768, - 12509,-32768, 12164, 12187, 12210, 12233, 12256, 12279, 8648, 8669, - 8690, 8711, 8732, 8753, 8774, 8795, 8816, 2024,-32768,-32768, --32768,-32768,-32768,-32768, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547,-32768, 1830, 1831, 1832, 1834, 1835, 1859, - 8837, 8858, 8879, 8900, 8921, 8942, 8963, 8984, 9005, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 571, 12509, 572, 12509, 576, 12509, - 577, 12509, 581, 12509, 584, 12509, 9026, 9047, 9068, 9089, - 9110, 9131, 9152, 9173, 9194, 2547, 2028, 2547, 2056, 2547, - 2060, 2547, 2063, 2547, 2064, 2547, 2065, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 2547, 2547, 12509,-32768, 12509,-32768, - 12509,-32768, 12509,-32768, 12509,-32768, 12509,-32768, 9215, 9236, - 9257, 9278, 9299, 9320, 12302, 12325, 12348, 2547, 2547, 2547, - 2547, 2547, 2547,-32768,-32768,-32768, 9341, 9362, 9383, 9404, - 9425, 9446, 1871, 1873, 1875, 2547, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2547, 9467, 9488, 9509, 9530, 9551, 9572, - 585, 12509, 588, 12509, 589, 12509, 2547, 2547, 2547, 2547, - 2547, 2547, 2547, 2072, 2547, 2074, 2547, 2076, 9593, 9614, - 9635, 12371, 12394, 12417, 12509,-32768, 12509,-32768, 12509,-32768, - 2547, 2547, 2547,-32768,-32768,-32768, 9656, 9677, 9698, 1893, - 1895, 1896, 2547, 2547, 2547, 2547, 2547, 2547, 9719, 9740, - 9761, 592, 12509, 593, 12509, 639, 12509, 2547, 2547, 2547, - 2547, 2092, 2547, 2093, 2547, 2094, 9782, 9803, 9824, 12509, --32768, 12509,-32768, 12509,-32768, 2547, 2547, 2547, 9845, 9866, - 9887, 2547, 2547, 2547, 9908, 9929, 9950, 2547, 2547, 2547, - 12440, 12463, 12486,-32768,-32768,-32768, 1901, 1903, 1904, 2547, - 2547, 2547, 643, 12509, 646, 12509, 665, 12509, 2547, 2095, - 2547, 2097, 2547, 2100, 12509,-32768, 12509,-32768, 12509,-32768, - 2107, 2108,-32768 +-32768,-32768,-32768, 2558, 2558,-32768,-32768,-32768,-32768,-32768, +-32768,-32768,-32768,-32768,-32768,-32768,-32768, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 1124,-32768, 2408, 43,-32768, 10576, + 1133, 2408, 973, 30, 2558, 1138, 1199, 680,-32768, 1123, + 1042, 10, 1201, 2558,-32768, 112, -98, 947, 947, 1249, + 947, 1251, 947, 947,-32768, 2408, 3082, 1497, 508,-32768, + 1771, 750, 1059, 1255, 1258, 1259, 1260, 290, 1261, 1262, + 1264, 1266, 1268, 1269, 1270, 1204, -31, 3793, 3814,-32768, +-32768, 3111, -98, -98, -98, 1272, 2408, 2408, 2408, 982, + 1274, 2558, 2558, 947, 947, 2558, 1275, 947, 1277, 3835, +-32768, 1815, 414, 1276, 1122, 1281, 2558, 2558, -98, 1283, + 1285, 1103, 1287, 1288, 947, 947, 1290, -98, 1291, 1293, + 947, 947, 1320, 1321, 1322, 1324, 1325, 947, 517, 947, + 1327, 1329, 1330, 1333, 1334,-32768, 1332, 380, 1335,-32768, + 1336, 2894, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558,-32768, 11671, + 10601, 11694, 10626, 11717, 10651, 11740, 10676, 10701, 1144, 168, + 1145, 224,-32768, 472,-32768, 105, 325, 1146, 1337, 1060, +-32768,-32768,-32768, 10, 2558,-32768, 512,-32768, 12591, 1341, + 20, 31, 1342, 947, 1343, 947, 1344, 1345, 516,-32768, +-32768, 2408,-32768, 2558,-32768, 2558, 947, 947, 947, 1148, +-32768, 458, 947, 947, 947, 947, 947, 947, 947, 544, + 2558, 2558, 2558, 1151, -118, -86, 129,-32768, 519, 520, + 523,-32768,-32768, 3856, 3877, 1347, 1350, 11763, -43, 1253, +-32768, 2558, 2558, 2558,-32768, 1157, 9, 1159, 3898, 3919, + -41, 1161, 1166, 1163, 1168, 1167, 1173, 1172, 1174, 201, + 1175, 1177, 1180, 1178, 1179, 1181, 1182, 1183, 1186, 1184, +-32768,-32768,-32768,-32768,-32768, 1187, 1188, 1189, 1191, 1192, + 1197, 1194,-32768, 1196, 174,-32768, 1360, 3940, 3961, 3982, + 4003, 4024, 4045, 4066, 4087, 4108, 4129, 4150, 4171, 4192, + 4213, 4234, 4255, 4276, 4297, 4318, 4339, 4360, 4381, 4402, + 4423, 4444, 4465,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768, 1171,-32768,-32768,-32768, 947, 43, 2558, 1371, 1393, + 15,-32768, 1394, 10726, 10,-32768,-32768,-32768,-32768, -98, +-32768, 1396,-32768, 1397,-32768,-32768, 1206, 524, 12591, 4486, + 1399, 1400, 1402, 2558, 2558, 2558, 1403, 1404, 1406, 1407, + 1408, 1409, 1410,-32768, 2488, 3134, 11786, 2728, 557, -98, + 1412, -98, 1415, -98, 1416, 1417, 1418, 1419, 2558, 2558, +-32768,-32768, 1392, 947, 947, 1323, 947, 2761, 254, 11809, + 2558, 9, 1423, 2558, 947, 1422, 1426, 1424, 1245, 1428, + 517, 1429, 1433, 2558, 1431, 1435, 1434, 1436, 1438, 517, + 2558, 2558, 2558, 947, 1437, 1462, 517, 2558, 1464, 1465, + 1463, 2558, 380,-32768,-32768, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 1466, 1467, 1483, 1427,-32768, 1425, 1484,-32768, 1240, +-32768, 79,-32768,-32768,-32768, 1273, 2558,-32768,-32768,-32768, + 4507, 1491, 1525,-32768,-32768,-32768,-32768,-32768,-32768,-32768, + 1572, 1485, 1271,-32768, 2558,-32768, 1294, 119,-32768, 1292, + 149,-32768, 1297, 162,-32768, 1298,-32768,-32768,-32768, 4528, + 4549, -43, 187,-32768, 527, 1303, 1391, 2558,-32768, 2558, +-32768,-32768, 4570, 9, 1299, 4591, 1338,-32768, 1339,-32768, + 1340,-32768, 1346,-32768, 1369, 11832,-32768, 1370,-32768,-32768, + 1348, 1375, 11855, 4612, 11878, 1372,-32768, 1377, 1378, 4633, + 1379, 1381,-32768, 4654, 1380, 4675, 4696, 4717, 4738, 4759, + 4780, 4801, 4822, 4843, 4864, 4885, 4906, 4927, 4948, 4969, + 4990, 5011, 5032, 5053, 5074, 5095, 5116, 5137, 5158, 5179, + 5200, 1385,-32768,-32768,-32768, 10,-32768, 1430,-32768,-32768, + 5221, 2558,-32768,-32768,-32768,-32768, 557, 2980,-32768, 2295, + -16, 2295, -16, 2295, -16, 2558, 2558, 1439,-32768, 947, +-32768, 947, 2558, 3157, 3187, 947, 1367, 1526, -43, 517, + 1530, 2558, 1528, 517, 1529, 1534, 1535, 1569, 1576, 2558, + 1577, 947, 1579, 1580, 2558, 1584, 1582, 2558, 1585, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558,-32768, 1583,-32768, 1586, 11901, + 1390, 2558,-32768, 2295, 2295, 2558, 3219, 173, 1588, 1395, + -39,-32768, 3242, 209, -30, 3265, 226, -27, 3288, 3311, + 1398,-32768, 1420, 1587,-32768,-32768, 1414, 9,-32768, 1443, + 1480, 1486, 5242,-32768, 1401,-32768, 1421,-32768,-32768,-32768, + 11924,-32768, 1488,-32768,-32768, 11947, 1432,-32768, 11970, 1489, + 11993, 12016, 12039, 5263, 5284, 5305, 5326, 5347, 5368, 5389, + 5410, 5431, 5452, 5473, 5494, 5515, 5536, 5557, 5578, 5599, + 5620, 5641, 5662, 5683, 12062, 5704,-32768, 1490, 947,-32768, + 3334, 3472, 1589, 2558,-32768, 947, 1592,-32768, 1612, 2558, + 1613, 1616, 2558, 1617, 1619, 1620, 947, 947,-32768, 1621, + 9, 517, 517, 517, 517, 1624, 1625, 1627, 517, 1628, + 1631, 1677, 1634,-32768,-32768,-32768, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558,-32768, 2558, 1679, + 947,-32768,-32768, 1492, 3357, 1494,-32768,-32768, 1496, 3380, +-32768,-32768, 1503, 3403,-32768,-32768,-32768, 1514, 1513,-32768, + 9, 1516, 1517, 1495, 1522,-32768,-32768,-32768, 1523,-32768, +-32768,-32768, 1524, 1521, 1550, 1575, 5725, 5746, 5767, 5788, + 5809, 5830, 5851, 5872, 5893, 5914, 5935, 5956, 5977, 5998, + 6019, 6040, 6061, 6082, 6103, 6124, 6145, 1581, 12085, 1527, + 1719, -16, 1720, 947, -16, 1772, -16, 1777, 947, 1676, + 1643, 517, 517, 1778, 1806, 517, 1817, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 43,-32768, 1819,-32768, -24,-32768, 1629, 531, -14, +-32768, 1630, -12,-32768, 1632, 1623, 1635, 9, 1626, 1638, +-32768,-32768, 1636, 1639, 537, 12591, 540, 12591, 541, 12591, + 6166, 6187, 6208, 6229, 6250, 6271, 6292, 6313, 6334, 6355, + 6376, 6397, 6418, 6439, 6460, 6481, 6502, 6523, 6544, 6565, + 6586, 552,-32768, 1641, 1659, 1822, -16, 947, 1823, 1828, + -16, 1834, -16, 1766, 2558, 9, 517, 947, 1871, 1872, + 2558, 1873, 2558, 1874, 2558, 1875, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 43, 1877, 43, + 1878,-32768, -2, 1683,-32768,-32768, 4,-32768, 17, 1685, + 6607, 9, 1687, 1689,-32768,-32768, 12591,-32768, 12591,-32768, + 12591,-32768, 12108, 12131, 12154, 6628, 6649, 6670, 6691, 6712, + 6733, 6754, 6775, 6796, 6817, 6838, 6859, 6880, 6901, 6922, + 6943, 6964, 6985,-32768,-32768, 555,-32768,-32768, 1882, 1884, + 1885, 1901, 2558, 2558, 1740, 517, 947,-32768,-32768,-32768, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 43, 1903, +-32768,-32768,-32768,-32768, 7006, 3426, 1741, 1711, 1712, 1713, + 1714, 1715, 7027, 7048, 7069, 7090, 7111, 7132, 7153, 7174, + 7195, 7216, 7237, 7258, 7279, 7300, 7321, 7342, 7363, 7384, +-32768,-32768, 2558, 1907,-32768, 947, 517, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 3449,-32768, + 1717, 1722, 559, 12591, 566, 12591, 588, 12591, 7405, 7426, + 7447, 7468, 7489, 7510, 7531, 7552, 7573, 7594, 7615, 7636, + 7657, 7678, 7699, 7720, 7741, 7762, 1913, 947, 1914, 2558, + 1915, 2558, 1916, 2558, 1918, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558,-32768, 1725,-32768, 12591,-32768, 12591,-32768, + 12591,-32768, 12177, 12200, 12223, 7783, 7804, 7825, 7846, 7867, + 7888, 7909, 7930, 7951, 7972, 7993, 8014, 8035, 8056, 8077, + 947,-32768,-32768,-32768, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 1726, + 1749, 1759, 1760, 8098, 8119, 8140, 8161, 8182, 8203, 8224, + 8245, 8266, 8287, 8308, 8329, 8350, 8371, 8392, 947, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 1762, 589, 12591, + 592, 12591, 595, 12591, 8413, 8434, 8455, 8476, 8497, 8518, + 8539, 8560, 8581, 8602, 8623, 8644, 8665, 8686, 8707, 517, + 2558, 1957, 2558, 1958, 2558, 1960, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 1773, 12591,-32768, 12591,-32768, 12591,-32768, 12246, 12269, + 12292, 12315, 12338, 12361, 8728, 8749, 8770, 8791, 8812, 8833, + 8854, 8875, 8896, 1961,-32768,-32768,-32768,-32768,-32768,-32768, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558,-32768, + 1770, 1793, 1803, 1804, 1805, 1807, 8917, 8938, 8959, 8980, + 9001, 9022, 9043, 9064, 9085, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 596, 12591, 626, 12591, 627, 12591, 631, 12591, 634, 12591, + 635, 12591, 9106, 9127, 9148, 9169, 9190, 9211, 9232, 9253, + 9274, 2558, 1967, 2558, 2001, 2558, 2004, 2558, 2005, 2558, + 2006, 2558, 2007, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 2558, 2558, 12591,-32768, 12591,-32768, 12591,-32768, 12591,-32768, + 12591,-32768, 12591,-32768, 9295, 9316, 9337, 9358, 9379, 9400, + 12384, 12407, 12430, 2558, 2558, 2558, 2558, 2558, 2558,-32768, +-32768,-32768, 9421, 9442, 9463, 9484, 9505, 9526, 1813, 1814, + 1816, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2558, + 9547, 9568, 9589, 9610, 9631, 9652, 639, 12591, 642, 12591, + 646, 12591, 2558, 2558, 2558, 2558, 2558, 2558, 2558, 2010, + 2558, 2021, 2558, 2022, 9673, 9694, 9715, 12453, 12476, 12499, + 12591,-32768, 12591,-32768, 12591,-32768, 2558, 2558, 2558,-32768, +-32768,-32768, 9736, 9757, 9778, 1829, 1830, 1831, 2558, 2558, + 2558, 2558, 2558, 2558, 9799, 9820, 9841, 647, 12591, 651, + 12591, 675, 12591, 2558, 2558, 2558, 2558, 2023, 2558, 2027, + 2558, 2028, 9862, 9883, 9904, 12591,-32768, 12591,-32768, 12591, +-32768, 2558, 2558, 2558, 9925, 9946, 9967, 2558, 2558, 2558, + 9988, 10009, 10030, 2558, 2558, 2558, 12522, 12545, 12568,-32768, +-32768,-32768, 1835, 1836, 1837, 2558, 2558, 2558, 676, 12591, + 679, 12591, 682, 12591, 2558, 2029, 2558, 2033, 2558, 2034, + 12591,-32768, 12591,-32768, 12591,-32768, 2041, 2042,-32768 }; static const short yypgoto[] = {-32768, - -25,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, --32768, 1504,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, + -32,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768, 1458,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, @@ -1422,1638 +1422,1654 @@ static const short yypgoto[] = {-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, - -289, -22,-32768, 2102, -5, -353, -171, -3,-32768,-32768, --32768,-32768, 2104,-32768,-32768,-32768,-32768,-32768,-32768,-32768, --32768,-32768, -1252, -1326,-32768,-32768, -1031, -23,-32768, -29, --32768, -88,-32768, -1152, 1092, 1513, -199, -319, -712, 1106, --32768, -267 + -290, -22,-32768, 2061, -5, -354, -170, -3,-32768,-32768, +-32768,-32768, 2065,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768,-32768, -1255, -1330,-32768,-32768, -1035, -23,-32768, -29, +-32768, -88,-32768, -1167, 1001, 1449, -154, -323, -714, 1054, +-32768, -185 }; -#define YYLAST 12703 +#define YYLAST 12785 static const short yytable[] = { 138, - 137, 72, 236, 73, 539, 479, 871, 364, 178, 513, - 181, 368, 192, 195, 171, 173, 241, 468, 469, 470, - 718, 81, 190, 146, 1359, 1353, 1362, 146, 1432, 295, - 1354, 478, 1432, 1282, 148, 1432, 545, 27, 28, 546, - 547, 31, 32, 33, 373, 34, 862, 36, 37, 38, - 1353, 40, 41, 1207, 1353, 1354, 1023, 203, 467, 1354, - 466, 467, 1216, 8, 355, 356, 1353, 143, 53, 1223, - 499, 1354, 9, 764, 500, 599, 1353, 355, 356, 600, - 1054, 1354, 1055, 84, 355, 356, 1022, 121, 122, 123, - 121, 122, 123, 475, 357, 1263, 54, 55, 56, 1024, - 1056, 243, 1057, 244, 288, 289, 290, 167, 168, 291, - 294, 186, 298, 85, 187, 66, 355, 356, 169, 318, - 319, 320, 182, 322, 170, 324, 325, 86, 336, 475, - 296, 297, 1058, 1068, 1059, 87, 350, 374, 352, 1069, - 1374, 312, 313, 314, 359, 353, 354, 863, 864, 315, - 88, 355, 356, 147, 131, 132, 1017, 147, 1353, 765, - 238, 1431, 239, 1354, 371, 372, 96, 375, 358, 377, - 766, 1353, 380, 381, 1353, 191, 1354, 384, 89, 1354, - 723, 355, 356, 355, 356, 161, 1435, 712, 162, 163, - 1438, 164, 736, 142, 124, 125, 126, 127, 606, 530, - 548, 1194, 1640, 82, 196, 179, 563, 183, 90, 193, - 714, 422, 1644, 242, 420, 131, 132, 719, 91, 424, - 425, 426, 427, 428, 429, 430, 431, 432, 433, 434, - 435, 436, 437, 438, 439, 440, 441, 442, 443, 444, - 445, 446, 447, 448, 449, 450, 451, 452, 453, 454, - 455, 456, 457, 458, 459, 460, 461, 462, 463, 464, - 465, 92, 1375, 1432, 355, 356, 1379, 1432, 96, 474, - 1432, 10, 480, 355, 356, 550, 551, 484, 485, 486, - 487, 488, 489, 490, 491, 492, 493, 494, 495, 496, - 497, 498, 141, 1590, 1646, 143, 1594, 504, 1597, 506, - 475, 131, 132, 1353, 289, 474, 1145, 1733, 1354, 816, - 1735, 144, 475, 517, 518, 519, 520, 1011, 522, 523, - 524, 525, 526, 527, 528, 533, 534, 355, 356, 124, - 125, 126, 127, 355, 356, 145, 541, 542, 543, 544, - 355, 356, 552, 540, 148, 355, 356, 355, 356, 906, - 559, 535, 535, 538, 538, 149, 1274, 1353, 151, 567, - 1432, 1276, 1354, 1278, 1432, 150, 1432, 301, 302, 303, - 304, 305, 152, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 929, 355, 356, 856, 153, 315, 1687, 355, - 356, 245, 1691, 246, 1693, 1195, 355, 356, 605, 1428, - 702, 1080, 703, 154, 11, 12, 13, 14, 15, 16, - 17, 18, 1434, 884, 1506, 1507, 1508, 1509, 303, 304, - 305, 1513, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 124, 125, 126, 127, 247, 315, 248, 857, 1736, - 355, 356, 131, 132, 914, 915, 916, 155, 509, 289, - 239, 156, 131, 132, 713, 715, 1437, 165, 304, 305, - 711, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 175, 160, 896, 176, 177, 315, 474, 355, 356, 166, - 124, 125, 126, 127, 174, 420, 734, 180, 474, 1089, - 738, 739, 956, 957, 958, 959, 960, 745, 131, 132, - 754, 131, 132, 184, 735, 475, 239, 755, 756, 860, - 310, 311, 312, 313, 314, 704, 759, 185, 875, 705, - 315, 897, 709, 188, 1603, 1604, 189, 767, 1607, 43, - 44, 45, 46, 475, 48, 1008, 131, 132, 777, 709, - 779, 780, 1283, 249, 197, 250, 1284, 1341, 301, 302, - 303, 304, 305, 198, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 199, 475, 475, 475, 1032, 315, 201, - 930, 1010, 1012, 251, 234, 252, 93, 326, 253, 237, - 254, 817, 97, 98, 99, 100, 101, 102, 103, 104, - 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, - 115, 116, 117, 118, 119, 120, 157, 158, 255, 159, - 256, 327, 257, 259, 258, 260, 261, 200, 262, 1697, - 263, 265, 264, 266, 267, 269, 268, 270, 271, 273, - 272, 274, 43, 44, 45, 46, 47, 48, 1039, 1040, - 301, 302, 303, 304, 305, 285, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 300, 1048, 1049, 846, 847, - 315, 202, 275, 277, 276, 278, 279, 281, 280, 282, - 286, 287, 848, 849, 850, 851, 852, 853, 854, 299, - 483, 474, 283, 316, 284, 859, 317, 475, 865, 709, - 709, 710, 737, 709, 876, 888, 1019, 874, 1020, 1171, - 709, 709, 1031, 1060, 709, 709, 1061, 1062, 1772, 474, - 709, 420, 1150, 1284, 1642, 1285, 1643, 337, 1655, 868, - 1656, 1657, 1659, 1658, 1660, 1682, 969, 1683, 349, 342, - 910, 911, 912, 1763, 1854, 1764, 1855, 1856, 321, 1857, - 474, 474, 474, 1138, 890, 919, 920, 343, 1858, 923, - 1859, 1985, 1987, 1986, 1988, 323, 936, 128, 328, 338, - 934, 935, 1989, 130, 1990, 945, 363, 339, 133, 1826, - 2096, 2098, 2097, 2099, 329, 2100, 2102, 2101, 2103, 360, - 2104, 1166, 2105, 2106, 2183, 2107, 2184, 2185, 2187, 2186, - 2188, 2231, 2233, 2232, 2234, 972, 973, 974, 975, 976, - 977, 978, 979, 980, 981, 982, 983, 984, 985, 986, - 987, 988, 989, 990, 991, 992, 993, 994, 995, 996, - 997, 917, 340, 301, 302, 303, 304, 305, 344, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 2235, 1013, - 2236, 345, 2279, 315, 2280, 2281, 1018, 2282, 301, 302, - 303, 304, 305, 361, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 474, 2283, 1033, 2284, 1034, 315, 362, - 346, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 347, 348, 1050, 1051, 1052, 315, 366, 301, 302, 303, - 304, 305, 367, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 376, 1072, 1073, 1074, 1076, 315, 378, 379, - 382, 383, 301, 302, 303, 304, 305, 1345, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 385, 386, 387, - 388, 389, 315, 415, 390, 391, 392, 393, 394, 395, - 396, 397, 398, 399, 1016, 400, 401, 1108, 93, 94, - 402, 403, 2006, 404, 97, 98, 99, 100, 101, 102, - 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, - 113, 114, 115, 116, 117, 118, 119, 120, 405, 1259, - 406, 407, 408, 409, 410, 411, 412, 413, 1139, 301, - 302, 303, 304, 305, 1146, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 414, 417, 418, 419, 421, 315, - 315, 481, 472, 482, 1155, 1156, 1157, 515, 1229, 510, - 521, 529, 554, 555, 1172, 1165, 1175, 558, 1178, 564, - 561, 568, 569, 570, 571, 572, 573, 574, 575, 1184, - 1185, 576, 577, 578, 579, 580, 581, 535, 582, 538, - 1198, 1197, 583, 584, 1200, 585, 586, 587, 588, 589, - 590, 591, 592, 593, 1210, 594, 595, 596, 597, 598, - 706, 1217, 1218, 1219, 601, 707, 602, 603, 1224, 716, - 717, 722, 1228, 753, 724, 725, 1230, 1231, 1232, 1233, - 1234, 1235, 1236, 1237, 1238, 1239, 1240, 1241, 1242, 1243, + 137, 72, 236, 73, 541, 481, 515, 876, 365, 178, + 181, 81, 369, 192, 171, 173, 241, 96, 721, 146, + 146, 195, 148, 190, 1288, 1028, 1359, 1365, 296, 1368, + 1438, 1360, 480, 867, 1438, 1359, 1029, 1438, 1359, 374, + 1360, 1359, 143, 1360, 356, 357, 1360, 468, 767, 1359, + 203, 1359, 8, 1359, 1360, 1213, 1360, 9, 1360, 467, + 468, 358, 85, 1359, 1222, 356, 357, 84, 1360, 1359, + 86, 1229, 356, 357, 1360, 87, 121, 122, 123, 1030, + 88, 1060, 1359, 1061, 1269, 167, 168, 1360, 532, 121, + 122, 123, 157, 158, 89, 159, 169, 356, 357, 469, + 470, 471, 170, 90, 289, 290, 291, 356, 357, 292, + 295, 96, 299, 1062, 501, 1063, 356, 357, 502, 319, + 320, 321, 182, 323, 359, 325, 326, 142, 337, 297, + 298, 1380, 375, 608, 868, 869, 351, 175, 353, 477, + 176, 177, 356, 357, 360, 354, 355, 356, 357, 147, + 147, 1074, 356, 357, 1086, 468, 768, 1075, 769, 1023, + 552, 553, 1437, 542, 372, 373, 91, 376, 911, 378, + 385, 1441, 381, 382, 1444, 477, 191, 1646, 726, 92, + 124, 125, 126, 127, 121, 122, 123, 1650, 715, 1652, + 739, 186, 148, 82, 187, 124, 125, 126, 127, 1739, + 153, 131, 132, 356, 357, 1741, 179, 183, 565, 714, + 193, 423, 196, 242, 421, 722, 131, 132, 1742, 425, + 426, 427, 428, 429, 430, 431, 432, 433, 434, 435, + 436, 437, 438, 439, 440, 441, 442, 443, 444, 445, + 446, 447, 448, 449, 450, 451, 452, 453, 454, 455, + 456, 457, 458, 459, 460, 461, 462, 463, 464, 465, + 466, 1200, 356, 357, 1381, 1438, 141, 10, 1385, 1438, + 476, 143, 1438, 482, 124, 125, 126, 127, 486, 487, + 488, 489, 490, 491, 492, 493, 494, 495, 496, 497, + 498, 499, 500, 601, 717, 901, 1596, 602, 506, 1600, + 508, 1603, 356, 357, 706, 290, 476, 880, 707, 144, + 1151, 712, 356, 357, 519, 520, 521, 522, 1280, 524, + 525, 526, 527, 528, 529, 530, 535, 536, 1064, 145, + 1065, 1017, 356, 357, 243, 149, 244, 543, 544, 545, + 546, 131, 132, 554, 902, 356, 357, 477, 1282, 819, + 150, 561, 537, 537, 540, 540, 356, 357, 151, 477, + 569, 1284, 1438, 1014, 131, 132, 1438, 712, 1438, 304, + 305, 306, 1434, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 1289, 860, 356, 357, 1290, 316, 704, 152, + 705, 1693, 356, 357, 154, 1697, 1095, 1699, 155, 607, + 11, 12, 13, 14, 15, 16, 17, 18, 1440, 356, + 357, 245, 889, 246, 131, 132, 1512, 1513, 1514, 1515, + 821, 934, 819, 1519, 247, 1443, 248, 302, 303, 304, + 305, 306, 156, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 160, 919, 920, 921, 161, 316, 710, 162, + 163, 290, 164, 165, 301, 1201, 716, 718, 311, 312, + 313, 314, 315, 302, 303, 304, 305, 306, 316, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 476, 516, + 249, 166, 250, 316, 712, 180, 713, 710, 737, 251, + 476, 252, 741, 742, 124, 125, 126, 127, 174, 748, + 131, 132, 757, 253, 199, 254, 238, 184, 239, 758, + 759, 131, 132, 1045, 1046, 131, 132, 472, 762, 239, + 185, 255, 861, 256, 188, 189, 1609, 1610, 197, 770, + 1613, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 780, 198, 782, 783, 201, 316, 313, 314, 315, 1054, + 1055, 1347, 477, 200, 316, 305, 306, 865, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 257, 1038, 258, + 202, 259, 316, 260, 234, 1016, 1018, 237, 131, 132, + 261, 477, 262, 820, 511, 300, 239, 302, 303, 304, + 305, 306, 285, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 131, 132, 485, 286, 317, 316, 738, 935, + 239, 287, 477, 477, 477, 43, 44, 45, 46, 318, + 48, 1703, 302, 303, 304, 305, 306, 322, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 961, 962, 963, + 964, 965, 316, 338, 324, 302, 303, 304, 305, 306, + 339, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 850, 851, 263, 340, 264, 316, 343, 265, 267, 266, + 268, 269, 341, 270, 852, 853, 854, 855, 856, 857, + 858, 344, 271, 476, 272, 873, 345, 273, 864, 274, + 275, 870, 276, 277, 279, 278, 280, 881, 346, 281, + 879, 282, 350, 283, 1177, 284, 712, 712, 740, 893, + 1778, 1025, 476, 1026, 710, 712, 347, 1037, 712, 712, + 1066, 1067, 712, 712, 1068, 1156, 1290, 348, 1291, 974, + 1648, 364, 1649, 915, 916, 917, 1661, 477, 1662, 1663, + 1665, 1664, 1666, 476, 476, 476, 361, 349, 924, 925, + 367, 1688, 928, 1689, 1769, 895, 1770, 368, 1860, 941, + 1861, 362, 363, 939, 940, 1862, 380, 1863, 950, 377, + 379, 1832, 302, 303, 304, 305, 306, 383, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 1864, 1991, 1865, + 1992, 1993, 316, 1994, 1995, 2102, 1996, 2103, 384, 978, + 979, 980, 981, 982, 983, 984, 985, 986, 987, 988, + 989, 990, 991, 992, 993, 994, 995, 996, 997, 998, + 999, 1000, 1001, 1002, 1003, 2104, 2106, 2105, 2107, 416, + 2108, 1144, 2109, 2110, 2112, 2111, 2113, 386, 2189, 820, + 2190, 2191, 387, 2192, 1019, 2193, 2237, 2194, 2238, 388, + 2239, 1024, 2240, 302, 303, 304, 305, 306, 389, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 476, 1172, + 1039, 390, 1040, 316, 2241, 2285, 2242, 2286, 2287, 391, + 2288, 2289, 392, 2290, 393, 394, 395, 1056, 1057, 1058, + 396, 397, 398, 418, 399, 400, 401, 402, 403, 404, + 405, 406, 407, 408, 1082, 409, 410, 411, 1078, 1079, + 1080, 412, 413, 414, 415, 420, 419, 422, 316, 474, + 483, 484, 1351, 302, 303, 304, 305, 306, 512, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 517, 523, + 531, 556, 557, 316, 560, 563, 566, 570, 571, 93, + 327, 594, 1114, 572, 2012, 97, 98, 99, 100, 101, + 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, + 112, 113, 114, 115, 116, 117, 118, 119, 120, 573, + 574, 575, 576, 577, 328, 578, 708, 922, 579, 580, + 581, 582, 583, 584, 1145, 585, 586, 587, 588, 589, + 1152, 590, 591, 592, 593, 43, 44, 45, 46, 47, + 48, 595, 596, 597, 598, 599, 600, 709, 603, 605, + 1161, 1162, 1163, 604, 1235, 719, 720, 725, 756, 760, + 1178, 1171, 1181, 727, 1184, 728, 729, 731, 733, 734, + 743, 761, 774, 772, 773, 1190, 1191, 775, 776, 1204, + 778, 779, 785, 537, 786, 540, 787, 1203, 788, 789, + 1206, 790, 791, 792, 793, 1022, 794, 795, 796, 797, + 1216, 798, 799, 800, 801, 802, 803, 1223, 1224, 1225, + 804, 805, 806, 807, 1230, 816, 808, 809, 1234, 810, + 811, 812, 1236, 1237, 1238, 1239, 1240, 1241, 1242, 1243, 1244, 1245, 1246, 1247, 1248, 1249, 1250, 1251, 1252, 1253, - 1254, 1255, 301, 302, 303, 304, 305, 726, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 1265, 728, 128, - 129, 730, 315, 731, 740, 130, 757, 758, 769, 771, - 133, 770, 772, 292, 773, 1272, 293, 301, 302, 303, - 304, 305, 775, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 1267, 776, 782, 783, 784, 315, 1288, 785, - 1289, 786, 1291, 93, 94, 787, 788, 789, 790, 97, - 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, - 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, - 118, 119, 120, 93, 94, 814, 813, 791, 792, 97, - 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, - 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, - 118, 119, 120, 845, 793, 794, 855, 819, 869, 820, - 858, 821, 1344, 866, 1352, 795, 1358, 867, 1361, 796, - 1351, 873, 1357, 879, 1360, 861, 1363, 1364, 822, 797, - 881, 892, 823, 1368, 893, 535, 798, 538, 799, 894, - 895, 800, 1377, 898, 801, 824, 899, 900, 901, 802, - 1385, 803, 804, 805, 806, 1390, 807, 808, 1393, 809, - 1395, 1396, 1397, 1398, 1399, 1400, 1401, 1402, 1403, 1404, + 1254, 1255, 1256, 1257, 1258, 1259, 1260, 1261, 813, 814, + 815, 817, 818, 823, 824, 825, 849, 859, 826, 874, + 128, 329, 827, 1271, 828, 829, 130, 830, 863, 831, + 832, 133, 833, 871, 834, 835, 836, 330, 837, 838, + 839, 1278, 840, 841, 842, 302, 303, 304, 305, 306, + 843, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 866, 1297, 93, 288, 1294, 316, 1295, 844, 97, 98, + 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, + 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, + 119, 120, 93, 288, 872, 845, 878, 910, 97, 98, + 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, + 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, + 119, 120, 846, 302, 303, 304, 305, 306, 875, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 1350, 847, + 1358, 848, 1364, 316, 1367, 884, 1357, 886, 1363, 896, + 1366, 897, 1369, 1370, 898, 899, 900, 903, 904, 1374, + 905, 537, 906, 540, 907, 908, 909, 918, 1383, 923, + 931, 929, 936, 938, 937, 942, 1391, 943, 944, 945, + 946, 1396, 949, 951, 1399, 952, 1401, 1402, 1403, 1404, 1405, 1406, 1407, 1408, 1409, 1410, 1411, 1412, 1413, 1414, - 1415, 1416, 1417, 1418, 1419, 1420, 810, 811, 1637, 352, - 812, 902, 1425, 815, 288, 289, 1426, 870, 825, 826, - 301, 302, 303, 304, 305, 827, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 828, 1445, 829, 830, 831, - 315, 903, 832, 833, 128, 129, 834, 835, 836, 837, - 130, 838, 839, 840, 841, 133, 842, 843, 732, 844, - 904, 733, 905, 913, 891, 918, 926, 924, 931, 932, - 933, 937, 938, 939, 128, 129, 940, 941, 944, 946, - 130, 947, 950, 951, 952, 133, 953, 954, 886, 963, - 964, 887, 965, 966, 1489, 967, 1007, 968, 970, 1009, - 1494, 1014, 1015, 1498, 1728, 1021, 1731, 1025, 1027, 1505, - 1029, 1030, 1053, 1038, 1065, 1066, 1071, 1075, 1109, 1077, - 1081, 1082, 1136, 1268, 1084, 1086, 1083, 1521, 1522, 1523, - 1524, 1525, 1526, 1527, 1528, 1529, 1530, 1531, 1532, 1533, - 1534, 1535, 1536, 1537, 1538, 1539, 1540, 1541, 1085, 1543, - 301, 302, 303, 304, 305, 1087, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 1088, 1090, 1091, 1092, 1555, - 315, 1140, 1141, 1093, 1094, 1095, 1169, 1096, 1170, 1097, - 93, 511, 1098, 1099, 1100, 1795, 97, 98, 99, 100, - 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, - 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, - 1101, 1102, 1105, 1103, 1104, 1106, 1143, 1107, 1147, 1148, - 1149, 1152, 1153, 1154, 1158, 1159, 1160, 1161, 1610, 1612, - 1614, 1615, 1616, 1617, 1618, 1619, 1620, 1621, 1622, 1623, + 1415, 1416, 1417, 1418, 1419, 1420, 1421, 1422, 1423, 1424, + 1425, 1426, 955, 956, 957, 353, 958, 959, 1431, 968, + 289, 290, 1432, 969, 970, 971, 972, 973, 975, 1013, + 1015, 976, 1044, 1021, 1020, 1451, 1027, 1031, 1033, 1035, + 1036, 1059, 1071, 128, 129, 1072, 1077, 1081, 1083, 130, + 1087, 1088, 1089, 1090, 133, 1115, 1091, 293, 1092, 1142, + 294, 1093, 1097, 1094, 1096, 1098, 1146, 1099, 1100, 1105, + 1101, 1102, 1103, 128, 129, 1104, 1106, 1107, 1108, 130, + 1109, 1110, 1111, 1112, 133, 1113, 1147, 735, 1192, 1149, + 736, 1153, 1154, 1155, 1158, 1159, 1643, 1160, 1164, 1165, + 1495, 1166, 1167, 1168, 1169, 1170, 1500, 1179, 1511, 1504, + 1182, 1185, 1187, 1188, 1189, 1205, 1196, 1208, 1209, 1210, + 1211, 1266, 1265, 1212, 1214, 1215, 1217, 1218, 1268, 1219, + 1221, 1220, 1227, 1527, 1528, 1529, 1530, 1531, 1532, 1533, + 1534, 1535, 1536, 1537, 1538, 1539, 1540, 1541, 1542, 1543, + 1544, 1545, 1546, 1547, 1228, 1549, 1231, 1232, 1233, 1262, + 1270, 1277, 1263, 302, 303, 304, 305, 306, 1561, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 1264, 1267, + 1276, 1293, 1281, 316, 1298, 1279, 1273, 1283, 1285, 93, + 288, 744, 1734, 1292, 1737, 97, 98, 99, 100, 101, + 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, + 112, 113, 114, 115, 116, 117, 118, 119, 120, 1378, + 1274, 1379, 1382, 1384, 1386, 1348, 1387, 1300, 1301, 1302, + 1388, 1303, 1371, 1307, 1616, 1618, 1620, 1621, 1622, 1623, 1624, 1625, 1626, 1627, 1628, 1629, 1630, 1631, 1632, 1633, - 1634, 1635, 1162, 1163, 1164, 1173, 1176, 1179, 1181, 1182, - 1183, 93, 94, 1186, 1190, 1199, 1650, 97, 98, 99, - 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, - 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, - 120, 301, 302, 303, 304, 305, 1202, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 1203, 1204, 1205, 1256, - 1206, 315, 1208, 1209, 1696, 1695, 1212, 1211, 1213, 1262, - 1214, 1701, 1269, 1703, 1215, 1705, 1221, 1707, 1708, 1709, - 1710, 1711, 1712, 1713, 1714, 1715, 1716, 1717, 1718, 1719, - 1720, 1721, 1722, 1723, 1724, 1725, 1726, 1727, 1222, 1225, - 1226, 1260, 1264, 334, 1227, 1257, 1258, 1261, 1270, 341, - 1739, 128, 129, 1271, 1287, 1273, 1294, 130, 1275, 1292, - 1277, 1279, 133, 1286, 1295, 1296, 1443, 1297, 512, 1298, - 1300, 1301, 365, 1302, 1306, 1307, 1308, 1342, 369, 370, - 1311, 1310, 1313, 1340, 1372, 1365, 1373, 1376, 1378, 1380, - 1381, 1382, 1383, 1769, 1770, 1384, 1386, 1388, 1389, 1391, - 1392, 1777, 1778, 1779, 1780, 1781, 1782, 1783, 1784, 1785, - 1786, 1787, 1788, 1789, 1790, 1791, 1792, 1793, 1794, 1394, - 1424, 1421, 1422, 1430, 1429, 1441, 1442, 1444, 1446, 1447, - 1448, 1450, 1348, 1349, 1453, 1487, 1491, 1492, 130, 1495, - 1496, 1451, 1499, 1350, 1500, 1455, 1501, 1457, 1504, 170, - 1484, 1510, 514, 1823, 1511, 1512, 1514, 1515, 1828, 1830, - 1832, 1833, 1834, 1835, 1836, 1837, 1838, 1839, 1840, 1841, - 1842, 1843, 1844, 1845, 1846, 1847, 1848, 1849, 1850, 1516, - 301, 302, 303, 304, 305, 1517, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 1544, 1601, 1608, 1546, 565, - 315, 1554, 1589, 1591, 1595, 1548, 1598, 1602, 1549, 1551, - 1881, 1605, 1883, 1553, 1885, 1556, 1887, 1888, 1889, 1890, - 1891, 1892, 1893, 1894, 1895, 1896, 1897, 1898, 1899, 1900, - 1901, 1902, 1903, 1904, 301, 302, 303, 304, 305, 1558, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 1557, - 1559, 1560, 1561, 1588, 315, 1606, 1562, 1563, 1564, 1586, - 1639, 1648, 1641, 1645, 1647, 1928, 1929, 1930, 1931, 1932, - 1933, 1934, 1935, 1936, 1937, 1938, 1939, 1940, 1941, 1942, - 1649, 1651, 1686, 1689, 1690, 1692, 1694, 1699, 1652, 1653, - 1700, 1702, 1704, 1654, 1706, 1729, 1732, 1765, 1766, 1684, - 1964, 1966, 1968, 1969, 1970, 1971, 1972, 1973, 1974, 1975, - 1976, 1977, 1978, 1979, 1980, 1981, 1982, 1983, 301, 302, - 303, 304, 305, 1685, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 1767, 1734, 1768, 1737, 1740, 315, 1741, - 1771, 2007, 1796, 2009, 1799, 2011, 1800, 2013, 2014, 2015, - 2016, 2017, 2018, 2019, 2020, 2021, 2022, 2023, 2024, 2025, - 2026, 2027, 1801, 1824, 708, 301, 302, 303, 304, 305, - 1802, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 1803, 1878, 1804, 1852, 1853, 315, 1880, 1882, 1884, 1886, - 1944, 2051, 2052, 2053, 2054, 2055, 2056, 2057, 2058, 2059, - 1945, 1905, 1943, 2008, 1946, 2010, 1984, 2012, 2028, 2044, - 2060, 2061, 2062, 2118, 2063, 2064, 2076, 2078, 2080, 2082, - 2084, 2086, 2087, 2088, 2089, 2090, 2091, 2092, 2093, 2094, - 2095, 545, 27, 28, 546, 547, 31, 32, 33, 2065, - 34, 2120, 36, 37, 38, 2122, 40, 41, 2124, 2126, - 2128, 2162, 2117, 2163, 2119, 2164, 2121, 2196, 2123, 2198, - 2125, 2200, 2127, 53, 2129, 2130, 2131, 2132, 2133, 2134, - 2135, 2136, 2137, 2216, 721, 2217, 2218, 2241, 2243, 2245, - 2286, 2270, 2288, 2271, 2272, 2290, 2292, 2293, 71, 818, - 78, 54, 55, 56, 2147, 2148, 2149, 2150, 2151, 2152, - 1142, 0, 889, 0, 0, 0, 0, 0, 0, 0, - 66, 0, 2165, 2166, 2167, 2168, 2169, 2170, 2172, 2174, - 2176, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 2189, 2190, 2191, 2192, 2193, 2194, 2195, - 1189, 2197, 0, 2199, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 2207, 2208, 2209, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 2219, - 2220, 2221, 2223, 2225, 2227, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 2237, 2238, 2239, 2240, 0, 2242, - 0, 2244, 0, 0, 0, 553, 0, 0, 0, 0, - 0, 0, 2249, 2250, 2251, 0, 0, 0, 2255, 2256, - 2257, 0, 0, 0, 2261, 2262, 2263, 877, 878, 0, - 880, 0, 882, 883, 0, 0, 2274, 2276, 2278, 0, - 0, 0, 0, 0, 0, 2285, 0, 2287, 0, 2289, - 301, 302, 303, 304, 305, 0, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 0, 0, 921, 922, 0, 0, 925, 301, 302, - 303, 304, 305, 928, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 942, 943, 0, 0, 315, 0, - 948, 949, 0, 0, 93, 94, 95, 955, 96, 962, - 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, - 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, - 117, 118, 119, 120, 0, 121, 122, 123, 0, 0, + 1634, 1635, 1636, 1637, 1638, 1639, 1640, 1641, 1304, 1306, + 1308, 1312, 1313, 1314, 1389, 1656, 1317, 1275, 1316, 1319, + 1346, 1390, 1392, 1801, 1394, 1395, 1397, 1398, 1427, 1400, + 1428, 1430, 1449, 1435, 1493, 1436, 1456, 1497, 1447, 335, + 302, 303, 304, 305, 306, 342, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 1450, 1457, 1498, 1501, 1448, + 316, 1502, 1505, 1702, 1506, 1507, 1510, 1461, 366, 1516, + 1517, 1701, 1518, 1520, 370, 371, 1521, 1707, 1523, 1709, + 567, 1711, 1452, 1713, 1714, 1715, 1716, 1717, 1718, 1719, + 1720, 1721, 1722, 1723, 1724, 1725, 1726, 1727, 1728, 1729, + 1730, 1731, 1732, 1733, 302, 303, 304, 305, 306, 1745, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 1453, + 128, 129, 1522, 1550, 316, 1454, 130, 1459, 1463, 1490, + 1564, 133, 1552, 1554, 891, 724, 1555, 892, 302, 303, + 304, 305, 306, 1557, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 1559, 1560, 1562, 1563, 1565, 316, 1775, + 1776, 1568, 1566, 1567, 1595, 1597, 1594, 1783, 1784, 1785, + 1786, 1787, 1788, 1789, 1790, 1791, 1792, 1793, 1794, 1795, + 1796, 1797, 1798, 1799, 1800, 302, 303, 304, 305, 306, + 1569, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 302, 303, 304, 305, 306, 316, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 1570, 1607, 1601, 894, 1829, + 316, 1592, 1604, 1611, 1834, 1836, 1838, 1839, 1840, 1841, + 1842, 1843, 1844, 1845, 1846, 1847, 1848, 1849, 1850, 1851, + 1852, 1853, 1854, 1855, 1856, 1608, 302, 303, 304, 305, + 306, 1612, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 1614, 933, 1645, 1654, 1657, 316, 1692, 1695, 1647, + 1651, 1659, 1653, 1696, 1660, 1655, 1887, 1658, 1889, 1698, + 1891, 1690, 1893, 1894, 1895, 1896, 1897, 1898, 1899, 1900, + 1901, 1902, 1903, 1904, 1905, 1906, 1907, 1908, 1909, 1910, + 1691, 302, 303, 304, 305, 306, 1700, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 1705, 1706, 1708, 1710, + 1712, 316, 1735, 1738, 1740, 1743, 1746, 1771, 1747, 1772, + 1773, 1934, 1935, 1936, 1937, 1938, 1939, 1940, 1941, 1942, + 1943, 1944, 1945, 1946, 1947, 1948, 1774, 1777, 1802, 1805, + 1806, 1807, 1830, 1808, 1809, 1810, 1858, 1859, 1884, 1886, + 1888, 1890, 711, 1892, 1911, 1949, 1970, 1972, 1974, 1975, + 1976, 1977, 1978, 1979, 1980, 1981, 1982, 1983, 1984, 1985, + 1986, 1987, 1988, 1989, 302, 303, 304, 305, 306, 1950, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 1951, + 1952, 1990, 2014, 2016, 316, 2018, 2050, 2013, 2034, 2015, + 2066, 2017, 2124, 2019, 2020, 2021, 2022, 2023, 2024, 2025, + 2026, 2027, 2028, 2029, 2030, 2031, 2032, 2033, 302, 303, + 304, 305, 306, 2067, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 2068, 2069, 2070, 2126, 2071, 316, 2128, + 2130, 2132, 2134, 2168, 2169, 2202, 2170, 2057, 2058, 2059, + 2060, 2061, 2062, 2063, 2064, 2065, 2204, 2206, 2247, 2222, + 2223, 2224, 2249, 2251, 2292, 2276, 2277, 2278, 2294, 2296, + 2298, 2299, 2082, 2084, 2086, 2088, 2090, 2092, 2093, 2094, + 2095, 2096, 2097, 2098, 2099, 2100, 2101, 547, 27, 28, + 548, 549, 31, 32, 33, 822, 34, 71, 36, 37, + 38, 78, 40, 41, 1148, 1195, 0, 0, 2123, 0, + 2125, 0, 2127, 0, 2129, 0, 2131, 0, 2133, 53, + 2135, 2136, 2137, 2138, 2139, 2140, 2141, 2142, 2143, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 93, 326, 0, 0, 0, 0, 97, 98, 99, - 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, - 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, - 120, 1026, 0, 1028, 0, 0, 327, 0, 0, 0, - 0, 0, 0, 0, 1035, 1036, 1037, 0, 0, 0, - 1041, 1042, 1043, 1044, 1045, 1046, 1047, 43, 44, 45, - 46, 47, 48, 0, 93, 94, 467, 0, 0, 0, - 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, - 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, - 117, 118, 119, 120, 0, 121, 122, 123, 0, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 124, 125, 126, 127, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 128, 129, 0, 0, 0, - 0, 130, 131, 132, 0, 0, 133, 0, 134, 0, - 135, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1137, 0, 0, 0, 301, 302, 303, 304, - 305, 0, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 128, 473, 0, 0, 315, 0, 130, 93, - 94, 0, 1192, 133, 1193, 97, 98, 99, 100, 101, + 0, 0, 0, 0, 0, 0, 0, 54, 55, 56, + 2153, 2154, 2155, 2156, 2157, 2158, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 66, 0, 2171, 2172, + 2173, 2174, 2175, 2176, 2178, 2180, 2182, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 2195, + 2196, 2197, 2198, 2199, 2200, 2201, 0, 2203, 0, 2205, + 0, 0, 0, 0, 0, 0, 882, 883, 0, 885, + 0, 887, 888, 2213, 2214, 2215, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 2225, 2226, 2227, 2229, 2231, + 2233, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2243, 2244, 2245, 2246, 0, 2248, 0, 2250, 0, 0, + 0, 550, 926, 927, 0, 0, 930, 0, 2255, 2256, + 2257, 0, 0, 0, 2261, 2262, 2263, 0, 0, 0, + 2267, 2268, 2269, 947, 948, 0, 0, 0, 0, 953, + 954, 0, 2280, 2282, 2284, 0, 960, 0, 967, 0, + 0, 2291, 0, 2293, 0, 2295, 0, 93, 513, 0, + 0, 0, 0, 97, 98, 99, 100, 101, 102, 103, + 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, + 114, 115, 116, 117, 118, 119, 120, 93, 288, 0, + 0, 0, 0, 97, 98, 99, 100, 101, 102, 103, + 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, + 114, 115, 116, 117, 118, 119, 120, 0, 0, 0, + 0, 0, 1032, 0, 1034, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 1041, 1042, 1043, 0, 0, + 0, 1047, 1048, 1049, 1050, 1051, 1052, 1053, 0, 93, + 94, 95, 0, 96, 0, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 0, - 0, 0, 0, 1191, 0, 0, 0, 0, 0, 0, - 0, 1201, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 128, 129, 0, 0, 0, - 1220, 130, 93, 511, 0, 0, 133, 0, 97, 98, - 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, - 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, - 119, 120, 0, 0, -10, 1, 0, -10, -53, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 545, 27, - 28, 546, 547, 31, 32, 33, 0, 34, 0, 36, - 37, 38, 0, 40, 41, 0, 0, -53, 0, 0, - 0, -53, -53, -53, -53, -53, -53, -53, -53, -53, - 53, -53, -53, -53, -53, -53, -53, -53, -53, 0, - 0, 0, -53, -53, -53, -53, -53, -53, -53, 0, - -53, -53, -53, -53, -53, 0, 0, 0, 54, 55, - 56, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 128, 129, 0, 0, 0, 0, 130, 66, 0, 0, - 0, 133, -53, -53, -53, 0, 0, 0, 0, -53, - 0, -53, 0, -53, -53, -53, -53, -53, -53, -53, - 0, -53, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - -10, -10, -10, -10, -10, -10, -10, -10, 0, 0, - 0, 0, 0, 128, 129, 0, 1366, 0, 1367, 130, - 204, 0, 1371, 0, 133, 2, 3, 0, 4, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 1387, 0, - 0, 0, 778, 0, 0, 607, 608, 609, 610, 611, - 612, 613, 614, 615, 616, 617, 618, 619, 620, 621, - 622, 623, 624, 625, 626, 627, 628, 629, 630, 631, - 632, 607, 608, 609, 610, 611, 612, 613, 614, 615, - 616, 617, 618, 619, 620, 621, 622, 623, 624, 625, - 626, 627, 628, 629, 630, 631, 632, 205, 206, 207, - 0, 0, 0, 0, 0, 208, 209, 210, 211, 212, - 213, 214, 215, 216, 217, 0, 0, 0, 0, 0, - 0, 0, 0, 218, 219, 220, 221, 222, 223, 224, - 225, 226, 227, 0, 228, 229, 230, 231, 232, 233, - 0, 0, 0, 0, 0, 0, 0, 0, 23, 0, - 0, 0, 0, 0, 0, 1485, 0, 0, 0, 0, - 0, 0, 1490, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 1502, 1503, 633, 0, 24, 0, 0, - 0, 25, 26, 27, 28, 29, 30, 31, 32, 33, - 0, 34, 35, 36, 37, 38, 39, 40, 41, 0, - 0, 971, 42, 43, 44, 45, 46, 47, 48, 0, - 49, 50, 51, 52, 53, 0, 0, 1545, 0, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 54, 55, 56, 1346, 0, 1347, 0, 57, - 0, 58, 0, 59, 60, 61, 62, 63, 64, 65, - 0, 66, 545, 27, 28, 546, 547, 31, 32, 33, - 0, 34, 0, 36, 37, 38, 0, 40, 41, 0, - 1593, 0, 0, 0, 0, 1600, 0, 0, 0, 301, - 302, 303, 304, 305, 53, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 0, 0, 0, 0, 741, 0, 0, - 0, 0, 54, 55, 56, 301, 302, 303, 304, 305, - 0, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 66, 0, 0, 0, 315, 0, 0, 301, 302, - 303, 304, 305, 746, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 0, 0, 0, 0, 1688, 0, 747, 0, 0, 301, - 302, 303, 304, 305, 1698, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 301, 302, 303, 304, 305, 885, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 0, 0, 301, 302, 303, 304, 305, - 909, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 0, 0, 301, 302, - 303, 304, 305, 1167, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 0, 0, 0, 1773, 0, 0, 1369, 301, 302, 303, - 304, 305, 0, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 0, 0, - 301, 302, 303, 304, 305, 1370, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 0, 0, 0, 0, 0, 0, 0, 1427, 0, - 0, 0, 1825, 301, 302, 303, 304, 305, 0, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 0, 0, 0, 0, 0, 0, - 0, 1433, 301, 302, 303, 304, 305, 0, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 0, 1879, 301, 302, 303, 304, 305, - 1436, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 0, 0, 301, 302, - 303, 304, 305, 1439, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 0, 0, 0, 0, 0, 0, 1440, 1924, 301, 302, - 303, 304, 305, 0, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 0, 0, 0, 0, 0, 0, 1486, 0, 0, 0, - 301, 302, 303, 304, 305, 1962, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 0, 0, 301, 302, 303, 304, 305, 1547, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 0, 0, 301, 302, 303, 304, - 305, 1550, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 0, 0, 301, - 302, 303, 304, 305, 1552, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 301, 302, 303, 304, 305, 1798, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 0, 0, 301, 302, 303, 304, 305, - 1851, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 0, 471, 0, 0, - 0, 531, 301, 302, 303, 304, 305, 0, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 531, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 532, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 562, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 682, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 683, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 696, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 697, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 698, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 699, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 700, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 701, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 760, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 761, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 762, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 907, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 908, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 927, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1063, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1064, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1078, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1079, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1110, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1111, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1112, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1113, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1114, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1115, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1116, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1117, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1118, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1119, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1120, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1121, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1122, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1123, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1124, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1125, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1126, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1127, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1128, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1129, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1130, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1131, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1132, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1133, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1134, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1135, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1151, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1266, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1280, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1281, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1290, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1293, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1304, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1309, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1312, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1314, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1315, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1316, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1317, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1318, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1319, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1320, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1321, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1322, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1323, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1324, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1325, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1326, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1327, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1328, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1329, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1330, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1331, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1332, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1333, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1334, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1335, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1336, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1337, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1338, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1339, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1343, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1449, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1461, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1462, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1463, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1464, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1465, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1466, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1467, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1468, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1469, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1470, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1471, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1472, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1473, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1474, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1475, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1476, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1477, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1478, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1479, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1480, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1481, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1483, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1565, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1566, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1567, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1568, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1569, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1570, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1571, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1572, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1573, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1574, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1575, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1576, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1577, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1578, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1579, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1580, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1581, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1582, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1583, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1584, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1585, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1661, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1662, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1663, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1664, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1665, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1666, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1667, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1668, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1669, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1670, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1671, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1672, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1673, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1674, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1675, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1676, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1677, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1678, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1679, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1680, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1681, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1738, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1745, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1746, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1747, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1748, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1749, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1750, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1751, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1752, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1753, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1754, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1755, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1756, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1757, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1758, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1759, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1760, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1761, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1762, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1797, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1805, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1806, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1807, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1808, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1809, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1810, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1811, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1812, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1813, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1814, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1815, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1816, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1817, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1818, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1819, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1820, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1821, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1822, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1860, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1861, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1862, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1863, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1864, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1865, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1866, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1867, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1868, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1869, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1870, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1871, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1872, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1873, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1874, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1875, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1876, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1877, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1909, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1910, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1911, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1912, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1913, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1914, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1915, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1916, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1917, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1918, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1919, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1920, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1921, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1922, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1923, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1947, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1948, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1949, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1950, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1951, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1952, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1953, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1954, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1955, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1956, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1957, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1958, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1959, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1960, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 1961, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 1991, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 1992, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 1993, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 1994, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 1995, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 1996, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 1997, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 1998, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 1999, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 2000, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 2001, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 2002, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 2003, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 2004, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 2005, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 2035, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 2036, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 2037, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 2038, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 2039, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 2040, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 2041, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 2042, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 2043, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 2066, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 2067, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 2068, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 2069, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 2070, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 2071, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 2072, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 2073, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 2074, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 2108, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 2109, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 2110, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 2111, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 2112, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 2113, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 2114, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 2115, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 2116, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 2138, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 2139, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 2140, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 2141, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 2142, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 2143, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 2156, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 2157, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 2158, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 2159, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 2160, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 2161, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 2177, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 2178, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 2179, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 2180, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 2181, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 2182, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 2201, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 2202, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 2203, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 2213, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 2214, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 2215, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 2228, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 2229, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 301, 302, 303, 304, 305, - 2230, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 301, 302, 303, 304, - 305, 2246, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 301, 302, 303, - 304, 305, 2247, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 301, 302, - 303, 304, 305, 2248, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 301, - 302, 303, 304, 305, 2252, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 301, 302, 303, 304, 305, 2253, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 301, 302, 303, 304, 305, 2254, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 301, 302, 303, 304, 305, 2258, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 301, 302, 303, 304, 305, 2259, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 301, 302, 303, 304, 305, 2260, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 477, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 604, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 661, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 663, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 665, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 667, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 669, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 671, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 673, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 675, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 677, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 679, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 681, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 685, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 687, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 689, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 691, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 693, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 695, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 763, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 768, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 999, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 1001, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 1003, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 1005, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 0, 0, 1006, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 0, 0, 1144, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 471, 301, 302, 303, 304, 305, 0, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 0, 501, 301, 302, 303, 304, 305, - 0, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 0, 502, 301, 302, - 303, 304, 305, 0, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 503, 301, 302, 303, 304, 305, 0, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 0, 505, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 507, 301, 302, 303, - 304, 305, 0, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 0, 508, - 301, 302, 303, 304, 305, 0, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 0, 516, 301, 302, 303, 304, 305, 0, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 0, 556, 301, 302, 303, 304, - 305, 0, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 0, 557, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 560, 301, 302, 303, 304, 305, 0, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 0, 566, 301, 302, 303, 304, 305, - 0, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 0, 660, 301, 302, - 303, 304, 305, 0, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 662, 301, 302, 303, 304, 305, 0, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 0, 664, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 666, 301, 302, 303, - 304, 305, 0, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 0, 668, - 301, 302, 303, 304, 305, 0, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 0, 670, 301, 302, 303, 304, 305, 0, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 0, 672, 301, 302, 303, 304, - 305, 0, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 0, 674, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 676, 301, 302, 303, 304, 305, 0, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 0, 678, 301, 302, 303, 304, 305, - 0, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 0, 680, 301, 302, - 303, 304, 305, 0, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 684, 301, 302, 303, 304, 305, 0, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 0, 686, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 688, 301, 302, 303, - 304, 305, 0, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 0, 690, - 301, 302, 303, 304, 305, 0, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 0, 692, 301, 302, 303, 304, 305, 0, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 0, 694, 301, 302, 303, 304, - 305, 0, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 0, 727, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 729, 301, 302, 303, 304, 305, 0, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 0, 742, 301, 302, 303, 304, 305, - 0, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 0, 743, 301, 302, - 303, 304, 305, 0, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 744, 301, 302, 303, 304, 305, 0, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 0, 748, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 749, 301, 302, 303, - 304, 305, 0, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 0, 750, - 301, 302, 303, 304, 305, 0, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 0, 751, 301, 302, 303, 304, 305, 0, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 0, 752, 301, 302, 303, 304, - 305, 0, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 0, 774, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 781, 301, 302, 303, 304, 305, 0, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 0, 998, 301, 302, 303, 304, 305, - 0, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 0, 1000, 301, 302, - 303, 304, 305, 0, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 1002, 301, 302, 303, 304, 305, 0, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 0, 1004, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 1067, 301, 302, 303, - 304, 305, 0, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 0, 1168, - 301, 302, 303, 304, 305, 0, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 0, 1196, 301, 302, 303, 304, 305, 0, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 0, 1299, 301, 302, 303, 304, - 305, 0, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 0, 1303, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 1305, 301, 302, 303, 304, 305, 0, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 0, 1423, 301, 302, 303, 304, 305, - 0, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 0, 1452, 301, 302, - 303, 304, 305, 0, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 1454, 301, 302, 303, 304, 305, 0, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 0, 1456, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 1458, 301, 302, 303, - 304, 305, 0, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 0, 1459, - 301, 302, 303, 304, 305, 0, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 0, 1460, 301, 302, 303, 304, 305, 0, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 0, 1482, 301, 302, 303, 304, - 305, 0, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 0, 1587, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 1742, 301, 302, 303, 304, 305, 0, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 0, 1743, 301, 302, 303, 304, 305, - 0, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 0, 1744, 301, 302, - 303, 304, 305, 0, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 1906, 301, 302, 303, 304, 305, 0, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 0, 1907, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 1908, 301, 302, 303, - 304, 305, 0, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 0, 2029, - 301, 302, 303, 304, 305, 0, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 0, 2030, 301, 302, 303, 304, 305, 0, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 0, 2031, 301, 302, 303, 304, - 305, 0, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 0, 2032, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 2033, 301, 302, 303, 304, 305, 0, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315, 0, 2034, 301, 302, 303, 304, 305, - 0, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 0, 0, 0, 0, 0, 315, 0, 2144, 301, 302, - 303, 304, 305, 0, 306, 307, 308, 309, 310, 311, - 312, 313, 314, 0, 0, 0, 0, 0, 315, 0, - 2145, 301, 302, 303, 304, 305, 0, 306, 307, 308, - 309, 310, 311, 312, 313, 314, 0, 0, 0, 0, - 0, 315, 0, 2146, 301, 302, 303, 304, 305, 0, - 306, 307, 308, 309, 310, 311, 312, 313, 314, 0, - 0, 0, 0, 0, 315, 0, 2204, 301, 302, 303, - 304, 305, 0, 306, 307, 308, 309, 310, 311, 312, - 313, 314, 0, 0, 0, 0, 0, 315, 0, 2205, - 301, 302, 303, 304, 305, 0, 306, 307, 308, 309, - 310, 311, 312, 313, 314, 0, 0, 0, 0, 0, - 315, 0, 2206, 301, 302, 303, 304, 305, 0, 306, - 307, 308, 309, 310, 311, 312, 313, 314, 0, 0, - 0, 0, 0, 315, 0, 2264, 301, 302, 303, 304, - 305, 0, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 0, 0, 0, 0, 0, 315, 0, 2265, 301, - 302, 303, 304, 305, 0, 306, 307, 308, 309, 310, - 311, 312, 313, 314, 0, 0, 0, 0, 0, 315, - 0, 2266, 301, 302, 303, 304, 305, 0, 306, 307, - 308, 309, 310, 311, 312, 313, 314, 0, 0, 0, - 0, 0, 315 + 121, 122, 123, 302, 303, 304, 305, 306, 0, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 93, 327, 0, 316, 0, 473, 97, 98, 99, 100, + 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, + 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, + 0, 0, 0, 0, 0, 328, 0, 0, 128, 129, + 0, 0, 0, 0, 130, 0, 0, 0, 0, 133, + 0, 0, 0, 0, 1143, 514, 43, 44, 45, 46, + 47, 48, 0, 0, 0, 0, 0, 0, 1354, 1355, + 0, 0, 0, 0, 130, 0, 0, 0, 0, 1356, + 93, 288, 468, 0, 0, 170, 97, 98, 99, 100, + 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, + 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, + 0, 121, 122, 123, 0, 1197, 124, 125, 126, 127, + 0, 0, 0, 1207, 0, 0, 0, 0, 0, 0, + 128, 129, 0, 0, 0, 0, 130, 131, 132, 0, + 0, 133, 1226, 134, 0, 135, 0, 0, 0, 0, + 93, 288, 0, 0, 0, 0, 97, 98, 99, 100, + 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, + 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, + 0, 128, 475, 0, 0, 0, 0, 130, 93, 513, + 0, 0, 133, 0, 97, 98, 99, 100, 101, 102, + 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, + 113, 114, 115, 116, 117, 118, 119, 120, 609, 610, + 611, 612, 613, 614, 615, 616, 617, 618, 619, 620, + 621, 622, 623, 624, 625, 626, 627, 628, 629, 630, + 631, 632, 633, 634, 0, 0, -10, 1, 0, -10, + -53, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 128, 129, 0, 0, 0, 0, 130, 0, 0, + 0, 0, 133, 0, 0, 0, 0, 0, 0, -53, + 0, 0, 0, -53, -53, -53, -53, -53, -53, -53, + -53, -53, 0, -53, -53, -53, -53, -53, -53, -53, + -53, 0, 0, 0, -53, -53, -53, -53, -53, -53, + -53, 0, -53, -53, -53, -53, -53, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1372, 0, + 1373, 128, 129, 0, 1377, 0, 0, 130, 0, 0, + 0, 0, 133, 0, -53, -53, -53, 0, 635, 0, + 1393, -53, 0, -53, 0, -53, -53, -53, -53, -53, + -53, -53, 0, -53, 0, 0, 0, 0, 0, 128, + 129, 0, 0, 0, 0, 130, 0, 0, 0, 0, + 133, 0, -10, -10, -10, -10, -10, -10, -10, -10, + 547, 27, 28, 548, 549, 31, 32, 33, 0, 34, + 0, 36, 37, 38, 0, 40, 41, 2, 3, 0, + 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 53, 0, 0, 0, 0, 547, 27, 28, + 548, 549, 31, 32, 33, 0, 34, 0, 36, 37, + 38, 0, 40, 41, 0, 0, 0, 0, 0, 0, + 54, 55, 56, 0, 0, 0, 0, 0, 0, 53, + 0, 0, 0, 0, 0, 0, 0, 1491, 0, 66, + 0, 0, 0, 0, 1496, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 1508, 1509, 54, 55, 56, + 0, 302, 303, 304, 305, 306, 0, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 66, 0, 0, 0, + 0, 316, 0, 0, 0, 0, 204, 1175, 0, 1176, + 0, 0, 0, 0, 302, 303, 304, 305, 306, 1551, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 0, 0, + 1198, 0, 1199, 0, 555, 609, 610, 611, 612, 613, + 614, 615, 616, 617, 618, 619, 620, 621, 622, 623, + 624, 625, 626, 627, 628, 629, 630, 631, 632, 633, + 634, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 781, 1599, 205, 206, 207, 0, 1606, 0, 0, + 0, 208, 209, 210, 211, 212, 213, 214, 215, 216, + 217, 23, 0, 0, 0, 0, 0, 0, 0, 218, + 219, 220, 221, 222, 223, 224, 225, 226, 227, 0, + 228, 229, 230, 231, 232, 233, 0, 0, 0, 0, + 24, 0, 0, 0, 25, 26, 27, 28, 29, 30, + 31, 32, 33, 0, 34, 35, 36, 37, 38, 39, + 40, 41, 0, 0, 0, 42, 43, 44, 45, 46, + 47, 48, 0, 49, 50, 51, 52, 53, 0, 0, + 0, 0, 0, 0, 0, 977, 1694, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1704, 0, 0, 0, + 0, 0, 0, 0, 0, 54, 55, 56, 0, 0, + 0, 0, 57, 0, 58, 0, 59, 60, 61, 62, + 63, 64, 65, 0, 66, 0, 547, 27, 28, 548, + 549, 31, 32, 33, 0, 34, 0, 36, 37, 38, + 0, 40, 41, 302, 303, 304, 305, 306, 0, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 53, 0, + 0, 0, 0, 316, 0, 0, 0, 0, 0, 1352, + 0, 1353, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 1779, 54, 55, 56, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 66, 0, 0, 0, 316, + 0, 0, 302, 303, 304, 305, 306, 749, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 0, 0, 0, 0, 0, 0, 0, + 750, 0, 0, 0, 1831, 302, 303, 304, 305, 306, + 0, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 0, 0, 0, 0, + 0, 0, 0, 890, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 1885, 302, 303, 304, + 305, 306, 914, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 0, 0, + 302, 303, 304, 305, 306, 1173, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 0, 0, 0, 0, 0, 0, 0, 1375, 1930, + 302, 303, 304, 305, 306, 0, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 0, 0, 0, 0, 0, 0, 0, 1376, 0, + 0, 0, 302, 303, 304, 305, 306, 1968, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 0, 0, 302, 303, 304, 305, 306, + 1433, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 0, 0, 302, 303, + 304, 305, 306, 1439, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 0, + 0, 302, 303, 304, 305, 306, 1442, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 0, 0, 302, 303, 304, 305, 306, 1445, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 302, 303, 304, + 305, 306, 1446, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 0, 0, + 302, 303, 304, 305, 306, 1492, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 0, 0, 302, 303, 304, 305, 306, 1553, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 0, 0, 302, 303, 304, 305, + 306, 1556, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 0, 0, 302, + 303, 304, 305, 306, 1558, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 302, 303, 304, 305, 306, 1804, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 0, 0, 302, 303, 304, 305, 306, + 1857, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 0, 473, 0, 0, + 0, 533, 302, 303, 304, 305, 306, 0, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 533, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 534, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 564, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 684, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 685, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 698, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 699, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 700, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 701, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 702, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 703, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 763, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 764, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 765, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 912, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 913, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 932, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1069, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1070, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1084, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1085, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1116, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1117, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1118, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1119, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1120, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1121, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1122, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1123, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1124, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1125, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1126, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1127, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1128, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1129, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1130, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1131, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1132, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1133, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1134, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1135, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1136, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1137, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1138, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1139, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1140, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1141, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1157, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1272, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1286, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1287, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1296, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1299, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1310, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1315, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1318, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1320, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1321, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1322, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1323, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1324, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1325, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1326, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1327, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1328, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1329, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1330, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1331, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1332, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1333, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1334, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1335, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1336, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1337, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1338, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1339, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1340, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1341, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1342, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1343, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1344, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1345, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1349, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1455, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1467, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1468, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1469, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1470, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1471, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1472, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1473, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1474, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1475, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1476, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1477, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1478, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1479, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1480, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1481, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1482, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1483, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1484, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1485, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1486, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1487, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1489, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1571, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1572, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1573, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1574, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1575, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1576, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1577, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1578, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1579, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1580, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1581, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1582, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1583, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1584, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1585, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1586, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1587, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1588, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1589, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1590, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1591, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1667, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1668, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1669, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1670, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1671, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1672, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1673, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1674, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1675, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1676, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1677, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1678, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1679, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1680, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1681, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1682, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1683, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1684, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1685, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1686, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1687, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1744, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1751, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1752, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1753, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1754, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1755, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1756, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1757, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1758, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1759, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1760, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1761, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1762, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1763, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1764, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1765, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1766, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1767, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1768, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1803, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1811, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1812, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1813, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1814, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1815, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1816, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1817, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1818, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1819, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1820, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1821, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1822, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1823, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1824, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1825, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1826, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1827, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1828, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1866, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1867, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1868, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1869, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1870, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1871, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1872, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1873, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1874, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1875, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1876, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1877, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1878, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1879, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1880, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1881, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1882, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1883, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1915, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1916, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1917, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1918, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1919, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1920, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1921, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1922, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1923, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1924, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1925, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1926, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1927, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1928, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1929, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1953, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1954, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1955, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1956, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1957, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1958, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1959, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1960, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 1961, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 1962, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 1963, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 1964, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 1965, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 1966, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 1967, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 1997, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 1998, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 1999, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 2000, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 2001, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 2002, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 2003, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 2004, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 2005, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 2006, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 2007, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 2008, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 2009, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 2010, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 2011, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 2041, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 2042, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 2043, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 2044, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 2045, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 2046, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 2047, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 2048, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 2049, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 2072, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 2073, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 2074, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 2075, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 2076, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 2077, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 2078, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 2079, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 2080, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 2114, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 2115, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 2116, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 2117, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 2118, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 2119, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 2120, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 2121, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 2122, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 2144, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 2145, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 2146, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 2147, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 2148, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 2149, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 2162, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 2163, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 2164, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 2165, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 2166, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 2167, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 2183, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 2184, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 2185, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 2186, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 2187, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 2188, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 2207, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 2208, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 2209, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 2219, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 2220, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 2221, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 2234, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 2235, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 302, 303, 304, 305, 306, + 2236, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 302, 303, 304, 305, + 306, 2252, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 302, 303, 304, + 305, 306, 2253, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 302, 303, + 304, 305, 306, 2254, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 302, + 303, 304, 305, 306, 2258, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 302, 303, 304, 305, 306, 2259, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 302, 303, 304, 305, 306, 2260, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 302, 303, 304, 305, 306, 2264, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 302, 303, 304, 305, 306, 2265, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 302, 303, 304, 305, 306, 2266, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 479, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 606, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 663, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 665, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 667, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 669, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 671, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 673, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 675, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 677, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 679, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 681, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 683, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 687, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 689, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 691, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 693, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 695, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 697, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 766, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 771, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 862, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 1005, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 1007, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 1009, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 1011, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 0, 0, 1012, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 0, 0, 1150, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 503, 302, 303, 304, + 305, 306, 0, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 0, 504, + 302, 303, 304, 305, 306, 0, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 0, 505, 302, 303, 304, 305, 306, 0, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 0, 507, 302, 303, 304, 305, + 306, 0, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 0, 509, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 510, 302, 303, 304, 305, 306, 0, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 0, 518, 302, 303, 304, 305, 306, + 0, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 0, 558, 302, 303, + 304, 305, 306, 0, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 0, + 559, 302, 303, 304, 305, 306, 0, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 0, 562, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 568, 302, 303, 304, + 305, 306, 0, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 0, 662, + 302, 303, 304, 305, 306, 0, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 0, 664, 302, 303, 304, 305, 306, 0, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 0, 666, 302, 303, 304, 305, + 306, 0, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 0, 668, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 670, 302, 303, 304, 305, 306, 0, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 0, 672, 302, 303, 304, 305, 306, + 0, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 0, 674, 302, 303, + 304, 305, 306, 0, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 0, + 676, 302, 303, 304, 305, 306, 0, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 0, 678, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 680, 302, 303, 304, + 305, 306, 0, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 0, 682, + 302, 303, 304, 305, 306, 0, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 0, 686, 302, 303, 304, 305, 306, 0, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 0, 688, 302, 303, 304, 305, + 306, 0, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 0, 690, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 692, 302, 303, 304, 305, 306, 0, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 0, 694, 302, 303, 304, 305, 306, + 0, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 0, 696, 302, 303, + 304, 305, 306, 0, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 0, + 730, 302, 303, 304, 305, 306, 0, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 0, 732, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 745, 302, 303, 304, + 305, 306, 0, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 0, 746, + 302, 303, 304, 305, 306, 0, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 0, 747, 302, 303, 304, 305, 306, 0, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 0, 751, 302, 303, 304, 305, + 306, 0, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 0, 752, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 753, 302, 303, 304, 305, 306, 0, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 0, 754, 302, 303, 304, 305, 306, + 0, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 0, 755, 302, 303, + 304, 305, 306, 0, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 0, + 777, 302, 303, 304, 305, 306, 0, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 0, 784, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 1004, 302, 303, 304, + 305, 306, 0, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 0, 1006, + 302, 303, 304, 305, 306, 0, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 0, 1008, 302, 303, 304, 305, 306, 0, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 0, 1010, 302, 303, 304, 305, + 306, 0, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 0, 1073, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 1174, 302, 303, 304, 305, 306, 0, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 0, 1202, 302, 303, 304, 305, 306, + 0, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 0, 1305, 302, 303, + 304, 305, 306, 0, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 0, + 1309, 302, 303, 304, 305, 306, 0, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 0, 1311, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 1429, 302, 303, 304, + 305, 306, 0, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 0, 1458, + 302, 303, 304, 305, 306, 0, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 0, 1460, 302, 303, 304, 305, 306, 0, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 0, 1462, 302, 303, 304, 305, + 306, 0, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 0, 1464, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 1465, 302, 303, 304, 305, 306, 0, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 0, 1466, 302, 303, 304, 305, 306, + 0, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 0, 1488, 302, 303, + 304, 305, 306, 0, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 0, + 1593, 302, 303, 304, 305, 306, 0, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 0, 1748, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 1749, 302, 303, 304, + 305, 306, 0, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 0, 1750, + 302, 303, 304, 305, 306, 0, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 0, 1912, 302, 303, 304, 305, 306, 0, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 0, 1913, 302, 303, 304, 305, + 306, 0, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 0, 1914, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 2035, 302, 303, 304, 305, 306, 0, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 0, 2036, 302, 303, 304, 305, 306, + 0, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 0, 2037, 302, 303, + 304, 305, 306, 0, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 0, + 2038, 302, 303, 304, 305, 306, 0, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 0, 2039, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316, 0, 2040, 302, 303, 304, + 305, 306, 0, 307, 308, 309, 310, 311, 312, 313, + 314, 315, 0, 0, 0, 0, 0, 316, 0, 2150, + 302, 303, 304, 305, 306, 0, 307, 308, 309, 310, + 311, 312, 313, 314, 315, 0, 0, 0, 0, 0, + 316, 0, 2151, 302, 303, 304, 305, 306, 0, 307, + 308, 309, 310, 311, 312, 313, 314, 315, 0, 0, + 0, 0, 0, 316, 0, 2152, 302, 303, 304, 305, + 306, 0, 307, 308, 309, 310, 311, 312, 313, 314, + 315, 0, 0, 0, 0, 0, 316, 0, 2210, 302, + 303, 304, 305, 306, 0, 307, 308, 309, 310, 311, + 312, 313, 314, 315, 0, 0, 0, 0, 0, 316, + 0, 2211, 302, 303, 304, 305, 306, 0, 307, 308, + 309, 310, 311, 312, 313, 314, 315, 0, 0, 0, + 0, 0, 316, 0, 2212, 302, 303, 304, 305, 306, + 0, 307, 308, 309, 310, 311, 312, 313, 314, 315, + 0, 0, 0, 0, 0, 316, 0, 2270, 302, 303, + 304, 305, 306, 0, 307, 308, 309, 310, 311, 312, + 313, 314, 315, 0, 0, 0, 0, 0, 316, 0, + 2271, 302, 303, 304, 305, 306, 0, 307, 308, 309, + 310, 311, 312, 313, 314, 315, 0, 0, 0, 0, + 0, 316, 0, 2272, 302, 303, 304, 305, 306, 0, + 307, 308, 309, 310, 311, 312, 313, 314, 315, 0, + 0, 0, 0, 0, 316 }; static const short yycheck[] = { 23, - 23, 7, 91, 7, 358, 295, 719, 179, 4, 329, - 4, 183, 4, 4, 44, 45, 4, 285, 286, 287, - 4, 3, 42, 65, 1277, 66, 1279, 65, 1355, 4, - 71, 7, 1359, 1186, 65, 1362, 38, 39, 40, 41, - 42, 43, 44, 45, 102, 47, 4, 49, 50, 51, - 66, 53, 54, 1085, 66, 71, 6, 83, 5, 71, - 4, 5, 1094, 6, 184, 185, 66, 195, 70, 1101, - 196, 71, 165, 201, 200, 196, 66, 184, 185, 200, - 200, 71, 202, 7, 184, 185, 6, 34, 35, 36, - 34, 35, 36, 293, 201, 6, 98, 99, 100, 49, - 200, 195, 202, 197, 128, 129, 130, 184, 185, 133, - 134, 38, 136, 6, 41, 117, 184, 185, 195, 143, - 144, 145, 116, 147, 201, 149, 150, 6, 152, 329, - 105, 106, 200, 195, 202, 6, 166, 195, 168, 201, - 1293, 186, 187, 188, 174, 169, 170, 105, 106, 194, - 6, 184, 185, 195, 191, 192, 869, 195, 66, 201, - 197, 202, 199, 71, 188, 189, 7, 191, 201, 193, - 201, 66, 196, 197, 66, 195, 71, 203, 6, 71, - 500, 184, 185, 184, 185, 38, 202, 477, 41, 42, - 202, 44, 512, 6, 170, 171, 172, 173, 201, 200, - 202, 8, 202, 185, 195, 201, 378, 201, 195, 201, - 478, 241, 202, 201, 238, 191, 192, 201, 195, 243, + 23, 7, 91, 7, 359, 296, 330, 722, 179, 4, + 4, 3, 183, 4, 44, 45, 4, 7, 4, 65, + 65, 4, 65, 42, 1192, 6, 66, 1283, 4, 1285, + 1361, 71, 7, 4, 1365, 66, 6, 1368, 66, 102, + 71, 66, 195, 71, 184, 185, 71, 5, 201, 66, + 83, 66, 6, 66, 71, 1091, 71, 165, 71, 4, + 5, 201, 6, 66, 1100, 184, 185, 7, 71, 66, + 6, 1107, 184, 185, 71, 6, 34, 35, 36, 49, + 6, 200, 66, 202, 6, 184, 185, 71, 200, 34, + 35, 36, 41, 42, 6, 44, 195, 184, 185, 285, + 286, 287, 201, 195, 128, 129, 130, 184, 185, 133, + 134, 7, 136, 200, 196, 202, 184, 185, 200, 143, + 144, 145, 116, 147, 201, 149, 150, 6, 152, 105, + 106, 1299, 195, 201, 105, 106, 166, 38, 168, 294, + 41, 42, 184, 185, 174, 169, 170, 184, 185, 195, + 195, 195, 184, 185, 196, 5, 201, 201, 201, 874, + 6, 7, 202, 200, 188, 189, 195, 191, 200, 193, + 203, 202, 196, 197, 202, 330, 195, 202, 502, 195, + 170, 171, 172, 173, 34, 35, 36, 202, 479, 202, + 514, 38, 65, 185, 41, 170, 171, 172, 173, 202, + 42, 191, 192, 184, 185, 202, 201, 201, 379, 199, + 201, 241, 195, 201, 238, 201, 191, 192, 202, 243, 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, 255, 256, 257, 258, 259, 260, 261, 262, 263, 264, 265, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 280, 281, 282, 283, - 284, 195, 1294, 1590, 184, 185, 1298, 1594, 7, 293, - 1597, 3, 295, 184, 185, 6, 7, 301, 302, 303, + 284, 8, 184, 185, 1300, 1596, 195, 3, 1304, 1600, + 294, 195, 1603, 296, 170, 171, 172, 173, 302, 303, 304, 305, 306, 307, 308, 309, 310, 311, 312, 313, - 314, 315, 195, 1546, 202, 195, 1549, 321, 1551, 323, - 500, 191, 192, 66, 328, 329, 1019, 202, 71, 199, - 202, 195, 512, 337, 338, 339, 340, 7, 342, 343, - 344, 345, 346, 347, 348, 355, 356, 184, 185, 170, - 171, 172, 173, 184, 185, 195, 360, 361, 362, 363, - 184, 185, 366, 200, 65, 184, 185, 184, 185, 200, - 374, 357, 358, 357, 358, 195, 200, 66, 46, 383, - 1687, 200, 71, 200, 1691, 195, 1693, 174, 175, 176, + 314, 315, 316, 196, 480, 6, 1552, 200, 322, 1555, + 324, 1557, 184, 185, 196, 329, 330, 196, 200, 195, + 1025, 200, 184, 185, 338, 339, 340, 341, 200, 343, + 344, 345, 346, 347, 348, 349, 356, 357, 200, 195, + 202, 7, 184, 185, 195, 195, 197, 361, 362, 363, + 364, 191, 192, 367, 55, 184, 185, 502, 200, 199, + 195, 375, 358, 359, 358, 359, 184, 185, 46, 514, + 384, 200, 1693, 196, 191, 192, 1697, 200, 1699, 176, + 177, 178, 200, 180, 181, 182, 183, 184, 185, 186, + 187, 188, 196, 707, 184, 185, 200, 194, 197, 195, + 199, 1647, 184, 185, 42, 1651, 196, 1653, 42, 422, + 136, 137, 138, 139, 140, 141, 142, 143, 200, 184, + 185, 195, 736, 197, 191, 192, 1452, 1453, 1454, 1455, + 606, 8, 199, 1459, 195, 200, 197, 174, 175, 176, + 177, 178, 42, 180, 181, 182, 183, 184, 185, 186, + 187, 188, 44, 767, 768, 769, 38, 194, 472, 41, + 42, 475, 44, 195, 6, 202, 479, 481, 184, 185, + 186, 187, 188, 174, 175, 176, 177, 178, 194, 180, + 181, 182, 183, 184, 185, 186, 187, 188, 502, 8, + 195, 201, 197, 194, 200, 42, 202, 511, 512, 195, + 514, 197, 516, 517, 170, 171, 172, 173, 201, 523, + 191, 192, 532, 195, 4, 197, 197, 6, 199, 533, + 534, 191, 192, 56, 57, 191, 192, 197, 542, 199, + 6, 195, 708, 197, 195, 195, 1562, 1563, 195, 553, + 1566, 180, 181, 182, 183, 184, 185, 186, 187, 188, + 564, 6, 566, 567, 42, 194, 186, 187, 188, 6, + 7, 1266, 707, 4, 194, 177, 178, 712, 180, 181, + 182, 183, 184, 185, 186, 187, 188, 195, 892, 197, + 3, 195, 194, 197, 195, 866, 867, 5, 191, 192, + 195, 736, 197, 606, 197, 6, 199, 174, 175, 176, 177, 178, 195, 180, 181, 182, 183, 184, 185, 186, - 187, 188, 8, 184, 185, 705, 42, 194, 1641, 184, - 185, 195, 1645, 197, 1647, 202, 184, 185, 421, 200, - 197, 196, 199, 42, 136, 137, 138, 139, 140, 141, - 142, 143, 200, 733, 1446, 1447, 1448, 1449, 176, 177, - 178, 1453, 180, 181, 182, 183, 184, 185, 186, 187, - 188, 170, 171, 172, 173, 195, 194, 197, 706, 202, - 184, 185, 191, 192, 764, 765, 766, 42, 197, 473, - 199, 42, 191, 192, 477, 479, 200, 195, 177, 178, - 199, 180, 181, 182, 183, 184, 185, 186, 187, 188, - 38, 44, 6, 41, 42, 194, 500, 184, 185, 201, - 170, 171, 172, 173, 201, 509, 510, 42, 512, 196, - 514, 515, 121, 122, 123, 124, 125, 521, 191, 192, - 530, 191, 192, 6, 197, 705, 199, 531, 532, 709, - 184, 185, 186, 187, 188, 196, 540, 6, 196, 200, - 194, 55, 200, 195, 1556, 1557, 195, 551, 1560, 59, - 60, 61, 62, 733, 64, 196, 191, 192, 562, 200, - 564, 565, 196, 195, 195, 197, 200, 1260, 174, 175, - 176, 177, 178, 6, 180, 181, 182, 183, 184, 185, - 186, 187, 188, 4, 764, 765, 766, 887, 194, 42, - 196, 861, 862, 195, 195, 197, 3, 4, 195, 5, - 197, 604, 9, 10, 11, 12, 13, 14, 15, 16, - 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, - 27, 28, 29, 30, 31, 32, 41, 42, 195, 44, - 197, 38, 195, 195, 197, 197, 195, 4, 197, 1651, - 195, 195, 197, 197, 195, 195, 197, 197, 195, 195, - 197, 197, 59, 60, 61, 62, 63, 64, 56, 57, - 174, 175, 176, 177, 178, 195, 180, 181, 182, 183, - 184, 185, 186, 187, 188, 6, 6, 7, 682, 683, - 194, 3, 195, 195, 197, 197, 195, 195, 197, 197, - 195, 195, 696, 697, 698, 699, 700, 701, 702, 6, - 6, 705, 195, 6, 197, 709, 5, 887, 712, 200, - 200, 202, 202, 200, 724, 202, 200, 721, 202, 1053, - 200, 200, 202, 202, 200, 200, 202, 202, 1740, 733, - 200, 735, 202, 200, 200, 202, 202, 201, 200, 6, - 202, 200, 200, 202, 202, 200, 815, 202, 4, 201, - 760, 761, 762, 200, 200, 202, 202, 200, 195, 202, - 764, 765, 766, 1011, 6, 769, 770, 201, 200, 773, - 202, 200, 200, 202, 202, 195, 786, 184, 185, 195, - 784, 785, 200, 190, 202, 795, 197, 195, 195, 1801, - 200, 200, 202, 202, 201, 200, 200, 202, 202, 201, - 200, 1049, 202, 200, 200, 202, 202, 200, 200, 202, - 202, 200, 200, 202, 202, 819, 820, 821, 822, 823, + 187, 188, 191, 192, 6, 195, 6, 194, 197, 196, + 199, 195, 767, 768, 769, 59, 60, 61, 62, 5, + 64, 1657, 174, 175, 176, 177, 178, 195, 180, 181, + 182, 183, 184, 185, 186, 187, 188, 121, 122, 123, + 124, 125, 194, 201, 195, 174, 175, 176, 177, 178, + 195, 180, 181, 182, 183, 184, 185, 186, 187, 188, + 684, 685, 195, 195, 197, 194, 201, 195, 195, 197, + 197, 195, 195, 197, 698, 699, 700, 701, 702, 703, + 704, 201, 195, 707, 197, 6, 195, 195, 712, 197, + 195, 715, 197, 195, 195, 197, 197, 727, 195, 195, + 724, 197, 4, 195, 1059, 197, 200, 200, 202, 202, + 1746, 200, 736, 202, 738, 200, 195, 202, 200, 200, + 202, 202, 200, 200, 202, 202, 200, 195, 202, 818, + 200, 197, 202, 763, 764, 765, 200, 892, 202, 200, + 200, 202, 202, 767, 768, 769, 201, 195, 772, 773, + 197, 200, 776, 202, 200, 6, 202, 6, 200, 789, + 202, 201, 201, 787, 788, 200, 108, 202, 798, 199, + 201, 1807, 174, 175, 176, 177, 178, 6, 180, 181, + 182, 183, 184, 185, 186, 187, 188, 200, 200, 202, + 202, 200, 194, 202, 200, 200, 202, 202, 195, 823, 824, 825, 826, 827, 828, 829, 830, 831, 832, 833, 834, 835, 836, 837, 838, 839, 840, 841, 842, 843, - 844, 6, 195, 174, 175, 176, 177, 178, 195, 180, - 181, 182, 183, 184, 185, 186, 187, 188, 200, 862, - 202, 195, 200, 194, 202, 200, 870, 202, 174, 175, - 176, 177, 178, 201, 180, 181, 182, 183, 184, 185, - 186, 187, 188, 887, 200, 889, 202, 891, 194, 201, - 195, 180, 181, 182, 183, 184, 185, 186, 187, 188, - 195, 195, 906, 907, 908, 194, 197, 174, 175, 176, - 177, 178, 6, 180, 181, 182, 183, 184, 185, 186, - 187, 188, 199, 927, 928, 929, 932, 194, 201, 108, - 6, 195, 174, 175, 176, 177, 178, 1271, 180, 181, - 182, 183, 184, 185, 186, 187, 188, 195, 195, 195, - 195, 195, 194, 5, 195, 195, 195, 195, 195, 195, - 195, 195, 195, 195, 6, 195, 195, 970, 3, 4, - 195, 195, 1984, 195, 9, 10, 11, 12, 13, 14, - 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, - 25, 26, 27, 28, 29, 30, 31, 32, 195, 6, - 195, 195, 195, 195, 195, 195, 195, 195, 1012, 174, - 175, 176, 177, 178, 1024, 180, 181, 182, 183, 184, - 185, 186, 187, 188, 195, 200, 196, 200, 4, 194, - 194, 199, 7, 7, 1038, 1039, 1040, 7, 1107, 201, - 7, 196, 7, 7, 1054, 1049, 1056, 103, 1058, 201, - 105, 166, 5, 5, 5, 5, 5, 5, 5, 1063, - 1064, 5, 5, 5, 5, 5, 5, 1053, 5, 1053, - 1076, 1075, 5, 5, 1078, 5, 5, 5, 5, 5, - 5, 5, 154, 5, 1088, 5, 5, 5, 3, 5, - 200, 1095, 1096, 1097, 5, 196, 6, 5, 1102, 6, - 4, 6, 1106, 199, 7, 7, 1110, 1111, 1112, 1113, - 1114, 1115, 1116, 1117, 1118, 1119, 1120, 1121, 1122, 1123, + 844, 845, 846, 847, 848, 200, 200, 202, 202, 5, + 200, 1017, 202, 200, 200, 202, 202, 195, 200, 862, + 202, 200, 195, 202, 867, 200, 200, 202, 202, 195, + 200, 875, 202, 174, 175, 176, 177, 178, 195, 180, + 181, 182, 183, 184, 185, 186, 187, 188, 892, 1055, + 894, 195, 896, 194, 200, 200, 202, 202, 200, 195, + 202, 200, 195, 202, 195, 195, 195, 911, 912, 913, + 195, 195, 195, 200, 195, 195, 195, 195, 195, 195, + 195, 195, 195, 195, 937, 195, 195, 195, 932, 933, + 934, 195, 195, 195, 195, 200, 196, 4, 194, 7, + 199, 7, 1277, 174, 175, 176, 177, 178, 201, 180, + 181, 182, 183, 184, 185, 186, 187, 188, 7, 7, + 196, 7, 7, 194, 103, 105, 201, 166, 5, 3, + 4, 154, 975, 5, 1990, 9, 10, 11, 12, 13, + 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, + 24, 25, 26, 27, 28, 29, 30, 31, 32, 5, + 5, 5, 5, 5, 38, 5, 200, 6, 5, 5, + 5, 5, 5, 5, 1018, 5, 5, 5, 5, 5, + 1030, 5, 5, 5, 5, 59, 60, 61, 62, 63, + 64, 5, 5, 5, 5, 3, 5, 196, 5, 5, + 1044, 1045, 1046, 6, 1113, 6, 4, 6, 199, 202, + 1060, 1055, 1062, 7, 1064, 7, 7, 7, 7, 7, + 7, 202, 7, 201, 201, 1069, 1070, 7, 195, 1082, + 7, 199, 167, 1059, 200, 1059, 200, 1081, 200, 200, + 1084, 200, 200, 200, 200, 6, 200, 200, 200, 200, + 1094, 200, 200, 200, 200, 200, 200, 1101, 1102, 1103, + 200, 200, 200, 200, 1108, 5, 200, 200, 1112, 200, + 200, 200, 1116, 1117, 1118, 1119, 1120, 1121, 1122, 1123, 1124, 1125, 1126, 1127, 1128, 1129, 1130, 1131, 1132, 1133, - 1134, 1135, 174, 175, 176, 177, 178, 7, 180, 181, - 182, 183, 184, 185, 186, 187, 188, 1151, 7, 184, - 185, 7, 194, 7, 7, 190, 202, 202, 201, 7, - 195, 201, 7, 198, 195, 1169, 201, 174, 175, 176, - 177, 178, 7, 180, 181, 182, 183, 184, 185, 186, - 187, 188, 6, 199, 167, 200, 200, 194, 1192, 200, - 1194, 200, 1198, 3, 4, 200, 200, 200, 200, 9, - 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, - 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, - 30, 31, 32, 3, 4, 196, 5, 200, 200, 9, - 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, - 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, - 30, 31, 32, 6, 200, 200, 4, 195, 7, 195, - 6, 195, 1266, 6, 1274, 200, 1276, 6, 1278, 200, - 1274, 6, 1276, 7, 1278, 198, 1280, 1281, 195, 200, - 7, 7, 195, 1287, 7, 1271, 200, 1271, 200, 7, - 7, 200, 1296, 7, 200, 195, 7, 7, 7, 200, - 1304, 200, 200, 200, 200, 1309, 200, 200, 1312, 200, - 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322, 1323, + 1134, 1135, 1136, 1137, 1138, 1139, 1140, 1141, 200, 200, + 200, 196, 200, 195, 195, 195, 6, 4, 195, 7, + 184, 185, 195, 1157, 195, 195, 190, 195, 6, 195, + 195, 195, 195, 6, 195, 195, 195, 201, 195, 195, + 195, 1175, 195, 195, 195, 174, 175, 176, 177, 178, + 195, 180, 181, 182, 183, 184, 185, 186, 187, 188, + 198, 1204, 3, 4, 1198, 194, 1200, 195, 9, 10, + 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, + 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, + 31, 32, 3, 4, 6, 195, 6, 4, 9, 10, + 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, + 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, + 31, 32, 195, 174, 175, 176, 177, 178, 197, 180, + 181, 182, 183, 184, 185, 186, 187, 188, 1272, 195, + 1280, 195, 1282, 194, 1284, 7, 1280, 7, 1282, 201, + 1284, 7, 1286, 1287, 7, 7, 7, 7, 7, 1293, + 7, 1277, 7, 1277, 7, 7, 7, 6, 1302, 6, + 4, 7, 7, 3, 163, 3, 1310, 3, 186, 3, + 3, 1315, 3, 3, 1318, 3, 1320, 1321, 1322, 1323, 1324, 1325, 1326, 1327, 1328, 1329, 1330, 1331, 1332, 1333, - 1334, 1335, 1336, 1337, 1338, 1339, 200, 200, 1586, 1349, - 200, 7, 1346, 200, 1348, 1349, 1350, 197, 195, 195, - 174, 175, 176, 177, 178, 195, 180, 181, 182, 183, - 184, 185, 186, 187, 188, 195, 1372, 195, 195, 195, - 194, 7, 195, 195, 184, 185, 195, 195, 195, 195, - 190, 195, 195, 195, 195, 195, 195, 195, 198, 195, - 7, 201, 4, 6, 201, 6, 4, 7, 7, 163, - 3, 3, 3, 186, 184, 185, 3, 3, 3, 3, - 190, 3, 3, 3, 3, 195, 3, 3, 198, 3, - 5, 201, 5, 3, 1428, 3, 196, 6, 4, 196, - 1434, 199, 7, 1437, 1682, 6, 1684, 6, 6, 1445, - 6, 6, 201, 195, 6, 6, 104, 201, 6, 200, - 200, 196, 199, 6, 196, 196, 200, 1461, 1462, 1463, - 1464, 1465, 1466, 1467, 1468, 1469, 1470, 1471, 1472, 1473, - 1474, 1475, 1476, 1477, 1478, 1479, 1480, 1481, 200, 1483, - 174, 175, 176, 177, 178, 200, 180, 181, 182, 183, - 184, 185, 186, 187, 188, 200, 200, 196, 196, 1505, - 194, 6, 4, 200, 200, 200, 200, 200, 202, 200, - 3, 4, 200, 196, 200, 1763, 9, 10, 11, 12, - 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, - 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, - 200, 200, 196, 200, 200, 200, 6, 200, 6, 6, - 198, 6, 6, 6, 6, 6, 6, 6, 1562, 1563, - 1564, 1565, 1566, 1567, 1568, 1569, 1570, 1571, 1572, 1573, + 1334, 1335, 1336, 1337, 1338, 1339, 1340, 1341, 1342, 1343, + 1344, 1345, 3, 3, 3, 1355, 3, 3, 1352, 3, + 1354, 1355, 1356, 5, 5, 3, 3, 6, 4, 196, + 196, 6, 195, 7, 199, 1378, 6, 6, 6, 6, + 6, 201, 6, 184, 185, 6, 104, 201, 200, 190, + 200, 196, 200, 196, 195, 6, 200, 198, 196, 199, + 201, 200, 196, 200, 200, 196, 6, 200, 200, 196, + 200, 200, 200, 184, 185, 200, 200, 200, 200, 190, + 200, 200, 196, 200, 195, 200, 4, 198, 7, 6, + 201, 6, 6, 198, 6, 6, 1592, 6, 6, 6, + 1434, 6, 6, 6, 6, 6, 1440, 6, 1451, 1443, + 6, 6, 6, 6, 6, 3, 104, 6, 3, 6, + 186, 7, 6, 6, 6, 3, 6, 3, 199, 6, + 3, 6, 6, 1467, 1468, 1469, 1470, 1471, 1472, 1473, + 1474, 1475, 1476, 1477, 1478, 1479, 1480, 1481, 1482, 1483, + 1484, 1485, 1486, 1487, 3, 1489, 3, 3, 6, 4, + 198, 201, 6, 174, 175, 176, 177, 178, 1511, 180, + 181, 182, 183, 184, 185, 186, 187, 188, 6, 6, + 6, 101, 201, 194, 196, 202, 6, 201, 201, 3, + 4, 202, 1688, 201, 1690, 9, 10, 11, 12, 13, + 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, + 24, 25, 26, 27, 28, 29, 30, 31, 32, 163, + 6, 6, 3, 6, 6, 106, 3, 200, 200, 200, + 6, 196, 104, 196, 1568, 1569, 1570, 1571, 1572, 1573, 1574, 1575, 1576, 1577, 1578, 1579, 1580, 1581, 1582, 1583, - 1584, 1585, 6, 6, 6, 6, 6, 6, 6, 6, - 6, 3, 4, 7, 104, 3, 1602, 9, 10, 11, - 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, - 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, - 32, 174, 175, 176, 177, 178, 6, 180, 181, 182, - 183, 184, 185, 186, 187, 188, 3, 6, 186, 4, - 6, 194, 6, 3, 1650, 1649, 3, 6, 6, 199, - 6, 1655, 6, 1657, 3, 1659, 6, 1661, 1662, 1663, - 1664, 1665, 1666, 1667, 1668, 1669, 1670, 1671, 1672, 1673, - 1674, 1675, 1676, 1677, 1678, 1679, 1680, 1681, 3, 3, - 3, 7, 198, 151, 6, 6, 6, 6, 6, 157, - 1696, 184, 185, 201, 101, 202, 200, 190, 201, 196, - 201, 201, 195, 201, 200, 200, 6, 196, 201, 200, - 200, 196, 180, 196, 200, 196, 196, 106, 186, 187, - 196, 200, 200, 196, 163, 104, 6, 3, 6, 6, - 3, 6, 6, 1737, 1738, 6, 6, 6, 6, 3, - 6, 1745, 1746, 1747, 1748, 1749, 1750, 1751, 1752, 1753, - 1754, 1755, 1756, 1757, 1758, 1759, 1760, 1761, 1762, 5, - 202, 6, 5, 201, 6, 201, 200, 202, 200, 200, - 200, 196, 184, 185, 200, 6, 6, 6, 190, 6, - 6, 196, 6, 195, 6, 196, 6, 200, 6, 201, - 200, 6, 8, 1797, 6, 6, 6, 6, 1802, 1803, - 1804, 1805, 1806, 1807, 1808, 1809, 1810, 1811, 1812, 1813, - 1814, 1815, 1816, 1817, 1818, 1819, 1820, 1821, 1822, 6, - 174, 175, 176, 177, 178, 5, 180, 181, 182, 183, - 184, 185, 186, 187, 188, 5, 101, 5, 201, 8, - 194, 202, 6, 6, 6, 200, 6, 163, 201, 201, - 1854, 6, 1856, 200, 1858, 200, 1860, 1861, 1862, 1863, - 1864, 1865, 1866, 1867, 1868, 1869, 1870, 1871, 1872, 1873, - 1874, 1875, 1876, 1877, 174, 175, 176, 177, 178, 196, + 1584, 1585, 1586, 1587, 1588, 1589, 1590, 1591, 200, 200, + 196, 200, 196, 196, 6, 1608, 196, 6, 200, 200, + 196, 6, 6, 1769, 6, 6, 3, 6, 6, 5, + 5, 202, 6, 6, 6, 201, 196, 6, 201, 151, + 174, 175, 176, 177, 178, 157, 180, 181, 182, 183, + 184, 185, 186, 187, 188, 202, 196, 6, 6, 200, + 194, 6, 6, 1656, 6, 6, 6, 196, 180, 6, + 6, 1655, 6, 6, 186, 187, 6, 1661, 5, 1663, + 8, 1665, 200, 1667, 1668, 1669, 1670, 1671, 1672, 1673, + 1674, 1675, 1676, 1677, 1678, 1679, 1680, 1681, 1682, 1683, + 1684, 1685, 1686, 1687, 174, 175, 176, 177, 178, 1702, 180, 181, 182, 183, 184, 185, 186, 187, 188, 200, - 196, 200, 200, 200, 194, 6, 201, 201, 201, 201, - 5, 202, 201, 201, 201, 1909, 1910, 1911, 1912, 1913, - 1914, 1915, 1916, 1917, 1918, 1919, 1920, 1921, 1922, 1923, - 201, 200, 6, 6, 6, 6, 101, 6, 200, 196, - 6, 6, 6, 196, 6, 6, 6, 6, 6, 201, - 1944, 1945, 1946, 1947, 1948, 1949, 1950, 1951, 1952, 1953, - 1954, 1955, 1956, 1957, 1958, 1959, 1960, 1961, 174, 175, - 176, 177, 178, 202, 180, 181, 182, 183, 184, 185, - 186, 187, 188, 6, 202, 6, 201, 200, 194, 200, - 168, 1985, 6, 1987, 169, 1989, 200, 1991, 1992, 1993, - 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, - 2004, 2005, 200, 6, 472, 174, 175, 176, 177, 178, + 184, 185, 6, 5, 194, 200, 190, 200, 200, 200, + 196, 195, 201, 200, 198, 8, 201, 201, 174, 175, + 176, 177, 178, 201, 180, 181, 182, 183, 184, 185, + 186, 187, 188, 200, 202, 200, 200, 196, 194, 1743, + 1744, 201, 200, 200, 6, 6, 200, 1751, 1752, 1753, + 1754, 1755, 1756, 1757, 1758, 1759, 1760, 1761, 1762, 1763, + 1764, 1765, 1766, 1767, 1768, 174, 175, 176, 177, 178, 201, 180, 181, 182, 183, 184, 185, 186, 187, 188, - 201, 6, 201, 200, 196, 194, 6, 6, 6, 6, - 201, 2035, 2036, 2037, 2038, 2039, 2040, 2041, 2042, 2043, - 201, 200, 200, 6, 201, 6, 200, 6, 196, 6, - 201, 201, 201, 6, 201, 201, 2060, 2061, 2062, 2063, - 2064, 2065, 2066, 2067, 2068, 2069, 2070, 2071, 2072, 2073, - 2074, 38, 39, 40, 41, 42, 43, 44, 45, 201, - 47, 6, 49, 50, 51, 6, 53, 54, 6, 6, - 6, 201, 2096, 201, 2098, 201, 2100, 6, 2102, 6, - 2104, 6, 2106, 70, 2108, 2109, 2110, 2111, 2112, 2113, - 2114, 2115, 2116, 201, 8, 201, 201, 6, 6, 6, - 6, 201, 6, 201, 201, 6, 0, 0, 7, 606, - 7, 98, 99, 100, 2138, 2139, 2140, 2141, 2142, 2143, - 1015, -1, 8, -1, -1, -1, -1, -1, -1, -1, - 117, -1, 2156, 2157, 2158, 2159, 2160, 2161, 2162, 2163, - 2164, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 2177, 2178, 2179, 2180, 2181, 2182, 2183, - 1069, 2185, -1, 2187, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 2201, 2202, 2203, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 2213, - 2214, 2215, 2216, 2217, 2218, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 2228, 2229, 2230, 2231, -1, 2233, - -1, 2235, -1, -1, -1, 202, -1, -1, -1, -1, - -1, -1, 2246, 2247, 2248, -1, -1, -1, 2252, 2253, - 2254, -1, -1, -1, 2258, 2259, 2260, 725, 726, -1, - 728, -1, 730, 731, -1, -1, 2270, 2271, 2272, -1, - -1, -1, -1, -1, -1, 2279, -1, 2281, -1, 2283, - 174, 175, 176, 177, 178, -1, 180, 181, 182, 183, - 184, 185, 186, 187, 188, -1, -1, -1, -1, -1, - 194, -1, -1, 771, 772, -1, -1, 775, 174, 175, - 176, 177, 178, 8, 180, 181, 182, 183, 184, 185, - 186, 187, 188, -1, 792, 793, -1, -1, 194, -1, - 798, 799, -1, -1, 3, 4, 5, 805, 7, 807, - 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, - 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, - 29, 30, 31, 32, -1, 34, 35, 36, -1, -1, + 174, 175, 176, 177, 178, 194, 180, 181, 182, 183, + 184, 185, 186, 187, 188, 201, 101, 6, 8, 1803, + 194, 201, 6, 6, 1808, 1809, 1810, 1811, 1812, 1813, + 1814, 1815, 1816, 1817, 1818, 1819, 1820, 1821, 1822, 1823, + 1824, 1825, 1826, 1827, 1828, 163, 174, 175, 176, 177, + 178, 6, 180, 181, 182, 183, 184, 185, 186, 187, + 188, 5, 8, 5, 202, 200, 194, 6, 6, 201, + 201, 196, 201, 6, 196, 201, 1860, 200, 1862, 6, + 1864, 201, 1866, 1867, 1868, 1869, 1870, 1871, 1872, 1873, + 1874, 1875, 1876, 1877, 1878, 1879, 1880, 1881, 1882, 1883, + 202, 174, 175, 176, 177, 178, 101, 180, 181, 182, + 183, 184, 185, 186, 187, 188, 6, 6, 6, 6, + 6, 194, 6, 6, 202, 201, 200, 6, 200, 6, + 6, 1915, 1916, 1917, 1918, 1919, 1920, 1921, 1922, 1923, + 1924, 1925, 1926, 1927, 1928, 1929, 6, 168, 6, 169, + 200, 200, 6, 201, 201, 201, 200, 196, 6, 6, + 6, 6, 474, 6, 200, 200, 1950, 1951, 1952, 1953, + 1954, 1955, 1956, 1957, 1958, 1959, 1960, 1961, 1962, 1963, + 1964, 1965, 1966, 1967, 174, 175, 176, 177, 178, 201, + 180, 181, 182, 183, 184, 185, 186, 187, 188, 201, + 201, 200, 6, 6, 194, 6, 6, 1991, 196, 1993, + 201, 1995, 6, 1997, 1998, 1999, 2000, 2001, 2002, 2003, + 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 174, 175, + 176, 177, 178, 201, 180, 181, 182, 183, 184, 185, + 186, 187, 188, 201, 201, 201, 6, 201, 194, 6, + 6, 6, 6, 201, 201, 6, 201, 2041, 2042, 2043, + 2044, 2045, 2046, 2047, 2048, 2049, 6, 6, 6, 201, + 201, 201, 6, 6, 6, 201, 201, 201, 6, 6, + 0, 0, 2066, 2067, 2068, 2069, 2070, 2071, 2072, 2073, + 2074, 2075, 2076, 2077, 2078, 2079, 2080, 38, 39, 40, + 41, 42, 43, 44, 45, 608, 47, 7, 49, 50, + 51, 7, 53, 54, 1021, 1075, -1, -1, 2102, -1, + 2104, -1, 2106, -1, 2108, -1, 2110, -1, 2112, 70, + 2114, 2115, 2116, 2117, 2118, 2119, 2120, 2121, 2122, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 3, 4, -1, -1, -1, -1, 9, 10, 11, - 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, - 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, - 32, 879, -1, 881, -1, -1, 38, -1, -1, -1, - -1, -1, -1, -1, 892, 893, 894, -1, -1, -1, - 898, 899, 900, 901, 902, 903, 904, 59, 60, 61, - 62, 63, 64, -1, 3, 4, 5, -1, -1, -1, - 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, - 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, - 29, 30, 31, 32, -1, 34, 35, 36, -1, 174, - 175, 176, 177, 178, -1, 180, 181, 182, 183, 184, - 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, - -1, 170, 171, 172, 173, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 184, 185, -1, -1, -1, - -1, 190, 191, 192, -1, -1, 195, -1, 197, -1, - 199, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 1010, -1, -1, -1, 174, 175, 176, 177, - 178, -1, 180, 181, 182, 183, 184, 185, 186, 187, - 188, -1, 184, 185, -1, -1, 194, -1, 190, 3, - 4, -1, 200, 195, 202, 9, 10, 11, 12, 13, + -1, -1, -1, -1, -1, -1, -1, 98, 99, 100, + 2144, 2145, 2146, 2147, 2148, 2149, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, 117, -1, 2162, 2163, + 2164, 2165, 2166, 2167, 2168, 2169, 2170, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, 2183, + 2184, 2185, 2186, 2187, 2188, 2189, -1, 2191, -1, 2193, + -1, -1, -1, -1, -1, -1, 728, 729, -1, 731, + -1, 733, 734, 2207, 2208, 2209, -1, -1, -1, -1, + -1, -1, -1, -1, -1, 2219, 2220, 2221, 2222, 2223, + 2224, -1, -1, -1, -1, -1, -1, -1, -1, -1, + 2234, 2235, 2236, 2237, -1, 2239, -1, 2241, -1, -1, + -1, 202, 774, 775, -1, -1, 778, -1, 2252, 2253, + 2254, -1, -1, -1, 2258, 2259, 2260, -1, -1, -1, + 2264, 2265, 2266, 795, 796, -1, -1, -1, -1, 801, + 802, -1, 2276, 2277, 2278, -1, 808, -1, 810, -1, + -1, 2285, -1, 2287, -1, 2289, -1, 3, 4, -1, + -1, -1, -1, 9, 10, 11, 12, 13, 14, 15, + 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, + 26, 27, 28, 29, 30, 31, 32, 3, 4, -1, + -1, -1, -1, 9, 10, 11, 12, 13, 14, 15, + 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, + 26, 27, 28, 29, 30, 31, 32, -1, -1, -1, + -1, -1, 884, -1, 886, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, 897, 898, 899, -1, -1, + -1, 903, 904, 905, 906, 907, 908, 909, -1, 3, + 4, 5, -1, 7, -1, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, -1, - -1, -1, -1, 1071, -1, -1, -1, -1, -1, -1, - -1, 1079, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 184, 185, -1, -1, -1, - 1098, 190, 3, 4, -1, -1, 195, -1, 9, 10, - 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, - 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, - 31, 32, -1, -1, 0, 1, -1, 3, 4, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 38, 39, - 40, 41, 42, 43, 44, 45, -1, 47, -1, 49, - 50, 51, -1, 53, 54, -1, -1, 33, -1, -1, - -1, 37, 38, 39, 40, 41, 42, 43, 44, 45, - 70, 47, 48, 49, 50, 51, 52, 53, 54, -1, - -1, -1, 58, 59, 60, 61, 62, 63, 64, -1, - 66, 67, 68, 69, 70, -1, -1, -1, 98, 99, - 100, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 184, 185, -1, -1, -1, -1, 190, 117, -1, -1, - -1, 195, 98, 99, 100, -1, -1, -1, -1, 105, - -1, 107, -1, 109, 110, 111, 112, 113, 114, 115, - -1, 117, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 136, 137, 138, 139, 140, 141, 142, 143, -1, -1, - -1, -1, -1, 184, 185, -1, 1284, -1, 1286, 190, - 41, -1, 1290, -1, 195, 161, 162, -1, 164, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 1306, -1, - -1, -1, 202, -1, -1, 72, 73, 74, 75, 76, + 34, 35, 36, 174, 175, 176, 177, 178, -1, 180, + 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, + 3, 4, -1, 194, -1, 196, 9, 10, 11, 12, + 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, + 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, + -1, -1, -1, -1, -1, 38, -1, -1, 184, 185, + -1, -1, -1, -1, 190, -1, -1, -1, -1, 195, + -1, -1, -1, -1, 1016, 201, 59, 60, 61, 62, + 63, 64, -1, -1, -1, -1, -1, -1, 184, 185, + -1, -1, -1, -1, 190, -1, -1, -1, -1, 195, + 3, 4, 5, -1, -1, 201, 9, 10, 11, 12, + 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, + 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, + -1, 34, 35, 36, -1, 1077, 170, 171, 172, 173, + -1, -1, -1, 1085, -1, -1, -1, -1, -1, -1, + 184, 185, -1, -1, -1, -1, 190, 191, 192, -1, + -1, 195, 1104, 197, -1, 199, -1, -1, -1, -1, + 3, 4, -1, -1, -1, -1, 9, 10, 11, 12, + 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, + 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, + -1, 184, 185, -1, -1, -1, -1, 190, 3, 4, + -1, -1, 195, -1, 9, 10, 11, 12, 13, 14, + 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, + 25, 26, 27, 28, 29, 30, 31, 32, 72, 73, + 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, + 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, + 94, 95, 96, 97, -1, -1, 0, 1, -1, 3, + 4, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, 184, 185, -1, -1, -1, -1, 190, -1, -1, + -1, -1, 195, -1, -1, -1, -1, -1, -1, 33, + -1, -1, -1, 37, 38, 39, 40, 41, 42, 43, + 44, 45, -1, 47, 48, 49, 50, 51, 52, 53, + 54, -1, -1, -1, 58, 59, 60, 61, 62, 63, + 64, -1, 66, 67, 68, 69, 70, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, 1290, -1, + 1292, 184, 185, -1, 1296, -1, -1, 190, -1, -1, + -1, -1, 195, -1, 98, 99, 100, -1, 202, -1, + 1312, 105, -1, 107, -1, 109, 110, 111, 112, 113, + 114, 115, -1, 117, -1, -1, -1, -1, -1, 184, + 185, -1, -1, -1, -1, 190, -1, -1, -1, -1, + 195, -1, 136, 137, 138, 139, 140, 141, 142, 143, + 38, 39, 40, 41, 42, 43, 44, 45, -1, 47, + -1, 49, 50, 51, -1, 53, 54, 161, 162, -1, + 164, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, 70, -1, -1, -1, -1, 38, 39, 40, + 41, 42, 43, 44, 45, -1, 47, -1, 49, 50, + 51, -1, 53, 54, -1, -1, -1, -1, -1, -1, + 98, 99, 100, -1, -1, -1, -1, -1, -1, 70, + -1, -1, -1, -1, -1, -1, -1, 1429, -1, 117, + -1, -1, -1, -1, 1436, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, 1447, 1448, 98, 99, 100, + -1, 174, 175, 176, 177, 178, -1, 180, 181, 182, + 183, 184, 185, 186, 187, 188, 117, -1, -1, -1, + -1, 194, -1, -1, -1, -1, 41, 200, -1, 202, + -1, -1, -1, -1, 174, 175, 176, 177, 178, 1491, + 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, + -1, -1, -1, -1, 194, -1, -1, -1, -1, -1, + 200, -1, 202, -1, 202, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, - 97, 72, 73, 74, 75, 76, 77, 78, 79, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, - 91, 92, 93, 94, 95, 96, 97, 118, 119, 120, - -1, -1, -1, -1, -1, 126, 127, 128, 129, 130, - 131, 132, 133, 134, 135, -1, -1, -1, -1, -1, - -1, -1, -1, 144, 145, 146, 147, 148, 149, 150, - 151, 152, 153, -1, 155, 156, 157, 158, 159, 160, - -1, -1, -1, -1, -1, -1, -1, -1, 4, -1, - -1, -1, -1, -1, -1, 1423, -1, -1, -1, -1, - -1, -1, 1430, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 1441, 1442, 202, -1, 33, -1, -1, - -1, 37, 38, 39, 40, 41, 42, 43, 44, 45, - -1, 47, 48, 49, 50, 51, 52, 53, 54, -1, - -1, 202, 58, 59, 60, 61, 62, 63, 64, -1, - 66, 67, 68, 69, 70, -1, -1, 1485, -1, 174, + 97, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, 202, 1554, 118, 119, 120, -1, 1559, -1, -1, + -1, 126, 127, 128, 129, 130, 131, 132, 133, 134, + 135, 4, -1, -1, -1, -1, -1, -1, -1, 144, + 145, 146, 147, 148, 149, 150, 151, 152, 153, -1, + 155, 156, 157, 158, 159, 160, -1, -1, -1, -1, + 33, -1, -1, -1, 37, 38, 39, 40, 41, 42, + 43, 44, 45, -1, 47, 48, 49, 50, 51, 52, + 53, 54, -1, -1, -1, 58, 59, 60, 61, 62, + 63, 64, -1, 66, 67, 68, 69, 70, -1, -1, + -1, -1, -1, -1, -1, 202, 1648, -1, -1, -1, + -1, -1, -1, -1, -1, -1, 1658, -1, -1, -1, + -1, -1, -1, -1, -1, 98, 99, 100, -1, -1, + -1, -1, 105, -1, 107, -1, 109, 110, 111, 112, + 113, 114, 115, -1, 117, -1, 38, 39, 40, 41, + 42, 43, 44, 45, -1, 47, -1, 49, 50, 51, + -1, 53, 54, 174, 175, 176, 177, 178, -1, 180, + 181, 182, 183, 184, 185, 186, 187, 188, 70, -1, + -1, -1, -1, 194, -1, -1, -1, -1, -1, 200, + -1, 202, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, 1747, 98, 99, 100, 174, 175, 176, 177, 178, -1, 180, 181, 182, 183, 184, - 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, - -1, -1, 98, 99, 100, 200, -1, 202, -1, 105, - -1, 107, -1, 109, 110, 111, 112, 113, 114, 115, - -1, 117, 38, 39, 40, 41, 42, 43, 44, 45, - -1, 47, -1, 49, 50, 51, -1, 53, 54, -1, - 1548, -1, -1, -1, -1, 1553, -1, -1, -1, 174, - 175, 176, 177, 178, 70, 180, 181, 182, 183, 184, - 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, - -1, -1, -1, -1, -1, -1, -1, 202, -1, -1, - -1, -1, 98, 99, 100, 174, 175, 176, 177, 178, - -1, 180, 181, 182, 183, 184, 185, 186, 187, 188, - -1, 117, -1, -1, -1, 194, -1, -1, 174, 175, - 176, 177, 178, 202, 180, 181, 182, 183, 184, 185, - 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, - -1, -1, -1, -1, 1642, -1, 202, -1, -1, 174, - 175, 176, 177, 178, 1652, 180, 181, 182, 183, 184, - 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, + 185, 186, 187, 188, -1, 117, -1, -1, -1, 194, -1, -1, 174, 175, 176, 177, 178, 202, 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, -1, - -1, -1, 194, -1, -1, 174, 175, 176, 177, 178, - 202, 180, 181, 182, 183, 184, 185, 186, 187, 188, - -1, -1, -1, -1, -1, 194, -1, -1, 174, 175, - 176, 177, 178, 202, 180, 181, 182, 183, 184, 185, - 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, - -1, -1, -1, 1741, -1, -1, 202, 174, 175, 176, - 177, 178, -1, 180, 181, 182, 183, 184, 185, 186, + -1, -1, 194, -1, -1, -1, -1, -1, -1, -1, + 202, -1, -1, -1, 1806, 174, 175, 176, 177, 178, + -1, 180, 181, 182, 183, 184, 185, 186, 187, 188, + -1, -1, -1, -1, -1, 194, -1, -1, -1, -1, + -1, -1, -1, 202, 174, 175, 176, 177, 178, -1, + 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, + -1, -1, -1, -1, 194, -1, 1858, 174, 175, 176, + 177, 178, 202, 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, -1, 174, 175, 176, 177, 178, 202, 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, -1, -1, -1, + 194, -1, -1, -1, -1, -1, -1, -1, 202, 1911, + 174, 175, 176, 177, 178, -1, 180, 181, 182, 183, + 184, 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, -1, -1, -1, -1, -1, -1, 202, -1, - -1, -1, 1800, 174, 175, 176, 177, 178, -1, 180, - 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, - -1, -1, -1, 194, -1, -1, -1, -1, -1, -1, - -1, 202, 174, 175, 176, 177, 178, -1, 180, 181, + -1, -1, 174, 175, 176, 177, 178, 1949, 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, -1, - -1, -1, 194, -1, 1852, 174, 175, 176, 177, 178, + -1, -1, 194, -1, -1, 174, 175, 176, 177, 178, 202, 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, -1, 174, 175, 176, 177, 178, 202, 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, - -1, -1, -1, -1, -1, -1, 202, 1905, 174, 175, - 176, 177, 178, -1, 180, 181, 182, 183, 184, 185, - 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, - -1, -1, -1, -1, -1, -1, 202, -1, -1, -1, - 174, 175, 176, 177, 178, 1943, 180, 181, 182, 183, + -1, 174, 175, 176, 177, 178, 202, 180, 181, 182, + 183, 184, 185, 186, 187, 188, -1, -1, -1, -1, + -1, 194, -1, -1, 174, 175, 176, 177, 178, 202, + 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, + -1, -1, -1, -1, 194, -1, -1, 174, 175, 176, + 177, 178, 202, 180, 181, 182, 183, 184, 185, 186, + 187, 188, -1, -1, -1, -1, -1, 194, -1, -1, + 174, 175, 176, 177, 178, 202, 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, -1, 174, 175, 176, 177, 178, 202, 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, @@ -3792,16 +3808,7 @@ static const short yycheck[] = { 23, -1, -1, -1, -1, 194, -1, -1, -1, 198, 174, 175, 176, 177, 178, -1, 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, - -1, 196, 174, 175, 176, 177, 178, -1, 180, 181, - 182, 183, 184, 185, 186, 187, 188, -1, -1, -1, - -1, -1, 194, -1, 196, 174, 175, 176, 177, 178, - -1, 180, 181, 182, 183, 184, 185, 186, 187, 188, - -1, -1, -1, -1, -1, 194, -1, 196, 174, 175, - 176, 177, 178, -1, 180, 181, 182, 183, 184, 185, - 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, - 196, 174, 175, 176, 177, 178, -1, 180, 181, 182, - 183, 184, 185, 186, 187, 188, -1, -1, -1, -1, - -1, 194, -1, 196, 174, 175, 176, 177, 178, -1, + -1, -1, -1, 198, 174, 175, 176, 177, 178, -1, 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, 196, 174, 175, 176, 177, 178, -1, 180, 181, 182, 183, 184, 185, 186, @@ -3978,7 +3985,16 @@ static const short yycheck[] = { 23, 185, 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, 196, 174, 175, 176, 177, 178, -1, 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, -1, -1, - -1, -1, 194 + -1, -1, 194, -1, 196, 174, 175, 176, 177, 178, + -1, 180, 181, 182, 183, 184, 185, 186, 187, 188, + -1, -1, -1, -1, -1, 194, -1, 196, 174, 175, + 176, 177, 178, -1, 180, 181, 182, 183, 184, 185, + 186, 187, 188, -1, -1, -1, -1, -1, 194, -1, + 196, 174, 175, 176, 177, 178, -1, 180, 181, 182, + 183, 184, 185, 186, 187, 188, -1, -1, -1, -1, + -1, 194, -1, 196, 174, 175, 176, 177, 178, -1, + 180, 181, 182, 183, 184, 185, 186, 187, 188, -1, + -1, -1, -1, -1, 194 }; /* -*-C-*- Note some compilers choke on comments on `#line' lines. */ #line 3 "/usr/share/bison.simple" @@ -5902,7 +5918,7 @@ case 226: { if(CTX.default_plugins){ try { - GMSH_PluginManager::Instance()->SetPluginOption(yyvsp[-6].c, yyvsp[-3].c, yyvsp[-1].d); + GMSH_PluginManager::instance()->setPluginOption(yyvsp[-6].c, yyvsp[-3].c, yyvsp[-1].d); } catch (...) { yymsg(WARNING, "Unknown option '%s' or plugin '%s'", yyvsp[-3].c, yyvsp[-6].c); @@ -5915,7 +5931,7 @@ case 227: { if(CTX.default_plugins){ try { - GMSH_PluginManager::Instance()->SetPluginOption(yyvsp[-6].c, yyvsp[-3].c, yyvsp[-1].c); + GMSH_PluginManager::instance()->setPluginOption(yyvsp[-6].c, yyvsp[-3].c, yyvsp[-1].c); } catch (...) { yymsg(WARNING, "Unknown option '%s' or plugin '%s'", yyvsp[-3].c, yyvsp[-6].c); @@ -6384,7 +6400,6 @@ case 273: #line 1953 "Gmsh.y" { if(!strcmp(yyvsp[-2].c, "Include")){ - yyinTab[RecursionLevel++] = yyin; if(yyvsp[-1].c[0] == '/' || yyvsp[-1].c[0] == '\\' || (strlen(yyvsp[-1].c)>2 && yyvsp[-1].c[1] == ':')){ @@ -6433,39 +6448,45 @@ case 273: CreateOutputFile(yyvsp[-1].c, CTX.mesh.format); #endif } - else if(!strcmp(yyvsp[-2].c, "Merge")){ - FILE *ff = yyin; MergeProblem(yyvsp[-1].c); yyin = ff; - } else if(!strcmp(yyvsp[-2].c, "MergeWithBoundingBox")){ - FILE *ff = yyin; MergeProblemWithBoundingBox(yyvsp[-1].c); yyin = ff; - } else if(!strcmp(yyvsp[-2].c, "Open")){ - FILE *ff = yyin; OpenProblem(yyvsp[-1].c); yyin = ff; - } else if(!strcmp(yyvsp[-2].c, "System")){ - SystemCall(yyvsp[-1].c); - } - else + else{ yymsg(GERROR, "Unknown command '%s'", yyvsp[-2].c); + } ; break;} case 274: -#line 2035 "Gmsh.y" +#line 2026 "Gmsh.y" +{ + if(!strcmp(yyvsp[-6].c, "Save") && !strcmp(yyvsp[-5].c, "View")){ + Post_View *v = (Post_View *)List_Pointer_Test(CTX.post.list, (int)yyvsp[-3].d); + if(v){ + WriteView(0, v, yyvsp[-1].c); + } + } + else{ + yymsg(GERROR, "Unknown command '%s'", yyvsp[-6].c); + } + ; + break;} +case 275: +#line 2038 "Gmsh.y" { if(!strcmp(yyvsp[-2].c, "Sleep")){ @@ -6486,21 +6507,21 @@ case 274: yymsg(GERROR, "Unknown command '%s'", yyvsp[-2].c); ; break;} -case 275: -#line 2055 "Gmsh.y" +case 276: +#line 2058 "Gmsh.y" { if(CTX.default_plugins) - GMSH_PluginManager::Instance()->Action(yyvsp[-4].c, yyvsp[-1].c, 0); + GMSH_PluginManager::instance()->action(yyvsp[-4].c, yyvsp[-1].c, 0); ; break;} -case 276: -#line 2060 "Gmsh.y" +case 277: +#line 2063 "Gmsh.y" { exit(0); ; break;} -case 277: -#line 2064 "Gmsh.y" +case 278: +#line 2067 "Gmsh.y" { #if defined(HAVE_FLTK) if(!CTX.batch){ // we're in interactive mode @@ -6517,8 +6538,8 @@ case 277: #endif ; break;} -case 278: -#line 2086 "Gmsh.y" +case 279: +#line 2089 "Gmsh.y" { LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-3].d ; LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-1].d ; @@ -6529,8 +6550,8 @@ case 278: ImbricatedLoop++; ; break;} -case 279: -#line 2096 "Gmsh.y" +case 280: +#line 2099 "Gmsh.y" { LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-5].d ; LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-3].d ; @@ -6541,8 +6562,8 @@ case 279: ImbricatedLoop++; ; break;} -case 280: -#line 2106 "Gmsh.y" +case 281: +#line 2109 "Gmsh.y" { LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-3].d ; LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-1].d ; @@ -6564,8 +6585,8 @@ case 280: ImbricatedLoop++; ; break;} -case 281: -#line 2127 "Gmsh.y" +case 282: +#line 2130 "Gmsh.y" { LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-5].d ; LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-3].d ; @@ -6587,8 +6608,8 @@ case 281: ImbricatedLoop++; ; break;} -case 282: -#line 2148 "Gmsh.y" +case 283: +#line 2151 "Gmsh.y" { if(LoopControlVariablesTab[ImbricatedLoop-1][1] > LoopControlVariablesTab[ImbricatedLoop-1][0]){ @@ -6610,41 +6631,41 @@ case 282: } ; break;} -case 283: -#line 2169 "Gmsh.y" +case 284: +#line 2172 "Gmsh.y" { if(!FunctionManager::Instance()->createFunction(yyvsp[0].c, yyin, yyname, yylineno)) yymsg(GERROR, "Redefinition of function %s", yyvsp[0].c); skip_until(NULL, "Return"); ; break;} -case 284: -#line 2175 "Gmsh.y" +case 285: +#line 2178 "Gmsh.y" { if(!FunctionManager::Instance()->leaveFunction(&yyin, yyname, yylineno)) yymsg(GERROR, "Error while exiting function"); ; break;} -case 285: -#line 2180 "Gmsh.y" +case 286: +#line 2183 "Gmsh.y" { if(!FunctionManager::Instance()->enterFunction(yyvsp[-1].c, &yyin, yyname, yylineno)) yymsg(GERROR, "Unknown function %s", yyvsp[-1].c); ; break;} -case 286: -#line 2185 "Gmsh.y" +case 287: +#line 2188 "Gmsh.y" { if(!yyvsp[-1].d) skip_until("If", "EndIf"); ; break;} -case 287: -#line 2189 "Gmsh.y" +case 288: +#line 2192 "Gmsh.y" { ; break;} -case 288: -#line 2200 "Gmsh.y" +case 289: +#line 2203 "Gmsh.y" { Curve *pc, *prc; TheShape.Num = Extrude_ProtudePoint(TRANSLATE, (int)yyvsp[-4].d, yyvsp[-2].v[0], yyvsp[-2].v[1], yyvsp[-2].v[2], @@ -6655,8 +6676,8 @@ case 288: List_Add(yyval.l, &TheShape); ; break;} -case 289: -#line 2210 "Gmsh.y" +case 290: +#line 2213 "Gmsh.y" { Curve *pc, *prc; TheShape.Num = Extrude_ProtudePoint(ROTATE, (int)yyvsp[-8].d, 0., 0., 0., @@ -6667,8 +6688,8 @@ case 289: List_Add(yyval.l, &TheShape); ; break;} -case 290: -#line 2220 "Gmsh.y" +case 291: +#line 2223 "Gmsh.y" { Curve *pc, *prc; TheShape.Num = Extrude_ProtudePoint(TRANSLATE_ROTATE, (int)yyvsp[-10].d, yyvsp[-8].v[0], yyvsp[-8].v[1], yyvsp[-8].v[2], @@ -6679,15 +6700,15 @@ case 290: List_Add(yyval.l, &TheShape); ; break;} -case 291: -#line 2230 "Gmsh.y" +case 292: +#line 2233 "Gmsh.y" { extr.mesh.ExtrudeMesh = false; extr.mesh.Recombine = false; ; break;} -case 292: -#line 2235 "Gmsh.y" +case 293: +#line 2238 "Gmsh.y" { Curve *pc, *prc; TheShape.Num = Extrude_ProtudePoint(TRANSLATE, (int)yyvsp[-8].d, yyvsp[-6].v[0], yyvsp[-6].v[1], yyvsp[-6].v[2], @@ -6698,15 +6719,15 @@ case 292: List_Add(yyval.l, &TheShape); ; break;} -case 293: -#line 2245 "Gmsh.y" +case 294: +#line 2248 "Gmsh.y" { extr.mesh.ExtrudeMesh = false; extr.mesh.Recombine = false; ; break;} -case 294: -#line 2250 "Gmsh.y" +case 295: +#line 2253 "Gmsh.y" { Curve *pc, *prc; TheShape.Num = Extrude_ProtudePoint(ROTATE, (int)yyvsp[-12].d, 0., 0., 0., @@ -6717,15 +6738,15 @@ case 294: List_Add(yyval.l, &TheShape); ; break;} -case 295: -#line 2260 "Gmsh.y" +case 296: +#line 2263 "Gmsh.y" { extr.mesh.ExtrudeMesh = false; extr.mesh.Recombine = false; ; break;} -case 296: -#line 2265 "Gmsh.y" +case 297: +#line 2268 "Gmsh.y" { Curve *pc, *prc; TheShape.Num = Extrude_ProtudePoint(TRANSLATE_ROTATE, (int)yyvsp[-14].d, yyvsp[-12].v[0], yyvsp[-12].v[1], yyvsp[-12].v[2], @@ -6736,8 +6757,8 @@ case 296: List_Add(yyval.l, &TheShape); ; break;} -case 297: -#line 2277 "Gmsh.y" +case 298: +#line 2280 "Gmsh.y" { Surface *ps; TheShape.Num = Extrude_ProtudeCurve(TRANSLATE, (int)yyvsp[-4].d, yyvsp[-2].v[0], yyvsp[-2].v[1], yyvsp[-2].v[2], @@ -6755,8 +6776,8 @@ case 297: List_Add(yyval.l, &TheShape); ; break;} -case 298: -#line 2294 "Gmsh.y" +case 299: +#line 2297 "Gmsh.y" { Surface *ps; TheShape.Num = Extrude_ProtudeCurve(ROTATE, (int)yyvsp[-8].d, 0., 0., 0., @@ -6774,8 +6795,8 @@ case 298: List_Add(yyval.l, &TheShape); ; break;} -case 299: -#line 2311 "Gmsh.y" +case 300: +#line 2314 "Gmsh.y" { Surface *ps; TheShape.Num = Extrude_ProtudeCurve(TRANSLATE_ROTATE, (int)yyvsp[-10].d, yyvsp[-8].v[0], yyvsp[-8].v[1], yyvsp[-8].v[2], @@ -6793,15 +6814,15 @@ case 299: List_Add(yyval.l, &TheShape); ; break;} -case 300: -#line 2328 "Gmsh.y" +case 301: +#line 2331 "Gmsh.y" { extr.mesh.ExtrudeMesh = false; extr.mesh.Recombine = false; ; break;} -case 301: -#line 2333 "Gmsh.y" +case 302: +#line 2336 "Gmsh.y" { Surface *ps; TheShape.Num = Extrude_ProtudeCurve(TRANSLATE, (int)yyvsp[-8].d, yyvsp[-6].v[0], yyvsp[-6].v[1], yyvsp[-6].v[2], @@ -6819,15 +6840,15 @@ case 301: List_Add(yyval.l, &TheShape); ; break;} -case 302: -#line 2350 "Gmsh.y" +case 303: +#line 2353 "Gmsh.y" { extr.mesh.ExtrudeMesh = false; extr.mesh.Recombine = false; ; break;} -case 303: -#line 2355 "Gmsh.y" +case 304: +#line 2358 "Gmsh.y" { Surface *ps; TheShape.Num = Extrude_ProtudeCurve(ROTATE, (int)yyvsp[-12].d, 0., 0., 0., @@ -6845,15 +6866,15 @@ case 303: List_Add(yyval.l, &TheShape); ; break;} -case 304: -#line 2372 "Gmsh.y" +case 305: +#line 2375 "Gmsh.y" { extr.mesh.ExtrudeMesh = false; extr.mesh.Recombine = false; ; break;} -case 305: -#line 2377 "Gmsh.y" +case 306: +#line 2380 "Gmsh.y" { Surface *ps; TheShape.Num = Extrude_ProtudeCurve(TRANSLATE_ROTATE, (int)yyvsp[-14].d, yyvsp[-12].v[0], yyvsp[-12].v[1], yyvsp[-12].v[2], @@ -6871,8 +6892,8 @@ case 305: List_Add(yyval.l, &TheShape); ; break;} -case 306: -#line 2397 "Gmsh.y" +case 307: +#line 2400 "Gmsh.y" { TheShape.Num = Extrude_ProtudeSurface(TRANSLATE, (int)yyvsp[-4].d, yyvsp[-2].v[0], yyvsp[-2].v[1], yyvsp[-2].v[2], 0., 0., 0., 0., 0., 0., 0., @@ -6889,8 +6910,8 @@ case 306: List_Add(yyval.l, &TheShape); ; break;} -case 307: -#line 2413 "Gmsh.y" +case 308: +#line 2416 "Gmsh.y" { TheShape.Num = Extrude_ProtudeSurface(ROTATE, (int)yyvsp[-8].d, 0., 0., 0., yyvsp[-6].v[0], yyvsp[-6].v[1], yyvsp[-6].v[2], yyvsp[-4].v[0], yyvsp[-4].v[1], yyvsp[-4].v[2], yyvsp[-2].d, @@ -6907,8 +6928,8 @@ case 307: List_Add(yyval.l, &TheShape); ; break;} -case 308: -#line 2429 "Gmsh.y" +case 309: +#line 2432 "Gmsh.y" { TheShape.Num = Extrude_ProtudeSurface(TRANSLATE_ROTATE, (int)yyvsp[-10].d, yyvsp[-8].v[0], yyvsp[-8].v[1], yyvsp[-8].v[2], yyvsp[-6].v[0], yyvsp[-6].v[1], yyvsp[-6].v[2], yyvsp[-4].v[0], yyvsp[-4].v[1], yyvsp[-4].v[2], yyvsp[-2].d, @@ -6925,15 +6946,15 @@ case 308: List_Add(yyval.l, &TheShape); ; break;} -case 309: -#line 2445 "Gmsh.y" +case 310: +#line 2448 "Gmsh.y" { extr.mesh.ExtrudeMesh = false; extr.mesh.Recombine = false; ; break;} -case 310: -#line 2450 "Gmsh.y" +case 311: +#line 2453 "Gmsh.y" { int vol = NEWREG(); TheShape.Num = Extrude_ProtudeSurface(TRANSLATE, (int)yyvsp[-8].d, yyvsp[-6].v[0], yyvsp[-6].v[1], yyvsp[-6].v[2], @@ -6951,15 +6972,15 @@ case 310: List_Add(yyval.l, &TheShape); ; break;} -case 311: -#line 2467 "Gmsh.y" +case 312: +#line 2470 "Gmsh.y" { extr.mesh.ExtrudeMesh = false; extr.mesh.Recombine = false; ; break;} -case 312: -#line 2473 "Gmsh.y" +case 313: +#line 2476 "Gmsh.y" { int vol = NEWREG(); TheShape.Num = Extrude_ProtudeSurface(ROTATE, (int)yyvsp[-12].d, 0., 0., 0., @@ -6977,15 +6998,15 @@ case 312: List_Add(yyval.l, &TheShape); ; break;} -case 313: -#line 2490 "Gmsh.y" +case 314: +#line 2493 "Gmsh.y" { extr.mesh.ExtrudeMesh = false; extr.mesh.Recombine = false; ; break;} -case 314: -#line 2496 "Gmsh.y" +case 315: +#line 2499 "Gmsh.y" { int vol = NEWREG(); TheShape.Num = Extrude_ProtudeSurface(TRANSLATE_ROTATE, (int)yyvsp[-14].d, yyvsp[-12].v[0], yyvsp[-12].v[1], yyvsp[-12].v[2], @@ -7003,18 +7024,18 @@ case 314: List_Add(yyval.l, &TheShape); ; break;} -case 315: -#line 2516 "Gmsh.y" -{ - ; - break;} case 316: #line 2519 "Gmsh.y" { ; break;} case 317: -#line 2525 "Gmsh.y" +#line 2522 "Gmsh.y" +{ + ; + break;} +case 318: +#line 2528 "Gmsh.y" { double d; extr.mesh.ExtrudeMesh = true; @@ -7041,8 +7062,8 @@ case 317: List_Delete(yyvsp[-2].l); ; break;} -case 318: -#line 2551 "Gmsh.y" +case 319: +#line 2554 "Gmsh.y" { double d; extr.mesh.ExtrudeMesh = true; @@ -7067,14 +7088,14 @@ case 318: List_Delete(yyvsp[-2].l); ; break;} -case 319: -#line 2575 "Gmsh.y" +case 320: +#line 2578 "Gmsh.y" { extr.mesh.Recombine = true; ; break;} -case 320: -#line 2584 "Gmsh.y" +case 321: +#line 2587 "Gmsh.y" { Curve *c; for(i = 0; i < List_Nbr(yyvsp[-3].l); i++){ @@ -7093,8 +7114,8 @@ case 320: List_Delete(yyvsp[-3].l); ; break;} -case 321: -#line 2602 "Gmsh.y" +case 322: +#line 2605 "Gmsh.y" { Curve *c; for(i = 0; i < List_Nbr(yyvsp[-6].l); i++){ @@ -7113,8 +7134,8 @@ case 321: List_Delete(yyvsp[-6].l); ; break;} -case 322: -#line 2620 "Gmsh.y" +case 323: +#line 2623 "Gmsh.y" { Curve *c; for(i = 0; i < List_Nbr(yyvsp[-6].l); i++){ @@ -7133,8 +7154,8 @@ case 322: List_Delete(yyvsp[-6].l); ; break;} -case 323: -#line 2638 "Gmsh.y" +case 324: +#line 2641 "Gmsh.y" { Surface *s = FindSurface((int)yyvsp[-4].d, THEM); if(!s) @@ -7157,8 +7178,8 @@ case 323: List_Delete(yyvsp[-1].l); ; break;} -case 324: -#line 2660 "Gmsh.y" +case 325: +#line 2663 "Gmsh.y" { Surface *s = FindSurface((int)yyvsp[-4].d, THEM); if(!s) @@ -7180,8 +7201,8 @@ case 324: List_Delete(yyvsp[-1].l); ; break;} -case 325: -#line 2681 "Gmsh.y" +case 326: +#line 2684 "Gmsh.y" { Volume *v = FindVolume((int)yyvsp[-4].d, THEM); if(!v) @@ -7203,8 +7224,8 @@ case 325: List_Delete(yyvsp[-1].l); ; break;} -case 326: -#line 2702 "Gmsh.y" +case 327: +#line 2705 "Gmsh.y" { Surface *s; for(i = 0; i < List_Nbr(yyvsp[-3].l); i++){ @@ -7219,8 +7240,8 @@ case 326: List_Delete(yyvsp[-3].l); ; break;} -case 327: -#line 2716 "Gmsh.y" +case 328: +#line 2719 "Gmsh.y" { Surface *s; for(i = 0; i < List_Nbr(yyvsp[-1].l); i++){ @@ -7235,72 +7256,72 @@ case 327: List_Delete(yyvsp[-1].l); ; break;} -case 328: -#line 2736 "Gmsh.y" +case 329: +#line 2739 "Gmsh.y" { ReplaceAllDuplicates(THEM); ; break;} -case 329: -#line 2740 "Gmsh.y" +case 330: +#line 2743 "Gmsh.y" { IntersectAllSegmentsTogether(); ; break;} -case 330: -#line 2749 "Gmsh.y" -{yyval.i = 1;; - break;} case 331: -#line 2750 "Gmsh.y" -{yyval.i = 0;; +#line 2752 "Gmsh.y" +{yyval.i = 1;; break;} case 332: -#line 2751 "Gmsh.y" -{yyval.i = -1;; +#line 2753 "Gmsh.y" +{yyval.i = 0;; break;} case 333: -#line 2752 "Gmsh.y" +#line 2754 "Gmsh.y" {yyval.i = -1;; break;} case 334: -#line 2753 "Gmsh.y" +#line 2755 "Gmsh.y" {yyval.i = -1;; break;} case 335: -#line 2757 "Gmsh.y" -{ yyval.d = yyvsp[0].d; ; +#line 2756 "Gmsh.y" +{yyval.i = -1;; break;} case 336: -#line 2758 "Gmsh.y" -{ yyval.d = yyvsp[-1].d ; ; +#line 2760 "Gmsh.y" +{ yyval.d = yyvsp[0].d; ; break;} case 337: -#line 2759 "Gmsh.y" -{ yyval.d = -yyvsp[0].d ; ; +#line 2761 "Gmsh.y" +{ yyval.d = yyvsp[-1].d ; ; break;} case 338: -#line 2760 "Gmsh.y" -{ yyval.d = yyvsp[0].d; ; +#line 2762 "Gmsh.y" +{ yyval.d = -yyvsp[0].d ; ; break;} case 339: -#line 2761 "Gmsh.y" -{ yyval.d = !yyvsp[0].d ; ; +#line 2763 "Gmsh.y" +{ yyval.d = yyvsp[0].d; ; break;} case 340: -#line 2762 "Gmsh.y" -{ yyval.d = yyvsp[-2].d - yyvsp[0].d ; ; +#line 2764 "Gmsh.y" +{ yyval.d = !yyvsp[0].d ; ; break;} case 341: -#line 2763 "Gmsh.y" -{ yyval.d = yyvsp[-2].d + yyvsp[0].d ; ; +#line 2765 "Gmsh.y" +{ yyval.d = yyvsp[-2].d - yyvsp[0].d ; ; break;} case 342: -#line 2764 "Gmsh.y" -{ yyval.d = yyvsp[-2].d * yyvsp[0].d ; ; +#line 2766 "Gmsh.y" +{ yyval.d = yyvsp[-2].d + yyvsp[0].d ; ; break;} case 343: -#line 2766 "Gmsh.y" +#line 2767 "Gmsh.y" +{ yyval.d = yyvsp[-2].d * yyvsp[0].d ; ; + break;} +case 344: +#line 2769 "Gmsh.y" { if(!yyvsp[0].d) yymsg(GERROR, "Division by zero in '%g / %g'", yyvsp[-2].d, yyvsp[0].d); @@ -7308,236 +7329,236 @@ case 343: yyval.d = yyvsp[-2].d / yyvsp[0].d ; ; break;} -case 344: -#line 2772 "Gmsh.y" -{ yyval.d = (int)yyvsp[-2].d % (int)yyvsp[0].d ; ; - break;} case 345: -#line 2773 "Gmsh.y" -{ yyval.d = pow(yyvsp[-2].d, yyvsp[0].d) ; ; +#line 2775 "Gmsh.y" +{ yyval.d = (int)yyvsp[-2].d % (int)yyvsp[0].d ; ; break;} case 346: -#line 2774 "Gmsh.y" -{ yyval.d = yyvsp[-2].d < yyvsp[0].d ; ; +#line 2776 "Gmsh.y" +{ yyval.d = pow(yyvsp[-2].d, yyvsp[0].d) ; ; break;} case 347: -#line 2775 "Gmsh.y" -{ yyval.d = yyvsp[-2].d > yyvsp[0].d ; ; +#line 2777 "Gmsh.y" +{ yyval.d = yyvsp[-2].d < yyvsp[0].d ; ; break;} case 348: -#line 2776 "Gmsh.y" -{ yyval.d = yyvsp[-2].d <= yyvsp[0].d ; ; +#line 2778 "Gmsh.y" +{ yyval.d = yyvsp[-2].d > yyvsp[0].d ; ; break;} case 349: -#line 2777 "Gmsh.y" -{ yyval.d = yyvsp[-2].d >= yyvsp[0].d ; ; +#line 2779 "Gmsh.y" +{ yyval.d = yyvsp[-2].d <= yyvsp[0].d ; ; break;} case 350: -#line 2778 "Gmsh.y" -{ yyval.d = yyvsp[-2].d == yyvsp[0].d ; ; +#line 2780 "Gmsh.y" +{ yyval.d = yyvsp[-2].d >= yyvsp[0].d ; ; break;} case 351: -#line 2779 "Gmsh.y" -{ yyval.d = yyvsp[-2].d != yyvsp[0].d ; ; +#line 2781 "Gmsh.y" +{ yyval.d = yyvsp[-2].d == yyvsp[0].d ; ; break;} case 352: -#line 2780 "Gmsh.y" -{ yyval.d = yyvsp[-2].d && yyvsp[0].d ; ; +#line 2782 "Gmsh.y" +{ yyval.d = yyvsp[-2].d != yyvsp[0].d ; ; break;} case 353: -#line 2781 "Gmsh.y" -{ yyval.d = yyvsp[-2].d || yyvsp[0].d ; ; +#line 2783 "Gmsh.y" +{ yyval.d = yyvsp[-2].d && yyvsp[0].d ; ; break;} case 354: -#line 2782 "Gmsh.y" -{ yyval.d = yyvsp[-4].d? yyvsp[-2].d : yyvsp[0].d ; ; +#line 2784 "Gmsh.y" +{ yyval.d = yyvsp[-2].d || yyvsp[0].d ; ; break;} case 355: -#line 2783 "Gmsh.y" -{ yyval.d = exp(yyvsp[-1].d); ; +#line 2785 "Gmsh.y" +{ yyval.d = yyvsp[-4].d? yyvsp[-2].d : yyvsp[0].d ; ; break;} case 356: -#line 2784 "Gmsh.y" -{ yyval.d = log(yyvsp[-1].d); ; +#line 2786 "Gmsh.y" +{ yyval.d = exp(yyvsp[-1].d); ; break;} case 357: -#line 2785 "Gmsh.y" -{ yyval.d = log10(yyvsp[-1].d); ; +#line 2787 "Gmsh.y" +{ yyval.d = log(yyvsp[-1].d); ; break;} case 358: -#line 2786 "Gmsh.y" -{ yyval.d = sqrt(yyvsp[-1].d); ; +#line 2788 "Gmsh.y" +{ yyval.d = log10(yyvsp[-1].d); ; break;} case 359: -#line 2787 "Gmsh.y" -{ yyval.d = sin(yyvsp[-1].d); ; +#line 2789 "Gmsh.y" +{ yyval.d = sqrt(yyvsp[-1].d); ; break;} case 360: -#line 2788 "Gmsh.y" -{ yyval.d = asin(yyvsp[-1].d); ; +#line 2790 "Gmsh.y" +{ yyval.d = sin(yyvsp[-1].d); ; break;} case 361: -#line 2789 "Gmsh.y" -{ yyval.d = cos(yyvsp[-1].d); ; +#line 2791 "Gmsh.y" +{ yyval.d = asin(yyvsp[-1].d); ; break;} case 362: -#line 2790 "Gmsh.y" -{ yyval.d = acos(yyvsp[-1].d); ; +#line 2792 "Gmsh.y" +{ yyval.d = cos(yyvsp[-1].d); ; break;} case 363: -#line 2791 "Gmsh.y" -{ yyval.d = tan(yyvsp[-1].d); ; +#line 2793 "Gmsh.y" +{ yyval.d = acos(yyvsp[-1].d); ; break;} case 364: -#line 2792 "Gmsh.y" -{ yyval.d = atan(yyvsp[-1].d); ; +#line 2794 "Gmsh.y" +{ yyval.d = tan(yyvsp[-1].d); ; break;} case 365: -#line 2793 "Gmsh.y" -{ yyval.d = atan2(yyvsp[-3].d, yyvsp[-1].d); ; +#line 2795 "Gmsh.y" +{ yyval.d = atan(yyvsp[-1].d); ; break;} case 366: -#line 2794 "Gmsh.y" -{ yyval.d = sinh(yyvsp[-1].d); ; +#line 2796 "Gmsh.y" +{ yyval.d = atan2(yyvsp[-3].d, yyvsp[-1].d); ; break;} case 367: -#line 2795 "Gmsh.y" -{ yyval.d = cosh(yyvsp[-1].d); ; +#line 2797 "Gmsh.y" +{ yyval.d = sinh(yyvsp[-1].d); ; break;} case 368: -#line 2796 "Gmsh.y" -{ yyval.d = tanh(yyvsp[-1].d); ; +#line 2798 "Gmsh.y" +{ yyval.d = cosh(yyvsp[-1].d); ; break;} case 369: -#line 2797 "Gmsh.y" -{ yyval.d = fabs(yyvsp[-1].d); ; +#line 2799 "Gmsh.y" +{ yyval.d = tanh(yyvsp[-1].d); ; break;} case 370: -#line 2798 "Gmsh.y" -{ yyval.d = floor(yyvsp[-1].d); ; +#line 2800 "Gmsh.y" +{ yyval.d = fabs(yyvsp[-1].d); ; break;} case 371: -#line 2799 "Gmsh.y" -{ yyval.d = ceil(yyvsp[-1].d); ; +#line 2801 "Gmsh.y" +{ yyval.d = floor(yyvsp[-1].d); ; break;} case 372: -#line 2800 "Gmsh.y" -{ yyval.d = fmod(yyvsp[-3].d, yyvsp[-1].d); ; +#line 2802 "Gmsh.y" +{ yyval.d = ceil(yyvsp[-1].d); ; break;} case 373: -#line 2801 "Gmsh.y" +#line 2803 "Gmsh.y" { yyval.d = fmod(yyvsp[-3].d, yyvsp[-1].d); ; break;} case 374: -#line 2802 "Gmsh.y" -{ yyval.d = sqrt(yyvsp[-3].d*yyvsp[-3].d+yyvsp[-1].d*yyvsp[-1].d); ; +#line 2804 "Gmsh.y" +{ yyval.d = fmod(yyvsp[-3].d, yyvsp[-1].d); ; break;} case 375: -#line 2803 "Gmsh.y" -{ yyval.d = yyvsp[-1].d*(double)rand()/(double)RAND_MAX; ; +#line 2805 "Gmsh.y" +{ yyval.d = sqrt(yyvsp[-3].d*yyvsp[-3].d+yyvsp[-1].d*yyvsp[-1].d); ; break;} case 376: -#line 2805 "Gmsh.y" -{ yyval.d = exp(yyvsp[-1].d); ; +#line 2806 "Gmsh.y" +{ yyval.d = yyvsp[-1].d*(double)rand()/(double)RAND_MAX; ; break;} case 377: -#line 2806 "Gmsh.y" -{ yyval.d = log(yyvsp[-1].d); ; +#line 2808 "Gmsh.y" +{ yyval.d = exp(yyvsp[-1].d); ; break;} case 378: -#line 2807 "Gmsh.y" -{ yyval.d = log10(yyvsp[-1].d); ; +#line 2809 "Gmsh.y" +{ yyval.d = log(yyvsp[-1].d); ; break;} case 379: -#line 2808 "Gmsh.y" -{ yyval.d = sqrt(yyvsp[-1].d); ; +#line 2810 "Gmsh.y" +{ yyval.d = log10(yyvsp[-1].d); ; break;} case 380: -#line 2809 "Gmsh.y" -{ yyval.d = sin(yyvsp[-1].d); ; +#line 2811 "Gmsh.y" +{ yyval.d = sqrt(yyvsp[-1].d); ; break;} case 381: -#line 2810 "Gmsh.y" -{ yyval.d = asin(yyvsp[-1].d); ; +#line 2812 "Gmsh.y" +{ yyval.d = sin(yyvsp[-1].d); ; break;} case 382: -#line 2811 "Gmsh.y" -{ yyval.d = cos(yyvsp[-1].d); ; +#line 2813 "Gmsh.y" +{ yyval.d = asin(yyvsp[-1].d); ; break;} case 383: -#line 2812 "Gmsh.y" -{ yyval.d = acos(yyvsp[-1].d); ; +#line 2814 "Gmsh.y" +{ yyval.d = cos(yyvsp[-1].d); ; break;} case 384: -#line 2813 "Gmsh.y" -{ yyval.d = tan(yyvsp[-1].d); ; +#line 2815 "Gmsh.y" +{ yyval.d = acos(yyvsp[-1].d); ; break;} case 385: -#line 2814 "Gmsh.y" -{ yyval.d = atan(yyvsp[-1].d); ; +#line 2816 "Gmsh.y" +{ yyval.d = tan(yyvsp[-1].d); ; break;} case 386: -#line 2815 "Gmsh.y" -{ yyval.d = atan2(yyvsp[-3].d, yyvsp[-1].d); ; +#line 2817 "Gmsh.y" +{ yyval.d = atan(yyvsp[-1].d); ; break;} case 387: -#line 2816 "Gmsh.y" -{ yyval.d = sinh(yyvsp[-1].d); ; +#line 2818 "Gmsh.y" +{ yyval.d = atan2(yyvsp[-3].d, yyvsp[-1].d); ; break;} case 388: -#line 2817 "Gmsh.y" -{ yyval.d = cosh(yyvsp[-1].d); ; +#line 2819 "Gmsh.y" +{ yyval.d = sinh(yyvsp[-1].d); ; break;} case 389: -#line 2818 "Gmsh.y" -{ yyval.d = tanh(yyvsp[-1].d); ; +#line 2820 "Gmsh.y" +{ yyval.d = cosh(yyvsp[-1].d); ; break;} case 390: -#line 2819 "Gmsh.y" -{ yyval.d = fabs(yyvsp[-1].d); ; +#line 2821 "Gmsh.y" +{ yyval.d = tanh(yyvsp[-1].d); ; break;} case 391: -#line 2820 "Gmsh.y" -{ yyval.d = floor(yyvsp[-1].d); ; +#line 2822 "Gmsh.y" +{ yyval.d = fabs(yyvsp[-1].d); ; break;} case 392: -#line 2821 "Gmsh.y" -{ yyval.d = ceil(yyvsp[-1].d); ; +#line 2823 "Gmsh.y" +{ yyval.d = floor(yyvsp[-1].d); ; break;} case 393: -#line 2822 "Gmsh.y" -{ yyval.d = fmod(yyvsp[-3].d, yyvsp[-1].d); ; +#line 2824 "Gmsh.y" +{ yyval.d = ceil(yyvsp[-1].d); ; break;} case 394: -#line 2823 "Gmsh.y" +#line 2825 "Gmsh.y" { yyval.d = fmod(yyvsp[-3].d, yyvsp[-1].d); ; break;} case 395: -#line 2824 "Gmsh.y" -{ yyval.d = sqrt(yyvsp[-3].d*yyvsp[-3].d+yyvsp[-1].d*yyvsp[-1].d); ; +#line 2826 "Gmsh.y" +{ yyval.d = fmod(yyvsp[-3].d, yyvsp[-1].d); ; break;} case 396: -#line 2825 "Gmsh.y" -{ yyval.d = yyvsp[-1].d*(double)rand()/(double)RAND_MAX; ; +#line 2827 "Gmsh.y" +{ yyval.d = sqrt(yyvsp[-3].d*yyvsp[-3].d+yyvsp[-1].d*yyvsp[-1].d); ; break;} case 397: -#line 2834 "Gmsh.y" -{ yyval.d = yyvsp[0].d; ; +#line 2828 "Gmsh.y" +{ yyval.d = yyvsp[-1].d*(double)rand()/(double)RAND_MAX; ; break;} case 398: -#line 2835 "Gmsh.y" -{ yyval.d = 3.141592653589793; ; +#line 2837 "Gmsh.y" +{ yyval.d = yyvsp[0].d; ; break;} case 399: -#line 2836 "Gmsh.y" -{ yyval.d = ParUtil::Instance()->rank(); ; +#line 2838 "Gmsh.y" +{ yyval.d = 3.141592653589793; ; break;} case 400: -#line 2837 "Gmsh.y" -{ yyval.d = ParUtil::Instance()->size(); ; +#line 2839 "Gmsh.y" +{ yyval.d = ParUtil::Instance()->rank(); ; break;} case 401: -#line 2842 "Gmsh.y" +#line 2840 "Gmsh.y" +{ yyval.d = ParUtil::Instance()->size(); ; + break;} +case 402: +#line 2845 "Gmsh.y" { TheSymbol.Name = yyvsp[0].c ; if(!(pSymbol = (Symbol*)Tree_PQuery(Symbol_T, &TheSymbol))) { @@ -7548,8 +7569,8 @@ case 401: yyval.d = *(double*)List_Pointer_Fast(pSymbol->val, 0) ; ; break;} -case 402: -#line 2853 "Gmsh.y" +case 403: +#line 2856 "Gmsh.y" { TheSymbol.Name = yyvsp[-3].c ; if(!(pSymbol = (Symbol*)Tree_PQuery(Symbol_T, &TheSymbol))) { @@ -7566,8 +7587,8 @@ case 402: } ; break;} -case 403: -#line 2870 "Gmsh.y" +case 404: +#line 2873 "Gmsh.y" { TheSymbol.Name = yyvsp[-1].c ; if(!(pSymbol = (Symbol*)Tree_PQuery(Symbol_T, &TheSymbol))) { @@ -7578,8 +7599,8 @@ case 403: yyval.d = (*(double*)List_Pointer_Fast(pSymbol->val, 0) += yyvsp[0].i) ; ; break;} -case 404: -#line 2881 "Gmsh.y" +case 405: +#line 2884 "Gmsh.y" { TheSymbol.Name = yyvsp[-4].c ; if(!(pSymbol = (Symbol*)Tree_PQuery(Symbol_T, &TheSymbol))) { @@ -7596,8 +7617,8 @@ case 404: } ; break;} -case 405: -#line 2900 "Gmsh.y" +case 406: +#line 2903 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-2].c))){ yymsg(GERROR, "Unknown numeric option class '%s'", yyvsp[-2].c); @@ -7613,8 +7634,8 @@ case 405: } ; break;} -case 406: -#line 2916 "Gmsh.y" +case 407: +#line 2919 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-5].c))){ yymsg(GERROR, "Unknown numeric option class '%s'", yyvsp[-5].c); @@ -7630,8 +7651,8 @@ case 406: } ; break;} -case 407: -#line 2932 "Gmsh.y" +case 408: +#line 2935 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-3].c))){ yymsg(GERROR, "Unknown numeric option class '%s'", yyvsp[-3].c); @@ -7647,8 +7668,8 @@ case 407: } ; break;} -case 408: -#line 2948 "Gmsh.y" +case 409: +#line 2951 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-6].c))){ yymsg(GERROR, "Unknown numeric option class '%s'", yyvsp[-6].c); @@ -7664,63 +7685,58 @@ case 408: } ; break;} -case 409: -#line 2966 "Gmsh.y" +case 410: +#line 2969 "Gmsh.y" { memcpy(yyval.v, yyvsp[0].v, 5*sizeof(double)) ; ; break;} -case 410: -#line 2970 "Gmsh.y" +case 411: +#line 2973 "Gmsh.y" { for(i = 0; i < 5; i++) yyval.v[i] = -yyvsp[0].v[i] ; ; break;} -case 411: -#line 2974 "Gmsh.y" +case 412: +#line 2977 "Gmsh.y" { for(i = 0; i < 5; i++) yyval.v[i] = yyvsp[0].v[i]; ; break;} -case 412: -#line 2978 "Gmsh.y" +case 413: +#line 2981 "Gmsh.y" { for(i = 0; i < 5; i++) yyval.v[i] = yyvsp[-2].v[i] - yyvsp[0].v[i] ; ; break;} -case 413: -#line 2982 "Gmsh.y" +case 414: +#line 2985 "Gmsh.y" { for(i = 0; i < 5; i++) yyval.v[i] = yyvsp[-2].v[i] + yyvsp[0].v[i] ; ; break;} -case 414: -#line 2989 "Gmsh.y" +case 415: +#line 2992 "Gmsh.y" { yyval.v[0] = yyvsp[-9].d; yyval.v[1] = yyvsp[-7].d; yyval.v[2] = yyvsp[-5].d; yyval.v[3] = yyvsp[-3].d; yyval.v[4] = yyvsp[-1].d; ; break;} -case 415: -#line 2993 "Gmsh.y" +case 416: +#line 2996 "Gmsh.y" { yyval.v[0] = yyvsp[-7].d; yyval.v[1] = yyvsp[-5].d; yyval.v[2] = yyvsp[-3].d; yyval.v[3] = yyvsp[-1].d; yyval.v[4] = 1.0; ; break;} -case 416: -#line 2997 "Gmsh.y" -{ - yyval.v[0] = yyvsp[-5].d; yyval.v[1] = yyvsp[-3].d; yyval.v[2] = yyvsp[-1].d; yyval.v[3] = 0.0; yyval.v[4] = 1.0; - ; - break;} case 417: -#line 3001 "Gmsh.y" +#line 3000 "Gmsh.y" { yyval.v[0] = yyvsp[-5].d; yyval.v[1] = yyvsp[-3].d; yyval.v[2] = yyvsp[-1].d; yyval.v[3] = 0.0; yyval.v[4] = 1.0; ; break;} case 418: -#line 3008 "Gmsh.y" +#line 3004 "Gmsh.y" { + yyval.v[0] = yyvsp[-5].d; yyval.v[1] = yyvsp[-3].d; yyval.v[2] = yyvsp[-1].d; yyval.v[3] = 0.0; yyval.v[4] = 1.0; ; break;} case 419: @@ -7729,7 +7745,7 @@ case 419: ; break;} case 420: -#line 3017 "Gmsh.y" +#line 3014 "Gmsh.y" { ; break;} @@ -7739,56 +7755,61 @@ case 421: ; break;} case 422: -#line 3026 "Gmsh.y" +#line 3023 "Gmsh.y" { ; break;} case 423: #line 3029 "Gmsh.y" { - yyval.l = yyvsp[-1].l; ; break;} case 424: -#line 3033 "Gmsh.y" +#line 3032 "Gmsh.y" { yyval.l = yyvsp[-1].l; ; break;} case 425: -#line 3040 "Gmsh.y" +#line 3036 "Gmsh.y" { - yyval.l = List_Create(2, 1, sizeof(List_T*)) ; - List_Add(yyval.l, &(yyvsp[0].l)) ; + yyval.l = yyvsp[-1].l; ; break;} case 426: -#line 3045 "Gmsh.y" +#line 3043 "Gmsh.y" { + yyval.l = List_Create(2, 1, sizeof(List_T*)) ; List_Add(yyval.l, &(yyvsp[0].l)) ; ; break;} case 427: -#line 3053 "Gmsh.y" +#line 3048 "Gmsh.y" +{ + List_Add(yyval.l, &(yyvsp[0].l)) ; + ; + break;} +case 428: +#line 3056 "Gmsh.y" { yyval.l = List_Create(2, 1, sizeof(double)) ; List_Add(yyval.l, &(yyvsp[0].d)) ; ; break;} -case 428: -#line 3058 "Gmsh.y" +case 429: +#line 3061 "Gmsh.y" { yyval.l = yyvsp[0].l ; ; break;} -case 429: -#line 3062 "Gmsh.y" +case 430: +#line 3065 "Gmsh.y" { yyval.l = yyvsp[-1].l; ; break;} -case 430: -#line 3066 "Gmsh.y" +case 431: +#line 3069 "Gmsh.y" { yyval.l = yyvsp[-1].l; for(i = 0; i < List_Nbr(yyval.l); i++){ @@ -7797,16 +7818,16 @@ case 430: } ; break;} -case 431: -#line 3077 "Gmsh.y" +case 432: +#line 3080 "Gmsh.y" { yyval.l = List_Create(2, 1, sizeof(double)) ; for(d = yyvsp[-2].d; (yyvsp[-2].d < yyvsp[0].d) ? (d <= yyvsp[0].d) : (d >= yyvsp[0].d); (yyvsp[-2].d < yyvsp[0].d) ? (d += 1.) : (d -= 1.)) List_Add(yyval.l, &d) ; ; break;} -case 432: -#line 3083 "Gmsh.y" +case 433: +#line 3086 "Gmsh.y" { yyval.l = List_Create(2, 1, sizeof(double)) ; if(!yyvsp[0].d || (yyvsp[-4].d < yyvsp[-2].d && yyvsp[0].d < 0) || (yyvsp[-4].d > yyvsp[-2].d && yyvsp[0].d > 0)){ @@ -7818,8 +7839,8 @@ case 432: List_Add(yyval.l, &d) ; ; break;} -case 433: -#line 3094 "Gmsh.y" +case 434: +#line 3097 "Gmsh.y" { // Returns the coordinates of a point and fills a list with it. // This allows to ensure e.g. that relative point positions are @@ -7840,8 +7861,8 @@ case 433: } ; break;} -case 434: -#line 3114 "Gmsh.y" +case 435: +#line 3117 "Gmsh.y" { yyval.l = List_Create(List_Nbr(yyvsp[0].l), 1, sizeof(double)) ; for(int i = 0; i < List_Nbr(yyvsp[0].l); i++){ @@ -7851,8 +7872,8 @@ case 434: } ; break;} -case 435: -#line 3123 "Gmsh.y" +case 436: +#line 3126 "Gmsh.y" { yyval.l = List_Create(List_Nbr(yyvsp[0].l), 1, sizeof(double)) ; for(int i = 0; i < List_Nbr(yyvsp[0].l); i++){ @@ -7862,8 +7883,8 @@ case 435: } ; break;} -case 436: -#line 3132 "Gmsh.y" +case 437: +#line 3135 "Gmsh.y" { // FIXME: The syntax for this is ugly: we get double semi-colons // at the end of the line @@ -7875,8 +7896,8 @@ case 436: } ; break;} -case 437: -#line 3143 "Gmsh.y" +case 438: +#line 3146 "Gmsh.y" { yyval.l = List_Create(2, 1, sizeof(double)) ; TheSymbol.Name = yyvsp[-2].c ; @@ -7891,8 +7912,8 @@ case 437: } ; break;} -case 438: -#line 3157 "Gmsh.y" +case 439: +#line 3160 "Gmsh.y" { yyval.l = List_Create(2, 1, sizeof(double)) ; TheSymbol.Name = yyvsp[-2].c ; @@ -7909,8 +7930,8 @@ case 438: } ; break;} -case 439: -#line 3173 "Gmsh.y" +case 440: +#line 3176 "Gmsh.y" { yyval.l = List_Create(2, 1, sizeof(double)) ; TheSymbol.Name = yyvsp[-5].c ; @@ -7931,8 +7952,8 @@ case 439: List_Delete(yyvsp[-2].l); ; break;} -case 440: -#line 3193 "Gmsh.y" +case 441: +#line 3196 "Gmsh.y" { yyval.l = List_Create(2, 1, sizeof(double)) ; TheSymbol.Name = yyvsp[-5].c ; @@ -7955,27 +7976,27 @@ case 440: List_Delete(yyvsp[-2].l); ; break;} -case 441: -#line 3218 "Gmsh.y" +case 442: +#line 3221 "Gmsh.y" { yyval.l = List_Create(2, 1, sizeof(double)) ; List_Add(yyval.l, &(yyvsp[0].d)) ; ; break;} -case 442: -#line 3223 "Gmsh.y" +case 443: +#line 3226 "Gmsh.y" { yyval.l = yyvsp[0].l ; ; break;} -case 443: -#line 3227 "Gmsh.y" +case 444: +#line 3230 "Gmsh.y" { List_Add(yyval.l, &(yyvsp[0].d)) ; ; break;} -case 444: -#line 3231 "Gmsh.y" +case 445: +#line 3234 "Gmsh.y" { for(i = 0; i < List_Nbr(yyvsp[0].l); i++){ List_Read(yyvsp[0].l, i, &d) ; @@ -7984,27 +8005,27 @@ case 444: List_Delete(yyvsp[0].l); ; break;} -case 445: -#line 3243 "Gmsh.y" +case 446: +#line 3246 "Gmsh.y" { yyval.u = PACK_COLOR((int)yyvsp[-7].d, (int)yyvsp[-5].d, (int)yyvsp[-3].d, (int)yyvsp[-1].d); ; break;} -case 446: -#line 3247 "Gmsh.y" +case 447: +#line 3250 "Gmsh.y" { yyval.u = PACK_COLOR((int)yyvsp[-5].d, (int)yyvsp[-3].d, (int)yyvsp[-1].d, 255); ; break;} -case 447: -#line 3258 "Gmsh.y" +case 448: +#line 3261 "Gmsh.y" { yyval.u = Get_ColorForString(ColorString, -1, yyvsp[0].c, &flag); if(flag) yymsg(GERROR, "Unknown color '%s'", yyvsp[0].c); ; break;} -case 448: -#line 3263 "Gmsh.y" +case 449: +#line 3266 "Gmsh.y" { if(!(pColCat = Get_ColorOptionCategory(yyvsp[-4].c))){ yymsg(GERROR, "Unknown color option class '%s'", yyvsp[-4].c); @@ -8021,14 +8042,14 @@ case 448: } ; break;} -case 449: -#line 3282 "Gmsh.y" +case 450: +#line 3285 "Gmsh.y" { yyval.l = yyvsp[-1].l; ; break;} -case 450: -#line 3286 "Gmsh.y" +case 451: +#line 3289 "Gmsh.y" { yyval.l = List_Create(256, 10, sizeof(unsigned int)) ; GmshColorTable *ct = Get_ColorTable((int)yyvsp[-3].d); @@ -8040,27 +8061,27 @@ case 450: } ; break;} -case 451: -#line 3300 "Gmsh.y" +case 452: +#line 3303 "Gmsh.y" { yyval.l = List_Create(256, 10, sizeof(unsigned int)) ; List_Add(yyval.l, &(yyvsp[0].u)) ; ; break;} -case 452: -#line 3305 "Gmsh.y" +case 453: +#line 3308 "Gmsh.y" { List_Add(yyval.l, &(yyvsp[0].u)) ; ; break;} -case 453: -#line 3312 "Gmsh.y" +case 454: +#line 3315 "Gmsh.y" { yyval.c = yyvsp[0].c; ; break;} -case 454: -#line 3316 "Gmsh.y" +case 455: +#line 3319 "Gmsh.y" { yyval.c = (char *)Malloc((strlen(yyvsp[-3].c)+strlen(yyvsp[-1].c)+1)*sizeof(char)) ; strcpy(yyval.c, yyvsp[-3].c) ; @@ -8069,8 +8090,8 @@ case 454: Free(yyvsp[-1].c); ; break;} -case 455: -#line 3324 "Gmsh.y" +case 456: +#line 3327 "Gmsh.y" { yyval.c = (char *)Malloc((strlen(yyvsp[-1].c)+1)*sizeof(char)) ; for(i = strlen(yyvsp[-1].c)-1; i >= 0; i--){ @@ -8084,14 +8105,14 @@ case 455: Free(yyvsp[-1].c); ; break;} -case 456: -#line 3337 "Gmsh.y" +case 457: +#line 3340 "Gmsh.y" { yyval.c = yyvsp[-1].c; ; break;} -case 457: -#line 3341 "Gmsh.y" +case 458: +#line 3344 "Gmsh.y" { i = PrintListOfDouble(yyvsp[-3].c, yyvsp[-1].l, tmpstring); if(i < 0){ @@ -8110,8 +8131,8 @@ case 457: List_Delete(yyvsp[-1].l); ; break;} -case 458: -#line 3359 "Gmsh.y" +case 459: +#line 3362 "Gmsh.y" { if(!(pStrCat = Get_StringOptionCategory(yyvsp[-3].c))) yymsg(GERROR, "Unknown string option class '%s'", yyvsp[-3].c); @@ -8126,8 +8147,8 @@ case 458: } ; break;} -case 459: -#line 3373 "Gmsh.y" +case 460: +#line 3376 "Gmsh.y" { if(!(pStrCat = Get_StringOptionCategory(yyvsp[-6].c))) yymsg(GERROR, "Unknown string option class '%s'", yyvsp[-6].c); @@ -8364,7 +8385,7 @@ yyerrhandle: } return 1; } -#line 3388 "Gmsh.y" +#line 3391 "Gmsh.y" void DeleteSymbol(void *a, void *b){ diff --git a/Parser/Gmsh.y b/Parser/Gmsh.y index 79b2a0d1a05c63e51017c9707fe82de723d4c29c..e56577f3d762f930ec91a7e63262d9e84302cc1b 100644 --- a/Parser/Gmsh.y +++ b/Parser/Gmsh.y @@ -1,5 +1,5 @@ %{ -// $Id: Gmsh.y,v 1.145 2003-10-29 22:24:24 geuzaine Exp $ +// $Id: Gmsh.y,v 1.146 2003-11-21 07:56:30 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -1508,7 +1508,7 @@ Affectation : { if(CTX.default_plugins){ try { - GMSH_PluginManager::Instance()->SetPluginOption($3, $6, $8); + GMSH_PluginManager::instance()->setPluginOption($3, $6, $8); } catch (...) { yymsg(WARNING, "Unknown option '%s' or plugin '%s'", $6, $3); @@ -1520,7 +1520,7 @@ Affectation : { if(CTX.default_plugins){ try { - GMSH_PluginManager::Instance()->SetPluginOption($3, $6, $8); + GMSH_PluginManager::instance()->setPluginOption($3, $6, $8); } catch (...) { yymsg(WARNING, "Unknown option '%s' or plugin '%s'", $6, $3); @@ -1926,7 +1926,7 @@ Delete : } | tDelete tSTRING '[' FExpr ']' tEND { - if(!strcmp($2, "View")) FreeView((int)$4); + if(!strcmp($2, "View")) RemoveViewByIndex((int)$4); } | tDelete tMesh tEND { @@ -1952,7 +1952,6 @@ Command : tSTRING StringExpr tEND { if(!strcmp($1, "Include")){ - yyinTab[RecursionLevel++] = yyin; if($2[0] == '/' || $2[0] == '\\' || (strlen($2)>2 && $2[1] == ':')){ @@ -2001,36 +2000,40 @@ Command : CreateOutputFile($2, CTX.mesh.format); #endif } - else if(!strcmp($1, "Merge")){ - FILE *ff = yyin; MergeProblem($2); yyin = ff; - } else if(!strcmp($1, "MergeWithBoundingBox")){ - FILE *ff = yyin; MergeProblemWithBoundingBox($2); yyin = ff; - } else if(!strcmp($1, "Open")){ - FILE *ff = yyin; OpenProblem($2); yyin = ff; - } else if(!strcmp($1, "System")){ - SystemCall($2); - } - else + else{ yymsg(GERROR, "Unknown command '%s'", $1); + } } + | tSTRING tSTRING '[' FExpr ']' StringExpr tEND + { + if(!strcmp($1, "Save") && !strcmp($2, "View")){ + Post_View *v = (Post_View *)List_Pointer_Test(CTX.post.list, (int)$4); + if(v){ + WriteView(0, v, $6); + } + } + else{ + yymsg(GERROR, "Unknown command '%s'", $1); + } + } | tSTRING FExpr tEND { if(!strcmp($1, "Sleep")){ @@ -2054,7 +2057,7 @@ Command : | tPlugin '(' tSTRING ')' '.' tSTRING tEND { if(CTX.default_plugins) - GMSH_PluginManager::Instance()->Action($3, $6, 0); + GMSH_PluginManager::instance()->action($3, $6, 0); } | tExit tEND { diff --git a/Parser/Gmsh.yy.cpp b/Parser/Gmsh.yy.cpp index 2f118d448aa61e627def88de9e265ce5f10791f2..427a5f73ac0e2b4a42dfa34a2955f8d5875d7ce7 100644 --- a/Parser/Gmsh.yy.cpp +++ b/Parser/Gmsh.yy.cpp @@ -2,7 +2,7 @@ /* A lexical scanner generated by flex */ /* Scanner skeleton version: - * $Header: /cvsroot/gmsh/Parser/Gmsh.yy.cpp,v 1.164 2003-10-29 22:24:25 geuzaine Exp $ + * $Header: /cvsroot/gmsh/Parser/Gmsh.yy.cpp,v 1.165 2003-11-21 07:56:31 geuzaine Exp $ */ #define FLEX_SCANNER @@ -1013,7 +1013,7 @@ char *yytext; #define INITIAL 0 #line 2 "Gmsh.l" -// $Id: Gmsh.yy.cpp,v 1.164 2003-10-29 22:24:25 geuzaine Exp $ +// $Id: Gmsh.yy.cpp,v 1.165 2003-11-21 07:56:31 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // diff --git a/Plugin/CutMap.cpp b/Plugin/CutMap.cpp index 78dde28c8515f9f7723a7b5a91f575ef36956b25..482f687dd090eaf6c3045b49cf9a77d68beaaf7b 100644 --- a/Plugin/CutMap.cpp +++ b/Plugin/CutMap.cpp @@ -1,4 +1,4 @@ -// $Id: CutMap.cpp,v 1.31 2003-11-14 21:20:55 geuzaine Exp $ +// $Id: CutMap.cpp,v 1.32 2003-11-21 07:56:31 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -27,7 +27,8 @@ extern Context_T CTX; StringXNumber CutMapOptions_Number[] = { {GMSH_FULLRC, "A", NULL, 1.}, - {GMSH_FULLRC, "iField", NULL, 0.}, + {GMSH_FULLRC, "TimeStep", NULL, -1.}, + {GMSH_FULLRC, "dView", NULL, -1.}, {GMSH_FULLRC, "iView", NULL, -1.} }; @@ -39,7 +40,6 @@ extern "C" } } - GMSH_CutMapPlugin::GMSH_CutMapPlugin() { ; @@ -57,10 +57,13 @@ void GMSH_CutMapPlugin::getInfos(char *author, char *copyright, strcpy(copyright, "DGR (www.multiphysics.com)"); strcpy(help_text, "Plugin(CutMap) extracts the isovalue surface of\n" - "value 'A' from the simplectic 3D scalar view\n" - "'iView' and draws the 'iField'-th component of\n" - "the field on the iso. If 'iView' < 0, the plugin\n" - "is run on the current view.\n"); + "value 'A' from the view 'iView' and draws the\n" + "'TimeStep'-th value of the view 'dView' on this\n" + "isovalue surface. If 'iView' < 0, the plugin is\n" + "run on the current view. If 'TimeStep' < 0, the\n" + "plugin uses, for each time step in 'iView', the\n" + "corresponding time step in 'dView'. If 'dView'\n" + "< 0, the plugin uses 'iView' as the field source.\n"); } int GMSH_CutMapPlugin::getNbOptions() const @@ -68,12 +71,12 @@ int GMSH_CutMapPlugin::getNbOptions() const return sizeof(CutMapOptions_Number) / sizeof(StringXNumber); } -StringXNumber *GMSH_CutMapPlugin::GetOption(int iopt) +StringXNumber *GMSH_CutMapPlugin::getOption(int iopt) { return &CutMapOptions_Number[iopt]; } -void GMSH_CutMapPlugin::CatchErrorMessage(char *errorMessage) const +void GMSH_CutMapPlugin::catchErrorMessage(char *errorMessage) const { strcpy(errorMessage, "CutMap failed..."); } @@ -90,9 +93,11 @@ Post_View *GMSH_CutMapPlugin::execute(Post_View * v) { Post_View *vv; - _ith_field_to_draw_on_the_iso = (int)CutMapOptions_Number[1].def; - int iView = (int)CutMapOptions_Number[2].def; - _orientation = ORIENT_MAP; + int iView = (int)CutMapOptions_Number[3].def; + _valueIndependent = 0; + _targetView = (int)CutMapOptions_Number[2].def; + _orientation = GMSH_LevelsetPlugin::MAP; + _timeStep = (int)CutMapOptions_Number[1].def; if(v && iView < 0) vv = v; diff --git a/Plugin/CutMap.h b/Plugin/CutMap.h index b99c60939978f993b55e56dc3f4226528791e48c..6073fc20cb94c075d31cd4fe1f0f9f536c4ab051 100644 --- a/Plugin/CutMap.h +++ b/Plugin/CutMap.h @@ -1,5 +1,5 @@ -#ifndef _CUTMAP_H_ -#define _CUTMAP_H +#ifndef _CUT_MAP_H_ +#define _CUT_MAP_H // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -20,25 +20,23 @@ // // Please report all bugs and problems to "gmsh@geuz.org". -#include "LevelsetPlugin.h" +#include "Levelset.h" extern "C" { - GMSH_Plugin *GMSH_RegisterCutMapPlugin (); + GMSH_Plugin *GMSH_RegisterCutMapPlugin(); } class GMSH_CutMapPlugin : public GMSH_LevelsetPlugin { - double levelset (double x, double y, double z, double val) const; -public: + double levelset(double x, double y, double z, double val) const; + public: GMSH_CutMapPlugin(); - void getName (char *name) const; - void getInfos (char *author, - char *copyright, - char *help_text) const; - void CatchErrorMessage (char *errorMessage) const; + void getName(char *name) const; + void getInfos(char *author, char *copyright, char *helpText) const; + void catchErrorMessage(char *errorMessage) const; int getNbOptions() const; - StringXNumber* GetOption (int iopt); + StringXNumber* getOption (int iopt); Post_View *execute (Post_View *); }; diff --git a/Plugin/CutPlane.cpp b/Plugin/CutPlane.cpp index b3a43c06c069a1a3e8ad9989615b31b5f56c85f4..dbc972e225cc71044b1027c4d8a6c47a507b9743 100644 --- a/Plugin/CutPlane.cpp +++ b/Plugin/CutPlane.cpp @@ -1,4 +1,4 @@ -// $Id: CutPlane.cpp,v 1.27 2003-11-14 21:20:55 geuzaine Exp $ +// $Id: CutPlane.cpp,v 1.28 2003-11-21 07:56:31 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -58,10 +58,10 @@ void GMSH_CutPlanePlugin::getInfos(char *author, char *copyright, strcpy(author, "J.-F. Remacle (remacle@scorec.rpi.edu)"); strcpy(copyright, "DGR (www.multiphysics.com)"); strcpy(help_text, - "Plugin(CutPlane) cuts the simplectic 3D scalar\n" - "view 'iView' with the plane 'A'*X + 'B'*Y + 'C'*Z +\n" - "'D' = 0. If 'iView' < 0, the plugin is run on the\n" - "current view.\n"); + "Plugin(CutPlane) cuts the view 'iView' with\n" + "the plane 'A'*X + 'B'*Y + 'C'*Z + 'D' = 0. If\n" + "'iView' < 0, the plugin is run on the current\n" + "view.\n"); } int GMSH_CutPlanePlugin::getNbOptions() const @@ -69,12 +69,12 @@ int GMSH_CutPlanePlugin::getNbOptions() const return sizeof(CutPlaneOptions_Number) / sizeof(StringXNumber); } -StringXNumber *GMSH_CutPlanePlugin::GetOption(int iopt) +StringXNumber *GMSH_CutPlanePlugin::getOption(int iopt) { return &CutPlaneOptions_Number[iopt]; } -void GMSH_CutPlanePlugin::CatchErrorMessage(char *errorMessage) const +void GMSH_CutPlanePlugin::catchErrorMessage(char *errorMessage) const { strcpy(errorMessage, "CutPlane failed..."); } @@ -91,10 +91,13 @@ Post_View *GMSH_CutPlanePlugin::execute(Post_View * v) Post_View *vv; int iView = (int)CutPlaneOptions_Number[4].def; - _orientation = ORIENT_PLANE; _ref[0] = CutPlaneOptions_Number[0].def; _ref[1] = CutPlaneOptions_Number[1].def; _ref[2] = CutPlaneOptions_Number[2].def; + _valueIndependent = 1; + _targetView = -1; + _orientation = GMSH_LevelsetPlugin::PLANE; + _timeStep = -1; if(v && iView < 0) vv = v; diff --git a/Plugin/CutPlane.h b/Plugin/CutPlane.h index 6a05c51f6e63d4fc6b3162c8ffd9b241bef5c263..3afcad55b73c8a8b5a5325f40d798cba60e6281c 100644 --- a/Plugin/CutPlane.h +++ b/Plugin/CutPlane.h @@ -1,5 +1,5 @@ -#ifndef _CUTPLANE_H_ -#define _CUTPLANE_H +#ifndef _CUT_PLANE_H_ +#define _CUT_PLANE_H // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -20,26 +20,24 @@ // // Please report all bugs and problems to "gmsh@geuz.org". -#include "LevelsetPlugin.h" +#include "Levelset.h" extern "C" { - GMSH_Plugin *GMSH_RegisterCutPlanePlugin (); + GMSH_Plugin *GMSH_RegisterCutPlanePlugin(); } class GMSH_CutPlanePlugin : public GMSH_LevelsetPlugin { - double levelset (double x, double y, double z, double val) const; + double levelset(double x, double y, double z, double val) const; public: GMSH_CutPlanePlugin(); - void getName (char *name) const; - void getInfos (char *author, - char *copyright, - char *help_text) const; - void CatchErrorMessage (char *errorMessage) const; + void getName(char *name) const; + void getInfos(char *author, char *copyright, char *helpText) const; + void catchErrorMessage(char *errorMessage) const; int getNbOptions() const; - StringXNumber *GetOption (int iopt); - Post_View *execute (Post_View *); + StringXNumber *getOption(int iopt); + Post_View *execute(Post_View *); }; #endif diff --git a/Plugin/CutSphere.cpp b/Plugin/CutSphere.cpp index fc5d44c8c231fc256adfb48e905d08b3f88c0a78..c13efb58181756e2e27dff76cada8791cee2fa98 100644 --- a/Plugin/CutSphere.cpp +++ b/Plugin/CutSphere.cpp @@ -1,4 +1,4 @@ -// $Id: CutSphere.cpp,v 1.26 2003-11-14 21:20:55 geuzaine Exp $ +// $Id: CutSphere.cpp,v 1.27 2003-11-21 07:56:32 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -59,10 +59,10 @@ void GMSH_CutSpherePlugin::getInfos(char *author, char *copyright, strcpy(author, "J.-F. Remacle (remacle@scorec.rpi.edu)"); strcpy(copyright, "DGR (www.multiphysics.com)"); strcpy(help_text, - "Plugin(CutSphere) cuts the simplectic 3D scalar\n" - "view 'iView' with the sphere (X-'Xc')^2 + (Y-'Yc')^2 +\n" - "(Z-'Zc')^2 = 'R'^2. If 'iView' < 0, the plugin is\n" - "run on the current view.\n"); + "Plugin(CutSphere) cuts the view 'iView' with the\n" + "sphere (X-'Xc')^2 + (Y-'Yc')^2 + (Z-'Zc')^2 = 'R'^2.\n" + "If 'iView' < 0, the plugin is run on the current\n" + "view.\n"); } int GMSH_CutSpherePlugin::getNbOptions() const @@ -70,12 +70,12 @@ int GMSH_CutSpherePlugin::getNbOptions() const return sizeof(CutSphereOptions_Number) / sizeof(StringXNumber); } -StringXNumber *GMSH_CutSpherePlugin::GetOption(int iopt) +StringXNumber *GMSH_CutSpherePlugin::getOption(int iopt) { return &CutSphereOptions_Number[iopt]; } -void GMSH_CutSpherePlugin::CatchErrorMessage(char *errorMessage) const +void GMSH_CutSpherePlugin::catchErrorMessage(char *errorMessage) const { strcpy(errorMessage, "CutSphere failed..."); } @@ -95,10 +95,13 @@ Post_View *GMSH_CutSpherePlugin::execute(Post_View * v) Post_View *vv; int iView = (int)CutSphereOptions_Number[4].def; - _orientation = ORIENT_SPHERE; _ref[0] = CutSphereOptions_Number[0].def; _ref[1] = CutSphereOptions_Number[1].def; _ref[2] = CutSphereOptions_Number[2].def; + _valueIndependent = 1; + _targetView = -1; + _orientation = GMSH_LevelsetPlugin::SPHERE; + _timeStep = -1; if(v && iView < 0) vv = v; diff --git a/Plugin/CutSphere.h b/Plugin/CutSphere.h index e9d47b69d80299de6c2430b35b8e6a014ee97aab..12e1ceddd43301ce42c86728d2cfd94b620898fd 100644 --- a/Plugin/CutSphere.h +++ b/Plugin/CutSphere.h @@ -1,5 +1,5 @@ -#ifndef _CUTSPHERE_H_ -#define _CUTSPHERE_H +#ifndef _CUT_SPHERE_H_ +#define _CUT_SPHERE_H // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -20,26 +20,24 @@ // // Please report all bugs and problems to "gmsh@geuz.org". -#include "LevelsetPlugin.h" +#include "Levelset.h" extern "C" { - GMSH_Plugin *GMSH_RegisterCutSpherePlugin (); + GMSH_Plugin *GMSH_RegisterCutSpherePlugin(); } class GMSH_CutSpherePlugin : public GMSH_LevelsetPlugin { - double levelset (double x, double y, double z, double val) const; + double levelset(double x, double y, double z, double val) const; public: GMSH_CutSpherePlugin(); - void getName (char *name) const; - void getInfos (char *author, - char *copyright, - char *help_text) const; - void CatchErrorMessage (char *errorMessage) const; + void getName(char *name) const; + void getInfos(char *author, char *copyright, char *helpText) const; + void catchErrorMessage(char *errorMessage) const; int getNbOptions() const; - StringXNumber* GetOption (int iopt); - Post_View *execute (Post_View *); + StringXNumber* getOption(int iopt); + Post_View *execute(Post_View *); }; #endif diff --git a/Plugin/DecomposeInSimplex.cpp b/Plugin/DecomposeInSimplex.cpp index 83d26b65d496423e8daf142e0bc8c5f311ed5ec8..bab2995e08bd3826094a580da08628cca0e6e43b 100644 --- a/Plugin/DecomposeInSimplex.cpp +++ b/Plugin/DecomposeInSimplex.cpp @@ -1,4 +1,4 @@ -// $Id: DecomposeInSimplex.cpp,v 1.2 2003-11-14 21:20:55 geuzaine Exp $ +// $Id: DecomposeInSimplex.cpp,v 1.3 2003-11-21 07:56:32 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -68,12 +68,12 @@ int GMSH_DecomposeInSimplexPlugin::getNbOptions() const return sizeof(DecomposeInSimplexOptions_Number) / sizeof(StringXNumber); } -StringXNumber *GMSH_DecomposeInSimplexPlugin::GetOption(int iopt) +StringXNumber *GMSH_DecomposeInSimplexPlugin::getOption(int iopt) { return &DecomposeInSimplexOptions_Number[iopt]; } -void GMSH_DecomposeInSimplexPlugin::CatchErrorMessage(char *errorMessage) const +void GMSH_DecomposeInSimplexPlugin::catchErrorMessage(char *errorMessage) const { strcpy(errorMessage, "DecomposeInSimplex failed..."); } @@ -110,12 +110,50 @@ Post_View *GMSH_DecomposeInSimplexPlugin::execute(Post_View * v) return 0; } -void GMSH_DecomposeInSimplexPlugin::Run() +// Utility class +int DecomposeInSimplex::num() { - execute(0); + switch(_numNodes){ + case 4 : return 2; // quad -> 2 tris + case 5 : return 2; // pyramid -> 2 tets + case 6 : return 3; // prism -> 3 tets + case 8 : return 6; // hexa -> 6 tets + } } -void GMSH_DecomposeInSimplexPlugin::Save() +int DecomposeInSimplex::numNodes() { - ; + if(_numNodes == 4) + return 3; // quad -> tris + else + return 4; // all others -> tets +} + +void DecomposeInSimplex::decompose() +{ +#if 0 + switch(_numNodes){ + case 4: // quad + 0 1 2 + 0 2 3 + break ; + + case 8: // hexa + 0 1 2 5 + 0 2 5 6 + 0 4 5 6 + 0 2 3 6 + 0 4 6 7 + 0 3 6 7 + + case 6: // prism + 0 1 2 4 + 0 2 4 5 + 0 3 4 5 + + case 5: // pyramid + 0 1 3 4 + 1 2 3 4 + } +#endif } diff --git a/Plugin/DecomposeInSimplex.h b/Plugin/DecomposeInSimplex.h index 3e16857ce9b8df41d93bb2de7cabc5206e3c25a7..70dcac93ec0ec263a7aba22091bd8a0184a60fd5 100644 --- a/Plugin/DecomposeInSimplex.h +++ b/Plugin/DecomposeInSimplex.h @@ -20,24 +20,44 @@ // // Please report all bugs and problems to "gmsh@geuz.org". +#include "Plugin.h" + extern "C" { - GMSH_Plugin *GMSH_RegisterDecomposeInSimplexPlugin (); + GMSH_Plugin *GMSH_RegisterDecomposeInSimplexPlugin(); } class GMSH_DecomposeInSimplexPlugin : public GMSH_Post_Plugin { public: GMSH_DecomposeInSimplexPlugin(); - void Run(); - void Save(); - void getName (char *name) const; - void getInfos (char *author, - char *copyright, - char *help_text) const; - void CatchErrorMessage (char *errorMessage) const; + void getName(char *name) const; + void getInfos(char *author, char *copyright, char *help_text) const; + void catchErrorMessage(char *errorMessage) const; int getNbOptions() const; - StringXNumber* GetOption (int iopt); - Post_View *execute (Post_View *); + StringXNumber* getOption(int iopt); + Post_View *execute(Post_View *); +}; + +class DecomposeInSimplex{ + private: + // how many nodes in the element to decompose + int _numNodes; + // how many field components + int _numComponents; + // how many time steps + int _numTimeSteps; + public: + // default constructor + DecomposeInSimplex(int numNodes, int numComponents, int numTimeSteps) + : _numNodes(numNodes), _numComponents(numComponents), + _numTimeSteps(numTimeSteps) { ; } + // the number of simplices into which the element is decomposed + int num(); + // the number of nodes of the simplex + int numNodes(); + // returns the i-th simplex in the decomposition + void decompose(); }; + #endif diff --git a/Plugin/DisplacementRaise.cpp b/Plugin/DisplacementRaise.cpp index 9202582d9dd1fe858cab71ce46fb5548ba181579..b220af3f6e297cf0107c69775c01f83101d1b191 100644 --- a/Plugin/DisplacementRaise.cpp +++ b/Plugin/DisplacementRaise.cpp @@ -1,4 +1,4 @@ -// $Id: DisplacementRaise.cpp,v 1.7 2003-11-19 01:52:32 geuzaine Exp $ +// $Id: DisplacementRaise.cpp,v 1.8 2003-11-21 07:56:32 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -76,12 +76,12 @@ int GMSH_DisplacementRaisePlugin::getNbOptions() const return sizeof(DisplacementRaiseOptions_Number) / sizeof(StringXNumber); } -StringXNumber *GMSH_DisplacementRaisePlugin::GetOption(int iopt) +StringXNumber *GMSH_DisplacementRaisePlugin::getOption(int iopt) { return &DisplacementRaiseOptions_Number[iopt]; } -void GMSH_DisplacementRaisePlugin::CatchErrorMessage(char *errorMessage) const +void GMSH_DisplacementRaisePlugin::catchErrorMessage(char *errorMessage) const { strcpy(errorMessage, "DisplacementRaise failed..."); } @@ -90,11 +90,11 @@ static void displacementRaiseList(Post_View * iView, List_T * iList, int iNbElm, Post_View * dView, List_T * dList, int dNbElm, int nbVert, double factor, int dTimeStep) { - if(!iNbElm) + if(!iNbElm || !dNbElm) return; if(iNbElm != dNbElm){ - Msg(GERROR, "View[%d] and View[%d] have different number of elements (%d != %d)", + Msg(WARNING, "View[%d] and View[%d] have a different number of elements (%d != %d)", iView->Index, dView->Index, iNbElm, dNbElm); return; } @@ -191,12 +191,3 @@ Post_View *GMSH_DisplacementRaisePlugin::execute(Post_View * v) return vv; } -void GMSH_DisplacementRaisePlugin::Run() -{ - execute(0); -} - -void GMSH_DisplacementRaisePlugin::Save() -{ - ; -} diff --git a/Plugin/DisplacementRaise.h b/Plugin/DisplacementRaise.h index 1fd1679ea9b1ad4fe8ade5787e2457ca799b2d92..660f45a12763e8d188433593b141fc744546f18a 100644 --- a/Plugin/DisplacementRaise.h +++ b/Plugin/DisplacementRaise.h @@ -20,24 +20,23 @@ // // Please report all bugs and problems to "gmsh@geuz.org". +#include "Plugin.h" + extern "C" { - GMSH_Plugin *GMSH_RegisterDisplacementRaisePlugin (); + GMSH_Plugin *GMSH_RegisterDisplacementRaisePlugin(); } class GMSH_DisplacementRaisePlugin : public GMSH_Post_Plugin { public: GMSH_DisplacementRaisePlugin(); - void Run(); - void Save(); - void getName (char *name) const; - void getInfos (char *author, - char *copyright, - char *help_text) const; - void CatchErrorMessage (char *errorMessage) const; + void getName(char *name) const; + void getInfos(char *author, char *copyright, char *help_text) const; + void catchErrorMessage(char *errorMessage) const; int getNbOptions() const; - StringXNumber* GetOption (int iopt); - Post_View *execute (Post_View *); + StringXNumber* getOption(int iopt); + Post_View *execute(Post_View *); }; + #endif diff --git a/Plugin/Harmonic2Time.cpp b/Plugin/Harmonic2Time.cpp index 20fe724ec9d6f27c47d2ddffaf7d7a91d55825d4..f9dbcbac1fb156b2539395f670ac192c4cf0b833 100644 --- a/Plugin/Harmonic2Time.cpp +++ b/Plugin/Harmonic2Time.cpp @@ -1,4 +1,4 @@ -// $Id: Harmonic2Time.cpp,v 1.6 2003-11-14 21:20:55 geuzaine Exp $ +// $Id: Harmonic2Time.cpp,v 1.7 2003-11-21 07:56:32 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -75,12 +75,12 @@ int GMSH_Harmonic2TimePlugin::getNbOptions() const return sizeof(Harmonic2TimeOptions_Number) / sizeof(StringXNumber); } -StringXNumber *GMSH_Harmonic2TimePlugin::GetOption(int iopt) +StringXNumber *GMSH_Harmonic2TimePlugin::getOption(int iopt) { return &Harmonic2TimeOptions_Number[iopt]; } -void GMSH_Harmonic2TimePlugin::CatchErrorMessage(char *errorMessage) const +void GMSH_Harmonic2TimePlugin::catchErrorMessage(char *errorMessage) const { strcpy(errorMessage, "Harmonic2Time failed..."); } @@ -140,12 +140,3 @@ Post_View *GMSH_Harmonic2TimePlugin::execute(Post_View * v) return 0; } -void GMSH_Harmonic2TimePlugin::Run() -{ - execute(0); -} - -void GMSH_Harmonic2TimePlugin::Save() -{ - ; -} diff --git a/Plugin/Harmonic2Time.h b/Plugin/Harmonic2Time.h index e4a95f91b085727bb30415706b34dd10cdf7dd18..c27189030bad956dd157ac3d31d3daa5c1321578 100644 --- a/Plugin/Harmonic2Time.h +++ b/Plugin/Harmonic2Time.h @@ -1,5 +1,5 @@ -#ifndef _HARMONIC2TIME_H_ -#define _HARMONIC2TIME_H +#ifndef _HARMONIC_2_TIME_H_ +#define _HARMONIC_2_TIME_H // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -20,24 +20,23 @@ // // Please report all bugs and problems to "gmsh@geuz.org". +#include "Plugin.h" + extern "C" { - GMSH_Plugin *GMSH_RegisterHarmonic2TimePlugin (); + GMSH_Plugin *GMSH_RegisterHarmonic2TimePlugin(); } class GMSH_Harmonic2TimePlugin : public GMSH_Post_Plugin { public: GMSH_Harmonic2TimePlugin(); - void Run(); - void Save(); - void getName (char *name) const; - void getInfos (char *author, - char *copyright, - char *help_text) const; - void CatchErrorMessage (char *errorMessage) const; + void getName(char *name) const; + void getInfos(char *author, char *copyright, char *help_text) const; + void catchErrorMessage(char *errorMessage) const; int getNbOptions() const; - StringXNumber* GetOption (int iopt); - Post_View *execute (Post_View *); + StringXNumber* getOption(int iopt); + Post_View *execute(Post_View *); }; + #endif diff --git a/Plugin/Levelset.cpp b/Plugin/Levelset.cpp new file mode 100644 index 0000000000000000000000000000000000000000..0f08e0545d9f0dd6baf267bc44a1a35b71190439 --- /dev/null +++ b/Plugin/Levelset.cpp @@ -0,0 +1,410 @@ +// $Id: Levelset.cpp,v 1.1 2003-11-21 07:56:32 geuzaine Exp $ +// +// Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle +// +// This program is free software; you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation; either version 2 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 +// USA. +// +// Please report all bugs and problems to "gmsh@geuz.org". + +#include "Levelset.h" +#include "DecomposeInSimplex.h" +#include "List.h" +#include "Views.h" +#include "Iso.h" +#include "Numeric.h" +#include "Context.h" +#include "Malloc.h" + +extern Context_T CTX; + +GMSH_LevelsetPlugin::GMSH_LevelsetPlugin() +{ + _invert = 0.; + _ref[0] = _ref[1] = _ref[2] = 0.; + _valueIndependent = 0; // "moving" levelset + _targetView = -1; // use same view for levelset and field data + _timeStep = -1; // use same time step in levelset and field data views + _orientation = GMSH_LevelsetPlugin::NONE; +} + +int GMSH_LevelsetPlugin::zeroLevelset(int timeStep, + int nbVert, int nbEdg, int exn[12][2], + double *x, double *y, double *z, + double *iVal, int iNbComp, + double *dVal, int dNbComp, + vector<Post_View *> out) +{ + double levels[8], scalarVal[8]; + + // compute the value of the levelset function at each node + if(_valueIndependent){ + for(int k = 0; k < nbVert; k++) { + levels[k] = levelset(x[k], y[k], z[k], 0.0); + } + } + else{ + for(int k = 0; k < nbVert; k++) { + double *vals = &iVal[iNbComp * k]; + switch(iNbComp) { + case 1: // scalar + scalarVal[k] = vals[0]; + break; + case 3 : // vector + scalarVal[k] = sqrt(DSQR(vals[0]) + DSQR(vals[1]) + DSQR(vals[2])); + break; + case 9 : // tensor + scalarVal[k] = ComputeVonMises(vals); + break; + } + levels[k] = levelset(x[k], y[k], z[k], scalarVal[k]); + } + } + + // interpolate the zero levelset and the field to plot on it + double xp[12], yp[12], zp[12], valp[12][9]; + int np = 0; + for(int k = 0; k < nbEdg; k++) { + if(levels[exn[k][0]] * levels[exn[k][1]] <= 0.0) { + if(iVal && dVal){ + double coef = InterpolateIso(x, y, z, levels, 0.0, exn[k][0], exn[k][1], + &xp[np], &yp[np], &zp[np]); + double *val1 = &dVal[dNbComp * exn[k][0]]; + double *val2 = &dVal[dNbComp * exn[k][1]]; + for(int l = 0; l < dNbComp; l++) { + valp[np][l] = coef * (val2[l] - val1[l]) + val1[l]; + } + } + np++; + } + } + + if(!iVal || !dVal) + return np; + + if(np < 1 || np > 4) + return 0; + + // avoid ``butterflies'' + if(np == 4){ + double xx = xp[3], yy = yp[3], zz = zp[3], vv[9]; + for(int l = 0; l < dNbComp; l++) + vv[l] = valp[3][l]; + xp[3] = xp[2]; + yp[3] = yp[2]; + zp[3] = zp[2]; + for(int l = 0; l < dNbComp; l++) + valp[3][l] = valp[2][l]; + xp[2] = xx; + yp[2] = yy; + zp[2] = zz; + for(int l = 0; l < dNbComp; l++) + valp[2][l] = vv[l]; + } + + // orient the triangles and the quads to get the normals right + if(np == 3 || np == 4){ + if(!timeStep || !_valueIndependent) { + // test this only once for spatially-fixed views + double v1[3] = { xp[2] - xp[0], yp[2] - yp[0], zp[2] - zp[0] }; + double v2[3] = { xp[1] - xp[0], yp[1] - yp[0], zp[1] - zp[0] }; + double gr[3], n[3]; + prodve(v1, v2, n); + switch (_orientation) { + case MAP: + gradSimplex(x, y, z, scalarVal, gr); + prosca(gr, n, &_invert); + break; + case PLANE: + prosca(n, _ref, &_invert); + break; + case SPHERE: + gr[0] = xp[0] - _ref[0]; + gr[1] = yp[0] - _ref[1]; + gr[2] = zp[0] - _ref[2]; + prosca(gr, n, &_invert); + case NONE: + default: + break; + } + } + if(_invert > 0.) { + double xpi[12], ypi[12], zpi[12], valpi[12][9]; + for(int k = 0; k < np; k++) { + xpi[k] = xp[k]; + ypi[k] = yp[k]; + zpi[k] = zp[k]; + for(int l = 0; l < dNbComp; l++) + valpi[k][l] = valp[k][l]; + } + for(int k = 0; k < np; k++) { + xp[k] = xpi[np - k - 1]; + yp[k] = ypi[np - k - 1]; + zp[k] = zpi[np - k - 1]; + for(int l = 0; l < dNbComp; l++) + valp[k][l] = valpi[np - k - 1][l]; + } + } + } + + // select the output view + Post_View *view = _valueIndependent ? out[0] : out[timeStep]; + List_T *list; + int *nbPtr; + if(np == 1){ + if(dNbComp == 1) { list = view->SP; nbPtr = &view->NbSP; } + else if(dNbComp == 3){ list = view->VP; nbPtr = &view->NbVP; } + else { list = view->TP; nbPtr = &view->NbTP; } + } + else if(np == 2){ + if(dNbComp == 1) { list = view->SL; nbPtr = &view->NbSL; } + else if(dNbComp == 3){ list = view->VL; nbPtr = &view->NbVL; } + else { list = view->TL; nbPtr = &view->NbTL; } + } + else if(np == 3){ + if(dNbComp == 1) { list = view->ST; nbPtr = &view->NbST; } + else if(dNbComp == 3){ list = view->VT; nbPtr = &view->NbVT; } + else { list = view->TT; nbPtr = &view->NbTT; } + } + else{ + if(dNbComp == 1) { list = view->SQ; nbPtr = &view->NbSQ; } + else if(dNbComp == 3){ list = view->VQ; nbPtr = &view->NbVQ; } + else { list = view->TQ; nbPtr = &view->NbTQ; } + } + + // copy the elements in the output view + if(!timeStep || !_valueIndependent) { + for(int k = 0; k < np; k++) List_Add(list, &xp[k]); + for(int k = 0; k < np; k++) List_Add(list, &yp[k]); + for(int k = 0; k < np; k++) List_Add(list, &zp[k]); + (*nbPtr)++; + } + for(int k = 0; k < np; k++) + for(int l = 0; l < dNbComp; l++) + List_Add(list, &valp[k][l]); + + return 0; +} + +static int getTimeStep(int timeStep, int ts, Post_View *dView) +{ + if(timeStep < 0){ + return ts; + } + if(timeStep >= dView->NbTimeStep){ + Msg(WARNING, "Wrong TimeStep %d in View[%d]: reverting to TimeStep 0", + timeStep, dView->Index); + return 0; + } + return timeStep; +} + +void GMSH_LevelsetPlugin::executeList(Post_View * iView, List_T * iList, + int iNbElm, int iNbComp, + Post_View * dView, List_T * dList, + int dNbElm, int dNbComp, + int nbVert, int nbEdg, int exn[12][2], + vector<Post_View *> out) +{ + if(!iNbElm || !dNbElm) + return; + + if(iNbElm != dNbElm) { + Msg(WARNING, "View[%d] and View[%d] have a different number of elements (%d != %d)", + iView->Index, dView->Index, iNbElm, dNbElm); + return; + } + + // for all elements + int iNb = List_Nbr(iList) / iNbElm; + int dNb = List_Nbr(dList) / dNbElm; + for(int i = 0, j = 0; i < List_Nbr(iList); i += iNb, j += dNb) { + double *x = (double *)List_Pointer_Fast(iList, i); + double *y = (double *)List_Pointer_Fast(iList, i + nbVert); + double *z = (double *)List_Pointer_Fast(iList, i + 2 * nbVert); + + if(nbVert == 2 || nbVert == 3 || (nbVert == 4 && nbEdg == 6)){ + // easy for simplices: at most one element is created per time step + for(int iTS = 0; iTS < iView->NbTimeStep; iTS++) { + int dTS = getTimeStep(_timeStep, iTS, dView); + double *iVal = (double *)List_Pointer_Fast(iList, i + 3 * nbVert + + iNbComp * nbVert * iTS); + double *dVal = (double *)List_Pointer_Fast(dList, j + 3 * nbVert + + dNbComp * nbVert * dTS); + zeroLevelset(iTS, nbVert, nbEdg, exn, x, y, z, + iVal, iNbComp, dVal, dNbComp, out); + } + } + else{ + Msg(GERROR, "Arghh! Non-tet levelset not finished!"); +#if 0 + // we decompose the element into simplices + DecomposeInSimplex iDec(nbVert, iNbComp, iView->NbTimeStep); + DecomposeInSimplex dDec(nbVert, dNbComp, dView->NbTimeStep); + + int nbVert_new = iDec.numNodes(); + int nbEdg_new = (nbVert_new==4)?6:3; + int exnTri[12][2] = {{0,1},{0,2},{1,2}}; + int exnTet[12][2] = {{0,1},{0,2},{0,3},{1,2},{1,3},{2,3}}; + double x_new[4], y_new[4], z_new[4]; + double *iVal_new = new double[4 * iNbComp * iView->NbTimeStep]; + double *dVal_new = new double[4 * dNbComp * dView->NbTimeStep]; + + if(_valueIndependent){ + // since the intersection is value-independent, we can loop on + // the time steps so that only one element gets created per + // time step. This allows us to still generate a *single* + // multi-timestep view. + if(zeroLevelset(0, nbVert, nbEdg, exn, x, y, z, NULL, 0, NULL, 0, out)){ + for(int k = 0; k < iDec.num(); k++){ + for(int iTS = 0; iTS < iView->NbTimeStep; iTS++) { + int dTS = getTimeStep(_timeStep, iTS, dView); + double *iVal = (double *)List_Pointer_Fast(iList, i + 3 * nbVert + + iNbComp * nbVert * iTS); + double *dVal = (double *)List_Pointer_Fast(dList, j + 3 * nbVert + + dNbComp * nbVert * dTS); + iDec.decompose(k, x, y, z, iVal, x_new, y_new, z_new, iVal_new); + dDec.decompose(k, x, y, z, dVal, x_new, y_new, z_new, dVal_new); + zeroLevelset(iTS, nbVert_new, nbEdg_new, (nbVert_new==4)?exnTet:exnTri, + x_new, y_new, z_new, iVal_new, iNbComp, dVal_new, dNbComp, + out); + } + } + } + } + else{ + // since we generate one view for each time step, we can + // generate multiple elements per time step without problem. + for(int iTS = 0; iTS < iView->NbTimeStep; iTS++) { + int dTS = getTimeStep(_timeStep, iTS, dView); + double *iVal = (double *)List_Pointer_Fast(iList, i + 3 * nbVert + + iNbComp * nbVert * iTS); + double *dVal = (double *)List_Pointer_Fast(dList, j + 3 * nbVert + + dNbComp * nbVert * dTS); + if(zeroLevelset(1, iTS, nbVert, nbEdg, exn, x, y, z, + iVal, iNbComp, dVal, dNbComp, out)){ + for(int k = 0; k < iDec.num(); k++){ + iDec.decompose(k, x, y, z, iVal, x_new, y_new, z_new, iVal_new); + dDec.decompose(k, x, y, z, dVal, x_new, y_new, z_new, dVal_new); + zeroLevelset(iTS, nbVert_new, nbEdg_new, (nbVert_new==4)?exnTet:exnTri, + x_new, y_new, z_new, iVal_new, iNbComp, dVal_new, dNbComp, + out); + } + } + } + } + + delete [] iVal_new; + delete [] dVal_new; +#endif + } + + } +} + +Post_View *GMSH_LevelsetPlugin::execute(Post_View * v) +{ + Post_View *w; + vector<Post_View *> out; + + if(_targetView < 0){ + w = v; + } + else if(!(w = (Post_View *)List_Pointer_Test(CTX.post.list, _targetView))) { + Msg(GERROR, "View[%d] does not exist: reverting to View[%d]", _targetView, + v->Index); + w = v; + } + + if(_valueIndependent) { + out.push_back(BeginView(1)); + } + else{ + for(int ts = 0; ts < v->NbTimeStep; ts++) + out.push_back(BeginView(1)); + } + + // lines + int exnLin[12][2] = {{0,1}}; + executeList(v, v->SL, v->NbSL, 1, w, w->SL, w->NbSL, 1, 2, 1, exnLin, out); + executeList(v, v->SL, v->NbSL, 1, w, w->SL, w->NbVL, 3, 2, 1, exnLin, out); + executeList(v, v->SL, v->NbSL, 1, w, w->SL, w->NbTL, 9, 2, 1, exnLin, out); + + executeList(v, v->VL, v->NbVL, 3, w, w->SL, w->NbSL, 1, 2, 1, exnLin, out); + executeList(v, v->VL, v->NbVL, 3, w, w->SL, w->NbVL, 3, 2, 1, exnLin, out); + executeList(v, v->VL, v->NbVL, 3, w, w->SL, w->NbTL, 9, 2, 1, exnLin, out); + + executeList(v, v->TL, v->NbTL, 9, w, w->SL, w->NbSL, 1, 2, 1, exnLin, out); + executeList(v, v->TL, v->NbTL, 9, w, w->SL, w->NbVL, 3, 2, 1, exnLin, out); + executeList(v, v->TL, v->NbTL, 9, w, w->SL, w->NbTL, 9, 2, 1, exnLin, out); + + // triangles + int exnTri[12][2] = {{0,1},{0,2},{1,2}}; + executeList(v, v->ST, v->NbST, 1, w, w->ST, w->NbST, 1, 3, 3, exnTri, out); + executeList(v, v->ST, v->NbST, 1, w, w->ST, w->NbVT, 3, 3, 3, exnTri, out); + executeList(v, v->ST, v->NbST, 1, w, w->ST, w->NbTT, 9, 3, 3, exnTri, out); + + executeList(v, v->VT, v->NbVT, 3, w, w->ST, w->NbST, 1, 3, 3, exnTri, out); + executeList(v, v->VT, v->NbVT, 3, w, w->ST, w->NbVT, 3, 3, 3, exnTri, out); + executeList(v, v->VT, v->NbVT, 3, w, w->ST, w->NbTT, 9, 3, 3, exnTri, out); + + executeList(v, v->TT, v->NbTT, 9, w, w->ST, w->NbST, 1, 3, 3, exnTri, out); + executeList(v, v->TT, v->NbTT, 9, w, w->ST, w->NbVT, 3, 3, 3, exnTri, out); + executeList(v, v->TT, v->NbTT, 9, w, w->ST, w->NbTT, 9, 3, 3, exnTri, out); + + // tets + int exnTet[12][2] = {{0,1},{0,2},{0,3},{1,2},{1,3},{2,3}}; + executeList(v, v->SS, v->NbSS, 1, w, w->SS, w->NbSS, 1, 4, 6, exnTet, out); + executeList(v, v->SS, v->NbSS, 1, w, w->SS, w->NbVS, 3, 4, 6, exnTet, out); + executeList(v, v->SS, v->NbSS, 1, w, w->SS, w->NbTS, 9, 4, 6, exnTet, out); + + executeList(v, v->VS, v->NbVS, 3, w, w->SS, w->NbSS, 1, 4, 6, exnTet, out); + executeList(v, v->VS, v->NbVS, 3, w, w->SS, w->NbVS, 3, 4, 6, exnTet, out); + executeList(v, v->VS, v->NbVS, 3, w, w->SS, w->NbTS, 9, 4, 6, exnTet, out); + + executeList(v, v->TS, v->NbTS, 9, w, w->SS, w->NbSS, 1, 4, 6, exnTet, out); + executeList(v, v->TS, v->NbTS, 9, w, w->SS, w->NbVS, 3, 4, 6, exnTet, out); + executeList(v, v->TS, v->NbTS, 9, w, w->SS, w->NbTS, 9, 4, 6, exnTet, out); + + // quads + //int exnQua[12][2] = + + // hexes + //int exnHex[12][2] = + + // prisms + //int exnPri[12][2] = + + // pyramids + //int exnPyr[12][2] = + + for(unsigned int i = 0; i < out.size(); i++) { + char name[1024], filename[1024]; + sprintf(name, "cut-%s-%d", v->Name, i); + sprintf(filename, "cut-%s-%d", v->FileName, i); + EndView(out[i], 1, filename, name); + } + + // remove empty views (this is a bit ugly because, due to the + // dynamic GUI events, this should actually be locked... + for(int i = List_Nbr(CTX.post.list) - 1; i >= 0; --i){ + w = (Post_View*) List_Pointer_Test(CTX.post.list, i); + if(w && w->empty()) + RemoveViewByIndex(i); + } + + return 0; +} + diff --git a/Plugin/LevelsetPlugin.h b/Plugin/Levelset.h similarity index 55% rename from Plugin/LevelsetPlugin.h rename to Plugin/Levelset.h index a07764590369eaab50c2ec46df12ad4a27dd2501..6440629b960f546f1513300ccea523d55a15173d 100644 --- a/Plugin/LevelsetPlugin.h +++ b/Plugin/Levelset.h @@ -1,5 +1,5 @@ -#ifndef _LEVELSETPLUGIN_H_ -#define _LEVELSETPLUGIN_H_ +#ifndef _LEVELSET_H_ +#define _LEVELSET_H_ // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -22,25 +22,33 @@ #include "Plugin.h" -#define ORIENT_NONE 0 -#define ORIENT_MAP 1 -#define ORIENT_PLANE 2 -#define ORIENT_SPHERE 3 +#include <vector> +using namespace std; class GMSH_LevelsetPlugin : public GMSH_Post_Plugin { +public: + typedef enum {NONE, PLANE, SPHERE, MAP} ORIENTATION ; protected: - int _ith_field_to_draw_on_the_iso; - int _orientation; double _ref[3]; + int _timeStep, _targetView, _valueIndependent; + ORIENTATION _orientation; private: - virtual double levelset (double x, double y, double z, double val) const = 0; - virtual double what_to_draw (double x, double y, double z, - int p1, int p2, double coef, double *val) const; + double _invert; + virtual double levelset(double x, double y, double z, double val) const = 0; + int zeroLevelset(int timeStep, int nbVert, int nbEdg, int exn[12][2], + double *x, double *y, double *z, + double *iVal, int iNbComp, double *dVal, int dNbComp, + vector<Post_View*> out); + void executeList(Post_View * iView, List_T * iList, + int iNbElm, int iNbComp, + Post_View * dView, List_T * dList, + int dNbElm, int dNbComp, + int nbVert, int nbEdg, int exn[12][2], + vector<Post_View *> out); public: GMSH_LevelsetPlugin(); - virtual Post_View *execute (Post_View *); - virtual void Run(); - virtual void Save(); + virtual Post_View *execute(Post_View *); }; + #endif diff --git a/Plugin/LevelsetPlugin.cpp b/Plugin/LevelsetPlugin.cpp deleted file mode 100644 index feabec4e3f7c16e4e7b7c9b2adaf7796682a5ffb..0000000000000000000000000000000000000000 --- a/Plugin/LevelsetPlugin.cpp +++ /dev/null @@ -1,265 +0,0 @@ -// $Id: LevelsetPlugin.cpp,v 1.31 2003-03-21 00:52:45 geuzaine Exp $ -// -// Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle -// -// This program is free software; you can redistribute it and/or modify -// it under the terms of the GNU General Public License as published by -// the Free Software Foundation; either version 2 of the License, or -// (at your option) any later version. -// -// This program is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -// GNU General Public License for more details. -// -// You should have received a copy of the GNU General Public License -// along with this program; if not, write to the Free Software -// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 -// USA. -// -// Please report all bugs and problems to "gmsh@geuz.org". - -#include "LevelsetPlugin.h" -#include "List.h" -#include "Views.h" -#include "Iso.h" -#include "Numeric.h" -#include "Malloc.h" - -GMSH_LevelsetPlugin::GMSH_LevelsetPlugin() -{ - processed = 0; - _ith_field_to_draw_on_the_iso = 0; - _orientation = ORIENT_NONE; - _ref[0] = _ref[1] = _ref[2] = 0.; - strcpy(OutputFileName, "levelset.pos"); -} - -void GMSH_LevelsetPlugin::Save() -{ - if(processed) { - Msg(INFO, "Writing file '%s'", OutputFileName); - WriteView(0, processed, OutputFileName); - Msg(INFO, "Levelset ouput complete '%s'", OutputFileName); - Msg(STATUS2, "Wrote '%s'", OutputFileName); - } -} - -void GMSH_LevelsetPlugin::Run() -{ - execute(0); -} - -Post_View *GMSH_LevelsetPlugin::execute(Post_View * v) -{ - // This plugin creates a new view which is the result of a cut of - // the actual view with a levelset. - - int nb, singleOutputView = 1, edtet[6][2] = - { {0, 1}, {0, 2}, {0, 3}, {1, 2}, {1, 3}, {2, 3} }; - double *X, *Y, *Z, *Vals, levels[6], coef; - double Xp[6], Yp[6], Zp[6], myVals[6]; - double Xpi[6], Ypi[6], Zpi[6], myValsi[6]; - double test; - - if(v->NbSS) { - - Post_View **View = - (Post_View **) Malloc(v->NbTimeStep * sizeof(Post_View *)); - - switch (_orientation) { - case ORIENT_PLANE: - case ORIENT_SPHERE: - // We know the levelset is spatially "fixed", so we can create a - // single view for all time steps - singleOutputView = 1; - View[0] = BeginView(1); - break; - case ORIENT_MAP: - default: - // Each time step will give rise to a new view - singleOutputView = 0; - for(int ts = 0; ts < v->NbTimeStep; ts++) - View[ts] = BeginView(1); - break; - } - - // for all scalar tets - nb = List_Nbr(v->SS) / v->NbSS; - for(int i = 0; i < List_Nbr(v->SS); i += nb) { - X = (double *)List_Pointer_Fast(v->SS, i); - Y = (double *)List_Pointer_Fast(v->SS, i + 4); - Z = (double *)List_Pointer_Fast(v->SS, i + 8); - - // for all time steps - for(int ts = 0; ts < v->NbTimeStep; ts++) { - Vals = (double *)List_Pointer_Fast(v->SS, i + 12 + (4 * ts)); - for(int j = 0; j < 4; j++) - levels[j] = levelset(X[j], Y[j], Z[j], Vals[j]); - int nx = 0; - for(int k = 0; k < 6; k++) { - if(levels[edtet[k][0]] * levels[edtet[k][1]] <= 0.0) { - coef = InterpolateIso(X, Y, Z, levels, 0.0, - edtet[k][0], edtet[k][1], - &Xp[nx], &Yp[nx], &Zp[nx]); - myVals[nx] = what_to_draw(Xp[nx], Yp[nx], Zp[nx], - edtet[k][0], edtet[k][1], coef, Vals); - nx++; - } - } - - if(nx == 4) { - double xx = Xp[3]; - double yy = Yp[3]; - double zz = Zp[3]; - double vv = myVals[3]; - Xp[3] = Xp[2]; - Yp[3] = Yp[2]; - Zp[3] = Zp[2]; - myVals[3] = myVals[2]; - Xp[2] = xx; - Yp[2] = yy; - Zp[2] = zz; - myVals[2] = vv; - } - - if(nx == 3 || nx == 4) { - - if(!ts || !singleOutputView) { // test this only once for "fixed" views - double v1[3] = { Xp[2] - Xp[0], Yp[2] - Yp[0], Zp[2] - Zp[0] }; - double v2[3] = { Xp[1] - Xp[0], Yp[1] - Yp[0], Zp[1] - Zp[0] }; - double gr[3]; - double n[3]; - prodve(v1, v2, n); - switch (_orientation) { - case ORIENT_MAP: - gradSimplex(X, Y, Z, Vals, gr); - prosca(gr, n, &test); - break; - case ORIENT_PLANE: - prosca(n, _ref, &test); - break; - case ORIENT_SPHERE: - gr[0] = Xp[0] - _ref[0]; - gr[1] = Yp[0] - _ref[1]; - gr[2] = Zp[0] - _ref[2]; - prosca(gr, n, &test); - break; - default: - test = 0.; - break; - } - } - - if(test > 0) { - for(int k = 0; k < nx; k++) { - Xpi[k] = Xp[k]; - Ypi[k] = Yp[k]; - Zpi[k] = Zp[k]; - myValsi[k] = myVals[k]; - } - for(int k = 0; k < nx; k++) { - Xp[k] = Xpi[nx - k - 1]; - Yp[k] = Ypi[nx - k - 1]; - Zp[k] = Zpi[nx - k - 1]; - myVals[k] = myValsi[nx - k - 1]; - } - } - - if(singleOutputView) { - if(nx == 3) { - if(!ts) { // for the first time step only - for(int k = 0; k < 3; k++) - List_Add(View[0]->ST, &Xp[k]); - for(int k = 0; k < 3; k++) - List_Add(View[0]->ST, &Yp[k]); - for(int k = 0; k < 3; k++) - List_Add(View[0]->ST, &Zp[k]); - View[0]->NbST++; - } - for(int k = 0; k < 3; k++) - List_Add(View[0]->ST, &myVals[k]); - } - if(nx == 4) { - if(!ts) { // for the first time step only - for(int k = 0; k < 4; k++) - List_Add(View[0]->SQ, &Xp[k]); - for(int k = 0; k < 4; k++) - List_Add(View[0]->SQ, &Yp[k]); - for(int k = 0; k < 4; k++) - List_Add(View[0]->SQ, &Zp[k]); - View[0]->NbSQ++; - } - for(int k = 0; k < 4; k++) - List_Add(View[0]->SQ, &myVals[k]); - } - } - else { - if(nx == 3) { - for(int k = 0; k < 3; k++) - List_Add(View[ts]->ST, &Xp[k]); - for(int k = 0; k < 3; k++) - List_Add(View[ts]->ST, &Yp[k]); - for(int k = 0; k < 3; k++) - List_Add(View[ts]->ST, &Zp[k]); - for(int k = 0; k < 3; k++) - List_Add(View[ts]->ST, &myVals[k]); - View[ts]->NbST++; - } - if(nx == 4) { - for(int k = 0; k < 4; k++) - List_Add(View[ts]->SQ, &Xp[k]); - for(int k = 0; k < 4; k++) - List_Add(View[ts]->SQ, &Yp[k]); - for(int k = 0; k < 4; k++) - List_Add(View[ts]->SQ, &Zp[k]); - for(int k = 0; k < 4; k++) - List_Add(View[ts]->SQ, &myVals[k]); - View[ts]->NbSQ++; - } - } - - } - } - } - - char name[1024], filename[1024]; - if(singleOutputView) { - sprintf(name, "cut-%s", v->Name); - sprintf(filename, "cut-%s", v->FileName); - EndView(View[0], 1, filename, name); - } - else { - for(int ts = 0; ts < v->NbTimeStep; ts++) { - sprintf(name, "cut-%s-%d", v->Name, ts); - sprintf(filename, "cut-%s-%d", v->FileName, ts); - EndView(View[ts], 1, filename, name); - } - } - - // a little bogus if multiple output views, but we don't use it anyway - processed = View[0]; - - Free(View); - - return processed; - } - - return 0; -} - -double GMSH_LevelsetPlugin::what_to_draw(double x, double y, double z, - int p1, int p2, - double coef, double *Vals) const -{ - // This very dangerous, since there is no test to check if enough - // values are avaiable in the view - int offset = _ith_field_to_draw_on_the_iso * 4; - - // TEST JF, this would draw y coord on the iso - //return y; - - p2 += offset; - p1 += offset; - return coef * (Vals[p2] - Vals[p1]) + Vals[p1]; -} diff --git a/Plugin/Makefile b/Plugin/Makefile index ee7cf81f2754589690253031714ef751ad18236e..d6c76392aada55589e731b5715dd4ed2bf8b9ca9 100644 --- a/Plugin/Makefile +++ b/Plugin/Makefile @@ -1,4 +1,4 @@ -# $Id: Makefile,v 1.37 2003-11-13 17:39:03 geuzaine Exp $ +# $Id: Makefile,v 1.38 2003-11-21 07:56:32 geuzaine Exp $ # # Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle # @@ -27,7 +27,7 @@ INCLUDE = -I../Common -I../Graphics -I../DataStr -I../Geo\ CFLAGS = -DMPICH_SKIP_MPICXX ${OPTIM} ${FLAGS} ${INCLUDE} SRC = Plugin.cpp\ - LevelsetPlugin.cpp\ + Levelset.cpp\ CutPlane.cpp CutSphere.cpp CutMap.cpp\ Smooth.cpp\ Transform.cpp\ @@ -62,19 +62,19 @@ depend: # DO NOT DELETE THIS LINE Plugin.o: Plugin.cpp Plugin.h ../Common/Options.h ../Common/Message.h \ - PluginManager.h CutMap.h LevelsetPlugin.h CutPlane.h CutSphere.h Skin.h \ + PluginManager.h CutMap.h Levelset.h CutPlane.h CutSphere.h Skin.h \ Smooth.h Transform.h Triangulate.h SphericalRaise.h -LevelsetPlugin.o: LevelsetPlugin.cpp LevelsetPlugin.h Plugin.h \ +Levelset.o: Levelset.cpp Levelset.h Plugin.h \ ../Common/Options.h ../Common/Message.h ../DataStr/List.h \ ../Common/Views.h ../Common/ColorTable.h ../Graphics/Iso.h \ ../Numeric/Numeric.h ../DataStr/Malloc.h -CutPlane.o: CutPlane.cpp CutPlane.h LevelsetPlugin.h Plugin.h \ +CutPlane.o: CutPlane.cpp CutPlane.h Levelset.h Plugin.h \ ../Common/Options.h ../Common/Message.h ../DataStr/List.h \ ../Common/Context.h -CutSphere.o: CutSphere.cpp CutSphere.h LevelsetPlugin.h Plugin.h \ +CutSphere.o: CutSphere.cpp CutSphere.h Levelset.h Plugin.h \ ../Common/Options.h ../Common/Message.h ../DataStr/List.h \ ../Common/Context.h -CutMap.o: CutMap.cpp CutMap.h LevelsetPlugin.h Plugin.h \ +CutMap.o: CutMap.cpp CutMap.h Levelset.h Plugin.h \ ../Common/Options.h ../Common/Message.h ../DataStr/List.h \ ../Common/Context.h Smooth.o: Smooth.cpp Plugin.h ../Common/Options.h ../Common/Message.h \ diff --git a/Plugin/Plugin.cpp b/Plugin/Plugin.cpp index dcaec12ab07d91ce39d80194f5fdaf36f30ecc64..c6062afbb2302e7b36546c765702ce245649544f 100644 --- a/Plugin/Plugin.cpp +++ b/Plugin/Plugin.cpp @@ -1,4 +1,4 @@ -// $Id: Plugin.cpp,v 1.42 2003-11-13 17:39:03 geuzaine Exp $ +// $Id: Plugin.cpp,v 1.43 2003-11-21 07:56:32 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -48,7 +48,7 @@ using namespace std; const char *GMSH_PluginEntry = "GMSH_RegisterPlugin"; -GMSH_PluginManager *GMSH_PluginManager::instance = 0; +GMSH_PluginManager *GMSH_PluginManager::_instance = 0; GMSH_PluginManager::GMSH_PluginManager() { @@ -68,24 +68,24 @@ GMSH_Plugin *GMSH_PluginManager::find(char *pluginName) return (*it).second; } -void GMSH_PluginManager::Action(char *pluginName, char *action, void *data) +void GMSH_PluginManager::action(char *pluginName, char *action, void *data) { GMSH_Plugin *plugin = find(pluginName); if(!plugin) { throw 1; } if(!strcmp(action, "Run")) { - plugin->Run(); + plugin->run(); } else if(!strcmp(action, "Save")) { - plugin->Save(); + plugin->save(); } else { throw 1; } } -void GMSH_PluginManager::SetPluginOption(char *pluginName, char *option, +void GMSH_PluginManager::setPluginOption(char *pluginName, char *option, char *value) { GMSH_Plugin *plugin = find(pluginName); @@ -94,14 +94,14 @@ void GMSH_PluginManager::SetPluginOption(char *pluginName, char *option, throw "Unknown plugin name"; if(!strcmp(option, "OutputFileName")) - strcpy(plugin->OutputFileName, value); + strcpy(plugin->outputFileName, value); else if(!strcmp(option, "InputFileName")) - strcpy(plugin->InputFileName, value); + strcpy(plugin->inputFileName, value); else throw "Unknown plugin option name"; } -void GMSH_PluginManager::SetPluginOption(char *pluginName, char *option, +void GMSH_PluginManager::setPluginOption(char *pluginName, char *option, double value) { GMSH_Plugin *plugin = find(pluginName); @@ -112,7 +112,7 @@ void GMSH_PluginManager::SetPluginOption(char *pluginName, char *option, for(int i = 0; i < plugin->getNbOptions(); i++) { StringXNumber *sxn; // get the ith option of the plugin - sxn = plugin->GetOption(i); + sxn = plugin->getOption(i); // look if it's the good option name if(!strcmp(sxn->str, option)) { sxn->def = value; @@ -122,15 +122,15 @@ void GMSH_PluginManager::SetPluginOption(char *pluginName, char *option, throw "Unknown plugin option name"; } -GMSH_PluginManager *GMSH_PluginManager::Instance() +GMSH_PluginManager *GMSH_PluginManager::instance() { - if(!instance) { - instance = new GMSH_PluginManager; + if(!_instance) { + _instance = new GMSH_PluginManager; } - return instance; + return _instance; } -void GMSH_PluginManager::RegisterDefaultPlugins() +void GMSH_PluginManager::registerDefaultPlugins() { allPlugins.insert(std::pair < char *, GMSH_Plugin * > ("CutMap", GMSH_RegisterCutMapPlugin())); @@ -177,7 +177,7 @@ void GMSH_PluginManager::RegisterDefaultPlugins() if(strlen(name) > 3) { strcpy(ext, name + (strlen(name) - 3)); if(!strcmp(ext, ".so") || !strcmp(ext, "dll")) { - AddPlugin(homeplugins, name); + addPlugin(homeplugins, name); } } } @@ -187,7 +187,7 @@ void GMSH_PluginManager::RegisterDefaultPlugins() #endif } -void GMSH_PluginManager::AddPlugin(char *dirName, char *pluginName) +void GMSH_PluginManager::addPlugin(char *dirName, char *pluginName) { #if defined(_NO_DLL) || !defined(HAVE_FLTK) Msg(WARNING, "No dynamic plugin loading on this platform"); @@ -198,7 +198,7 @@ void GMSH_PluginManager::AddPlugin(char *dirName, char *pluginName) char plugin_author[256]; char plugin_copyright[256]; char plugin_help[256]; - class GMSH_Plugin *(*RegisterPlugin) (void); + class GMSH_Plugin *(*registerPlugin) (void); sprintf(dynamic_lib, "%s/%s", dirName, pluginName); Msg(INFO, "Opening Plugin '%s'", dynamic_lib); void *hlib = dlopen(dynamic_lib, RTLD_NOW); @@ -207,7 +207,7 @@ void GMSH_PluginManager::AddPlugin(char *dirName, char *pluginName) Msg(WARNING, "Error in opening %s (dlerror = %s)", dynamic_lib, err); return; } - RegisterPlugin = + registerPlugin = (class GMSH_Plugin * (*)(void))dlsym(hlib, GMSH_PluginEntry); err = (char*)dlerror(); if(err != NULL) { @@ -216,7 +216,7 @@ void GMSH_PluginManager::AddPlugin(char *dirName, char *pluginName) return; } - GMSH_Plugin *p = RegisterPlugin(); + GMSH_Plugin *p = registerPlugin(); p->hlib = hlib; p->getName(plugin_name); p->getInfos(plugin_author, plugin_copyright, plugin_help); diff --git a/Plugin/Plugin.h b/Plugin/Plugin.h index f8d9766d7a4da106b17bade04e32f588f21355bf..32669e4a6c5e827b20cfe62036c9608cb2a30a0c 100644 --- a/Plugin/Plugin.h +++ b/Plugin/Plugin.h @@ -33,20 +33,21 @@ #include <string.h> #include <stdio.h> + #include "Options.h" #include "Message.h" - +#include "Views.h" class PluginDialogBox; -class Post_View; + class GMSH_Plugin { public : // output file name - char OutputFileName[256]; + char outputFileName[256]; //input file name - char InputFileName[256]; + char inputFileName[256]; // a dialog box for user interface PluginDialogBox *dialogBox; @@ -63,20 +64,18 @@ public : // returns the type of plugin for downcasting GMSH_Plugin into // GMSH_CAD_Plugin, GMSH_Mesh_Plugin and GMSH_Post_Plugin virtual GMSH_PLUGIN_TYPE getType() const = 0; - virtual void getName (char *name) const = 0; - virtual void getInfos (char *author, - char *copyright, - char *help_text) const = 0; + virtual void getName(char *name) const = 0; + virtual void getInfos(char *author, char *copyright, char *helpText) const = 0; // When an error is thrown by the plugin, the plugin manager will // show the message and hopefully continue - virtual void CatchErrorMessage (char *errorMessage) const = 0; + virtual void catchErrorMessage(char *errorMessage) const = 0; // gmsh style option, ca be loaded, saved and set virtual int getNbOptions() const = 0; - virtual StringXNumber *GetOption (int iopt) = 0; - virtual void Save() = 0; - virtual void Run() = 0; + virtual StringXNumber *getOption(int iopt) = 0; + virtual void save() = 0; + virtual void run() = 0; }; @@ -85,15 +84,15 @@ public : class GMSH_Post_Plugin : public GMSH_Plugin { - protected: - Post_View *processed; public: - inline GMSH_PLUGIN_TYPE getType() const - {return GMSH_Plugin::GMSH_POST_PLUGIN;} - + inline GMSH_PLUGIN_TYPE getType() const { return GMSH_Plugin::GMSH_POST_PLUGIN; } + virtual void save(){ + Msg(WARNING, "Plugin().Save is deprecated: use 'Save View[num]' instead"); + } + virtual void run(){ execute(0); } // If returned pointer is the same as the argument, then view is // simply modified, else, a new view is added in the view list - virtual Post_View *execute (Post_View *) = 0; + virtual Post_View *execute(Post_View *) = 0; }; #endif diff --git a/Plugin/PluginManager.h b/Plugin/PluginManager.h index ef53caaa0ccaa684dd57c2b3289d9c7bbf997ecd..f04f7d174bc4e7c5b8e1b9231b1ed25d686c8ac2 100644 --- a/Plugin/PluginManager.h +++ b/Plugin/PluginManager.h @@ -1,5 +1,5 @@ -#ifndef _PLUGINMANAGER_H_ -#define _PLUGINMANAGER_H_ +#ifndef _PLUGIN_MANAGER_H_ +#define _PLUGIN_MANAGER_H_ // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -23,7 +23,8 @@ #include <map> #include <iosfwd> -class GMSH_Plugin; +#include "Plugin.h" + struct ltstrpg { bool operator()(const char* s1, const char* s2) const @@ -35,7 +36,7 @@ struct ltstrpg class GMSH_PluginManager { GMSH_PluginManager(); - static GMSH_PluginManager *instance; + static GMSH_PluginManager *_instance; std::map<const char*,GMSH_Plugin*,ltstrpg> allPlugins; public : virtual ~GMSH_PluginManager(); @@ -48,18 +49,18 @@ public : // is usually called a 'plugin'. We should call the plugins // 'modules'. A plugin is an _executable_, but that can only be // executed from inside another program... - void RegisterDefaultPlugins(); - static GMSH_PluginManager *Instance(); + void registerDefaultPlugins(); + static GMSH_PluginManager *instance(); // Dynamically add a plugin pluginName.so in dirName - void AddPlugin(char *dirName, char *pluginName); + void addPlugin(char *dirName, char *pluginName); // Uninstall a given plugin - void UninstallPlugin (char *pluginName); + void uninstallPlugin (char *pluginName); // Set an option to a value in plugin named pluginName - void SetPluginOption (char *pluginName, char *option, double value); - void SetPluginOption (char *pluginName, char *option, char * value); + void setPluginOption (char *pluginName, char *option, double value); + void setPluginOption (char *pluginName, char *option, char * value); // Iterator on plugins inline iter begin() {return allPlugins.begin();} @@ -70,7 +71,7 @@ public : // Perform an action on the plugin. Default action are Run and // Save. Other plugins may perform other actions. - void Action (char *pluginMane , char *action , void *data); + void action (char *pluginMane , char *action , void *data); }; #endif diff --git a/Plugin/Skin.cpp b/Plugin/Skin.cpp index b194fa63530db94df72967dca2c1df4b93861912..37c554b3fc8cdc2ebc06953b998aa4f10ffadc76 100644 --- a/Plugin/Skin.cpp +++ b/Plugin/Skin.cpp @@ -1,4 +1,4 @@ -// $Id: Skin.cpp,v 1.18 2003-11-14 21:20:55 geuzaine Exp $ +// $Id: Skin.cpp,v 1.19 2003-11-21 07:56:32 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -57,8 +57,8 @@ void GMSH_SkinPlugin::getInfos(char *author, char *copyright, char *help_text) c strcpy(copyright, "DGR (www.multiphysics.com)"); strcpy(help_text, "Plugin(Skin) extracts the skin (the boundary) of\n" - "the scalar view 'iView'. If 'iView' < 0, the plugin\n" - "is run on the current view.\n"); + "the simplectic view 'iView'. If 'iView' < 0, the\n" + "plugin is run on the current view.\n"); } int GMSH_SkinPlugin::getNbOptions() const @@ -66,12 +66,12 @@ int GMSH_SkinPlugin::getNbOptions() const return sizeof(SkinOptions_Number) / sizeof(StringXNumber); } -StringXNumber *GMSH_SkinPlugin::GetOption(int iopt) +StringXNumber *GMSH_SkinPlugin::getOption(int iopt) { return &SkinOptions_Number[iopt]; } -void GMSH_SkinPlugin::CatchErrorMessage(char *errorMessage) const +void GMSH_SkinPlugin::catchErrorMessage(char *errorMessage) const { strcpy(errorMessage, "Skin failed..."); } @@ -238,18 +238,9 @@ Post_View *GMSH_SkinPlugin::execute(Post_View * v) return View; } else - FreeView(View->Index); + RemoveViewByNumber(View->Num); } return 0; } -void GMSH_SkinPlugin::Run() -{ - execute(0); -} - -void GMSH_SkinPlugin::Save() -{ - ; -} diff --git a/Plugin/Skin.h b/Plugin/Skin.h index 568cd360919ba93274983ed1abff73226d6037af..4ef8fd3a64dd4a09228955e1bbaf065ec6fc1d4d 100644 --- a/Plugin/Skin.h +++ b/Plugin/Skin.h @@ -20,24 +20,23 @@ // // Please report all bugs and problems to "gmsh@geuz.org". +#include "Plugin.h" + extern "C" { - GMSH_Plugin *GMSH_RegisterSkinPlugin (); + GMSH_Plugin *GMSH_RegisterSkinPlugin(); } class GMSH_SkinPlugin : public GMSH_Post_Plugin { public: GMSH_SkinPlugin(); - void Run(); - void Save(); - void getName (char *name) const; - void getInfos (char *author, - char *copyright, - char *help_text) const; - void CatchErrorMessage (char *errorMessage) const; + void getName(char *name) const; + void getInfos(char *author, char *copyright, char *helpText) const; + void catchErrorMessage(char *errorMessage) const; int getNbOptions() const; - StringXNumber* GetOption (int iopt); - Post_View *execute (Post_View *); + StringXNumber* getOption(int iopt); + Post_View *execute(Post_View *); }; + #endif diff --git a/Plugin/Smooth.cpp b/Plugin/Smooth.cpp index 74ca03020888c76e4bdbddc69b71d5e144fd6883..c8b1ff973ffd6e28f21b40a6365bb7c129a65523 100644 --- a/Plugin/Smooth.cpp +++ b/Plugin/Smooth.cpp @@ -1,4 +1,4 @@ -// $Id: Smooth.cpp,v 1.14 2003-11-14 21:20:55 geuzaine Exp $ +// $Id: Smooth.cpp,v 1.15 2003-11-21 07:56:32 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -66,12 +66,12 @@ int GMSH_SmoothPlugin::getNbOptions() const return sizeof(SmoothOptions_Number) / sizeof(StringXNumber); } -StringXNumber *GMSH_SmoothPlugin::GetOption(int iopt) +StringXNumber *GMSH_SmoothPlugin::getOption(int iopt) { return &SmoothOptions_Number[iopt]; } -void GMSH_SmoothPlugin::CatchErrorMessage(char *errorMessage) const +void GMSH_SmoothPlugin::catchErrorMessage(char *errorMessage) const { strcpy(errorMessage, "Smooth failed..."); } @@ -96,12 +96,3 @@ Post_View *GMSH_SmoothPlugin::execute(Post_View * v) return vv; } -void GMSH_SmoothPlugin::Run() -{ - execute(0); -} - -void GMSH_SmoothPlugin::Save() -{ - ; -} diff --git a/Plugin/Smooth.h b/Plugin/Smooth.h index b93d321f09c920df50810acc542e4070ec05ad9f..1c93dbd6d8d00a88effcf2e28ca93e48ff75102c 100644 --- a/Plugin/Smooth.h +++ b/Plugin/Smooth.h @@ -20,24 +20,23 @@ // // Please report all bugs and problems to "gmsh@geuz.org". +#include "Plugin.h" + extern "C" { - GMSH_Plugin *GMSH_RegisterSmoothPlugin (); + GMSH_Plugin *GMSH_RegisterSmoothPlugin(); } class GMSH_SmoothPlugin : public GMSH_Post_Plugin { public: GMSH_SmoothPlugin(); - void Run(); - void Save(); - void getName (char *name) const; - void getInfos (char *author, - char *copyright, - char *help_text) const; - void CatchErrorMessage (char *errorMessage) const; + void getName(char *name) const; + void getInfos(char *author, char *copyright, char *help_text) const; + void catchErrorMessage(char *errorMessage) const; int getNbOptions() const; - StringXNumber* GetOption (int iopt); - Post_View *execute (Post_View *); + StringXNumber* getOption(int iopt); + Post_View *execute(Post_View *); }; + #endif diff --git a/Plugin/SphericalRaise.cpp b/Plugin/SphericalRaise.cpp index 5c9921bce0fba55b5dcb4ef8fb98d328b1dde2a9..0d97ec475abb512f6c826b89e0bce64870b1636b 100644 --- a/Plugin/SphericalRaise.cpp +++ b/Plugin/SphericalRaise.cpp @@ -1,4 +1,4 @@ -// $Id: SphericalRaise.cpp,v 1.8 2003-11-19 01:52:32 geuzaine Exp $ +// $Id: SphericalRaise.cpp,v 1.9 2003-11-21 07:56:32 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -79,12 +79,12 @@ int GMSH_SphericalRaisePlugin::getNbOptions() const return sizeof(SphericalRaiseOptions_Number) / sizeof(StringXNumber); } -StringXNumber *GMSH_SphericalRaisePlugin::GetOption(int iopt) +StringXNumber *GMSH_SphericalRaisePlugin::getOption(int iopt) { return &SphericalRaiseOptions_Number[iopt]; } -void GMSH_SphericalRaisePlugin::CatchErrorMessage(char *errorMessage) const +void GMSH_SphericalRaisePlugin::catchErrorMessage(char *errorMessage) const { strcpy(errorMessage, "SphericalRaise failed..."); } @@ -173,12 +173,3 @@ Post_View *GMSH_SphericalRaisePlugin::execute(Post_View * v) return vv; } -void GMSH_SphericalRaisePlugin::Run() -{ - execute(0); -} - -void GMSH_SphericalRaisePlugin::Save() -{ - ; -} diff --git a/Plugin/SphericalRaise.h b/Plugin/SphericalRaise.h index dc28137ac19dcdb342de3961aada9b276a15db5b..dcacc3e4c9c9368d35be4ad9351ca587142e1ca8 100644 --- a/Plugin/SphericalRaise.h +++ b/Plugin/SphericalRaise.h @@ -20,24 +20,23 @@ // // Please report all bugs and problems to "gmsh@geuz.org". +#include "Plugin.h" + extern "C" { - GMSH_Plugin *GMSH_RegisterSphericalRaisePlugin (); + GMSH_Plugin *GMSH_RegisterSphericalRaisePlugin(); } class GMSH_SphericalRaisePlugin : public GMSH_Post_Plugin { public: GMSH_SphericalRaisePlugin(); - void Run(); - void Save(); - void getName (char *name) const; - void getInfos (char *author, - char *copyright, - char *help_text) const; - void CatchErrorMessage (char *errorMessage) const; + void getName(char *name) const; + void getInfos(char *author, char *copyright, char *helpText) const; + void catchErrorMessage(char *errorMessage) const; int getNbOptions() const; - StringXNumber* GetOption (int iopt); - Post_View *execute (Post_View *); + StringXNumber* getOption(int iopt); + Post_View *execute(Post_View *); }; + #endif diff --git a/Plugin/Transform.cpp b/Plugin/Transform.cpp index 81c32772e427519a3e8b158827666b97354f2d56..dbfe9b994a9289bf326a222d35da3451b44dad26 100644 --- a/Plugin/Transform.cpp +++ b/Plugin/Transform.cpp @@ -1,4 +1,4 @@ -// $Id: Transform.cpp,v 1.18 2003-11-14 21:28:30 geuzaine Exp $ +// $Id: Transform.cpp,v 1.19 2003-11-21 07:56:32 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -79,12 +79,12 @@ int GMSH_TransformPlugin::getNbOptions() const return sizeof(TransformOptions_Number) / sizeof(StringXNumber); } -StringXNumber *GMSH_TransformPlugin::GetOption(int iopt) +StringXNumber *GMSH_TransformPlugin::getOption(int iopt) { return &TransformOptions_Number[iopt]; } -void GMSH_TransformPlugin::CatchErrorMessage(char *errorMessage) const +void GMSH_TransformPlugin::catchErrorMessage(char *errorMessage) const { strcpy(errorMessage, "Transform failed..."); } @@ -122,12 +122,3 @@ Post_View *GMSH_TransformPlugin::execute(Post_View * v) return vv; } -void GMSH_TransformPlugin::Run() -{ - execute(0); -} - -void GMSH_TransformPlugin::Save() -{ - ; -} diff --git a/Plugin/Transform.h b/Plugin/Transform.h index 19833c8c417078a2deafdac1650e8d12b24f2758..c4c7a089a13782f4f25fe5347cd37c6fc5a66ffc 100644 --- a/Plugin/Transform.h +++ b/Plugin/Transform.h @@ -20,24 +20,23 @@ // // Please report all bugs and problems to "gmsh@geuz.org". +#include "Plugin.h" + extern "C" { - GMSH_Plugin *GMSH_RegisterTransformPlugin (); + GMSH_Plugin *GMSH_RegisterTransformPlugin(); } class GMSH_TransformPlugin : public GMSH_Post_Plugin { public: GMSH_TransformPlugin(); - void Run(); - void Save(); - void getName (char *name) const; - void getInfos (char *author, - char *copyright, - char *help_text) const; - void CatchErrorMessage (char *errorMessage) const; + void getName(char *name) const; + void getInfos(char *author, char *copyright, char *help_text) const; + void catchErrorMessage(char *errorMessage) const; int getNbOptions() const; - StringXNumber* GetOption (int iopt); - Post_View *execute (Post_View *); + StringXNumber* getOption(int iopt); + Post_View *execute(Post_View *); }; + #endif diff --git a/Plugin/Triangulate.cpp b/Plugin/Triangulate.cpp index 81b43ec9a610cd3c5af49d007f8fb25a5ee6a65d..fcfb538edd4396a6e2ad01b1cc5e494fef57df3c 100644 --- a/Plugin/Triangulate.cpp +++ b/Plugin/Triangulate.cpp @@ -1,4 +1,4 @@ -// $Id: Triangulate.cpp,v 1.12 2003-11-14 21:20:55 geuzaine Exp $ +// $Id: Triangulate.cpp,v 1.13 2003-11-21 07:56:32 geuzaine Exp $ // // Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle // @@ -32,7 +32,6 @@ #include "Utils.h" #include "Create.h" - extern Context_T CTX; StringXNumber TriangulateOptions_Number[] = { @@ -75,12 +74,12 @@ int GMSH_TriangulatePlugin::getNbOptions() const return sizeof(TriangulateOptions_Number) / sizeof(StringXNumber); } -StringXNumber *GMSH_TriangulatePlugin::GetOption(int iopt) +StringXNumber *GMSH_TriangulatePlugin::getOption(int iopt) { return &TriangulateOptions_Number[iopt]; } -void GMSH_TriangulatePlugin::CatchErrorMessage(char *errorMessage) const +void GMSH_TriangulatePlugin::catchErrorMessage(char *errorMessage) const { strcpy(errorMessage, "Triangulate failed..."); } @@ -233,12 +232,3 @@ Post_View *GMSH_TriangulatePlugin::execute(Post_View * v) } -void GMSH_TriangulatePlugin::Run() -{ - execute(0); -} - -void GMSH_TriangulatePlugin::Save() -{ - ; -} diff --git a/Plugin/Triangulate.h b/Plugin/Triangulate.h index 4960da458cb22591d9d6be6f8c40796c10ad3966..b01bec8532ff0dff8f9725d8b7ec9357a8e220e4 100644 --- a/Plugin/Triangulate.h +++ b/Plugin/Triangulate.h @@ -20,24 +20,23 @@ // // Please report all bugs and problems to "gmsh@geuz.org". +#include "Plugin.h" + extern "C" { - GMSH_Plugin *GMSH_RegisterTriangulatePlugin (); + GMSH_Plugin *GMSH_RegisterTriangulatePlugin(); } class GMSH_TriangulatePlugin : public GMSH_Post_Plugin { public: GMSH_TriangulatePlugin(); - void Run(); - void Save(); - void getName (char *name) const; - void getInfos (char *author, - char *copyright, - char *help_text) const; - void CatchErrorMessage (char *errorMessage) const; + void getName(char *name) const; + void getInfos(char *author, char *copyright, char *helpText) const; + void catchErrorMessage(char *errorMessage) const; int getNbOptions() const; - StringXNumber* GetOption (int iopt); - Post_View *execute (Post_View *); + StringXNumber* getOption(int iopt); + Post_View *execute(Post_View *); }; + #endif diff --git a/doc/VERSIONS b/doc/VERSIONS index 3aa0462de8df64c7554b2504be5a8742bde720a2..95a3010c35dbd87c77670ff70a16db34a6f5b5cf 100644 --- a/doc/VERSIONS +++ b/doc/VERSIONS @@ -1,7 +1,7 @@ -$Id: VERSIONS,v 1.158 2003-11-14 22:57:35 geuzaine Exp $ +$Id: VERSIONS,v 1.159 2003-11-21 07:56:32 geuzaine Exp $ New since 1.47: new DisplacementRaise plugin to plot arbitrary fields -on a deformed mesh; +on a deformed mesh; small bug fixes (configure script); New in 1.47: fixed extrusion of surfaces defined by only two curves; new syntax to retrieve point coordinates and indices of entities diff --git a/doc/texinfo/gmsh.texi b/doc/texinfo/gmsh.texi index 50ef960fe5db398bf98a829086bf770a6da3e433..c95b1e29dace0e93f42b72b72ed7d154dacff711 100644 --- a/doc/texinfo/gmsh.texi +++ b/doc/texinfo/gmsh.texi @@ -1,5 +1,5 @@ \input texinfo.tex @c -*-texinfo-*- -@c $Id: gmsh.texi,v 1.84 2003-10-29 20:15:10 geuzaine Exp $ +@c $Id: gmsh.texi,v 1.85 2003-11-21 07:56:33 geuzaine Exp $ @c @c Copyright (C) 1997-2003 C. Geuzaine, J.-F. Remacle @c @@ -2163,6 +2163,10 @@ Sets a floating point (@var{expression}) or a character (@var{char-expression}) option for a given plugin. See @ref{t9.geo}, for an example. +@item Save View[@var{expression}] @var{char-expression}; +Saves the the @var{expression}-th post-processing view in a file named +@var{char-expression}. + @item View "@var{string}" @{ @var{string} ( @var{expression-list} ) @{ @var{expression-list} @}; @dots{} @} Creates a new post-processing view, named @code{"@var{string}"}. This is the easiest way to create a post-processing view, but also the least efficient