Select Git revision
ProParser.tab.c
-
Patrick Dular authored
Added: members of structures being lists of strings and functions to get their elements or the full lists; also added: function to get full lists of strings (was not available)
Patrick Dular authoredAdded: members of structures being lists of strings and functions to get their elements or the full lists; also added: function to get full lists of strings (was not available)
ProParser.tab.c 841.63 KiB
/* A Bison parser, made by GNU Bison 2.3. */
/* Skeleton implementation for Bison's Yacc-like parsers in C
Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006
Free Software Foundation, Inc.
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, 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., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA. */
/* As a special exception, you may create a larger work that contains
part or all of the Bison parser skeleton and distribute that work
under terms of your choice, so long as that work isn't itself a
parser generator using the skeleton or a modified version thereof
as a parser skeleton. Alternatively, if you modify or redistribute
the parser skeleton itself, you may (at your option) remove this
special exception, which will cause the skeleton and the resulting
Bison output files to be licensed under the GNU General Public
License without this special exception.
This special exception was added by the Free Software Foundation in
version 2.2 of Bison. */
/* C LALR(1) parser skeleton written by Richard Stallman, by
simplifying the original so-called "semantic" parser. */
/* All symbols defined below should begin with yy or YY, to avoid
infringing on user name space. This should be done even for local
variables, as they might otherwise be expanded by user macros.
There are some unavoidable exceptions within include files to
define necessary library symbols; they are noted "INFRINGES ON
USER NAME SPACE" below. */
/* Identify Bison output. */
#define YYBISON 1
/* Bison version. */
#define YYBISON_VERSION "2.3"
/* Skeleton name. */
#define YYSKELETON_NAME "yacc.c"
/* Pure parsers. */
#define YYPURE 0
/* Using locations. */
#define YYLSP_NEEDED 0
/* Tokens. */
#ifndef YYTOKENTYPE
# define YYTOKENTYPE
/* Put the tokens into the symbol table, so that GDB and other debuggers
know about them. */
enum yytokentype {
tINT = 258,
tFLOAT = 259,
tSTRING = 260,
tBIGSTR = 261,
tEND = 262,
tDOTS = 263,
tSCOPE = 264,
tStr = 265,
tStrList = 266,
tStrCat = 267,
tSprintf = 268,
tPrintf = 269,
tMPI_Printf = 270,
tRead = 271,
tPrintConstants = 272,
tStrCmp = 273,
tStrFind = 274,
tStrLen = 275,
tStrChoice = 276,
tStrSub = 277,
tUpperCase = 278,
tLowerCase = 279,
tLowerCaseIn = 280,
tNbrRegions = 281,
tGetRegion = 282,
tGetRegions = 283,
tStringToName = 284,
tNameToString = 285,
tFor = 286,
tEndFor = 287,
tIf = 288,
tElseIf = 289,
tElse = 290,
tEndIf = 291,
tMacro = 292,
tReturn = 293,
tCall = 294,
tCallTest = 295,
tTest = 296,
tWhile = 297,
tParse = 298,
tFlag = 299,
tExists = 300,
tFileExists = 301,
tGetForced = 302,
tGetForcedStr = 303,
tInclude = 304,
tLevelInclude = 305,
tConstant = 306,
tList = 307,
tListAlt = 308,
tLinSpace = 309,
tLogSpace = 310,
tListFromFile = 311,
tChangeCurrentPosition = 312,
tDefineConstant = 313,
tUndefineConstant = 314,
tDefineNumber = 315,
tDefineString = 316,
tDefineStruct = 317,
tNameStruct = 318,
tDimNameSpace = 319,
tGetNumber = 320,
tGetString = 321,
tSetNumber = 322,
tSetString = 323,
tPi = 324,
tMPI_Rank = 325,
tMPI_Size = 326,
t0D = 327,
t1D = 328,
t2D = 329,
t3D = 330,
tLevelTest = 331,
tTotalMemory = 332,
tNumInclude = 333,
tCurrentDirectory = 334,
tAbsolutePath = 335,
tDirName = 336,
tBaseFileName = 337,
tCurrentFileName = 338,
tGETDP_MAJOR_VERSION = 339,
tGETDP_MINOR_VERSION = 340,
tGETDP_PATCH_VERSION = 341,
tExp = 342,
tLog = 343,
tLog10 = 344,
tSqrt = 345,
tSin = 346,
tAsin = 347,
tCos = 348,
tAcos = 349,
tTan = 350,
tAtan = 351,
tAtan2 = 352,
tSinh = 353,
tCosh = 354,
tTanh = 355,
tFabs = 356,
tFloor = 357,
tCeil = 358,
tRound = 359,
tSign = 360,
tFmod = 361,
tModulo = 362,
tHypot = 363,
tRand = 364,
tSolidAngle = 365,
tTrace = 366,
tOrder = 367,
tCrossProduct = 368,
tDofValue = 369,
tMHTransform = 370,
tMHJacNL = 371,
tAppend = 372,
tGroup = 373,
tDefineGroup = 374,
tAll = 375,
tInSupport = 376,
tMovingBand2D = 377,
tDefineFunction = 378,
tUndefineFunction = 379,
tConstraint = 380,
tRegion = 381,
tSubRegion = 382,
tSubRegion2 = 383,
tRegionRef = 384,
tSubRegionRef = 385,
tFilter = 386,
tToleranceFactor = 387,
tCoefficient = 388,
tValue = 389,
tTimeFunction = 390,
tBranch = 391,
tNameOfResolution = 392,
tJacobian = 393,
tCase = 394,
tMetricTensor = 395,
tIntegration = 396,
tType = 397,
tSubType = 398,
tCriterion = 399,
tGeoElement = 400,
tNumberOfPoints = 401,
tMaxNumberOfPoints = 402,
tNumberOfDivisions = 403,
tMaxNumberOfDivisions = 404,
tStoppingCriterion = 405,
tFunctionSpace = 406,
tName = 407,
tBasisFunction = 408,
tNameOfCoef = 409,
tFunction = 410,
tdFunction = 411,
tSubFunction = 412,
tSubdFunction = 413,
tSupport = 414,
tEntity = 415,
tSubSpace = 416,
tNameOfBasisFunction = 417,
tGlobalQuantity = 418,
tEntityType = 419,
tAuto = 420,
tEntitySubType = 421,
tNameOfConstraint = 422,
tFormulation = 423,
tQuantity = 424,
tNameOfSpace = 425,
tIndexOfSystem = 426,
tSymmetry = 427,
tGalerkin = 428,
tdeRham = 429,
tGlobalTerm = 430,
tGlobalEquation = 431,
tDt = 432,
tDtDof = 433,
tDtDt = 434,
tDtDtDof = 435,
tDtDtDtDof = 436,
tDtDtDtDtDof = 437,
tDtDtDtDtDtDof = 438,
tJacNL = 439,
tDtDofJacNL = 440,
tNeverDt = 441,
tDtNL = 442,
tAtAnteriorTimeStep = 443,
tMaxOverTime = 444,
tFourierSteinmetz = 445,
tIn = 446,
tFull_Matrix = 447,
tResolution = 448,
tHidden = 449,
tDefineSystem = 450,
tNameOfFormulation = 451,
tNameOfMesh = 452,
tFrequency = 453,
tSolver = 454,
tOriginSystem = 455,
tDestinationSystem = 456,
tOperation = 457,
tOperationEnd = 458,
tSetTime = 459,
tSetTimeStep = 460,
tSetDTime = 461,
tDTime = 462,
tSetFrequency = 463,
tFourierTransform = 464,
tFourierTransformJ = 465,
tCopySolution = 466,
tCopyRHS = 467,
tCopyResidual = 468,
tCopyIncrement = 469,
tCopyDofs = 470,
tGetNormSolution = 471,
tGetNormResidual = 472,
tGetNormRHS = 473,
tGetNormIncrement = 474,
tLanczos = 475,
tEigenSolve = 476,
tEigenSolveJac = 477,
tPerturbation = 478,
tUpdate = 479,
tUpdateConstraint = 480,
tBreak = 481,
tGetResidual = 482,
tCreateSolution = 483,
tEvaluate = 484,
tSelectCorrection = 485,
tAddCorrection = 486,
tMultiplySolution = 487,
tAddOppositeFullSolution = 488,
tSolveAgainWithOther = 489,
tSetGlobalSolverOptions = 490,
tTimeLoopTheta = 491,
tTimeLoopNewmark = 492,
tTimeLoopRungeKutta = 493,
tTimeLoopAdaptive = 494,
tTime0 = 495,
tTimeMax = 496,
tTheta = 497,
tBeta = 498,
tGamma = 499,
tIterativeLoop = 500,
tIterativeLoopN = 501,
tIterativeLinearSolver = 502,
tNbrMaxIteration = 503,
tRelaxationFactor = 504,
tIterativeTimeReduction = 505,
tSetCommSelf = 506,
tSetCommWorld = 507,
tBarrier = 508,
tBroadcastFields = 509,
tBroadcastVariables = 510,
tSleep = 511,
tDivisionCoefficient = 512,
tChangeOfState = 513,
tChangeOfCoordinates = 514,
tChangeOfCoordinates2 = 515,
tSystemCommand = 516,
tError = 517,
tGmshRead = 518,
tGmshMerge = 519,
tGmshOpen = 520,
tGmshWrite = 521,
tGmshClearAll = 522,
tDelete = 523,
tDeleteFile = 524,
tRenameFile = 525,
tCreateDir = 526,
tGenerateOnly = 527,
tGenerateOnlyJac = 528,
tSolveJac_AdaptRelax = 529,
tSaveSolutionExtendedMH = 530,
tSaveSolutionMHtoTime = 531,
tSaveSolutionWithEntityNum = 532,
tInitMovingBand2D = 533,
tMeshMovingBand2D = 534,
tGenerateMHMoving = 535,
tGenerateMHMovingSeparate = 536,
tAddMHMoving = 537,
tGenerateGroup = 538,
tGenerateJacGroup = 539,
tGenerateRHSGroup = 540,
tGenerateGroupCumulative = 541,
tGenerateJacGroupCumulative = 542,
tGenerateRHSGroupCumulative = 543,
tSaveMesh = 544,
tDeformMesh = 545,
tFrequencySpectrum = 546,
tPostProcessing = 547,
tNameOfSystem = 548,
tPostOperation = 549,
tNameOfPostProcessing = 550,
tUsingPost = 551,
tResampleTime = 552,
tPlot = 553,
tPrint = 554,
tPrintGroup = 555,
tEcho = 556,
tSendMergeFileRequest = 557,
tWrite = 558,
tAdapt = 559,
tOnGlobal = 560,
tOnRegion = 561,
tOnElementsOf = 562,
tOnGrid = 563,
tOnSection = 564,
tOnPoint = 565,
tOnLine = 566,
tOnPlane = 567,
tOnBox = 568,
tWithArgument = 569,
tFile = 570,
tDepth = 571,
tDimension = 572,
tComma = 573,
tTimeStep = 574,
tHarmonicToTime = 575,
tCosineTransform = 576,
tTimeToHarmonic = 577,
tValueIndex = 578,
tValueName = 579,
tFormat = 580,
tHeader = 581,
tFooter = 582,
tSkin = 583,
tSmoothing = 584,
tTarget = 585,
tSort = 586,
tIso = 587,
tNoNewLine = 588,
tNoTitle = 589,
tDecomposeInSimplex = 590,
tChangeOfValues = 591,
tTimeLegend = 592,
tFrequencyLegend = 593,
tEigenvalueLegend = 594,
tEvaluationPoints = 595,
tStoreInRegister = 596,
tStoreInVariable = 597,
tStoreInField = 598,
tStoreInMeshBasedField = 599,
tStoreMaxInRegister = 600,
tStoreMaxXinRegister = 601,
tStoreMaxYinRegister = 602,
tStoreMaxZinRegister = 603,
tStoreMinInRegister = 604,
tStoreMinXinRegister = 605,
tStoreMinYinRegister = 606,
tStoreMinZinRegister = 607,
tLastTimeStepOnly = 608,
tAppendTimeStepToFileName = 609,
tTimeValue = 610,
tTimeImagValue = 611,
tTimeInterval = 612,
tAppendExpressionToFileName = 613,
tAppendExpressionFormat = 614,
tOverrideTimeStepValue = 615,
tNoMesh = 616,
tSendToServer = 617,
tDate = 618,
tOnelabAction = 619,
tCodeName = 620,
tFixRelativePath = 621,
tAppendToExistingFile = 622,
tAppendStringToFileName = 623,
tDEF = 624,
tOR = 625,
tAND = 626,
tAPPROXEQUAL = 627,
tNOTEQUAL = 628,
tEQUAL = 629,
tGREATERGREATER = 630,
tLESSLESS = 631,
tGREATEROREQUAL = 632,
tLESSOREQUAL = 633,
tCROSSPRODUCT = 634,
UNARYPREC = 635,
tSHOW = 636
};
#endif
/* Tokens. */
#define tINT 258
#define tFLOAT 259
#define tSTRING 260
#define tBIGSTR 261
#define tEND 262
#define tDOTS 263
#define tSCOPE 264
#define tStr 265
#define tStrList 266
#define tStrCat 267
#define tSprintf 268
#define tPrintf 269
#define tMPI_Printf 270
#define tRead 271
#define tPrintConstants 272
#define tStrCmp 273
#define tStrFind 274
#define tStrLen 275
#define tStrChoice 276
#define tStrSub 277
#define tUpperCase 278
#define tLowerCase 279
#define tLowerCaseIn 280
#define tNbrRegions 281
#define tGetRegion 282
#define tGetRegions 283
#define tStringToName 284
#define tNameToString 285
#define tFor 286
#define tEndFor 287
#define tIf 288
#define tElseIf 289
#define tElse 290
#define tEndIf 291
#define tMacro 292
#define tReturn 293
#define tCall 294
#define tCallTest 295
#define tTest 296
#define tWhile 297
#define tParse 298
#define tFlag 299
#define tExists 300
#define tFileExists 301
#define tGetForced 302
#define tGetForcedStr 303
#define tInclude 304
#define tLevelInclude 305
#define tConstant 306
#define tList 307
#define tListAlt 308
#define tLinSpace 309
#define tLogSpace 310
#define tListFromFile 311
#define tChangeCurrentPosition 312
#define tDefineConstant 313
#define tUndefineConstant 314
#define tDefineNumber 315
#define tDefineString 316
#define tDefineStruct 317
#define tNameStruct 318
#define tDimNameSpace 319
#define tGetNumber 320
#define tGetString 321
#define tSetNumber 322
#define tSetString 323
#define tPi 324
#define tMPI_Rank 325
#define tMPI_Size 326
#define t0D 327
#define t1D 328
#define t2D 329
#define t3D 330
#define tLevelTest 331
#define tTotalMemory 332
#define tNumInclude 333
#define tCurrentDirectory 334
#define tAbsolutePath 335
#define tDirName 336
#define tBaseFileName 337
#define tCurrentFileName 338
#define tGETDP_MAJOR_VERSION 339
#define tGETDP_MINOR_VERSION 340
#define tGETDP_PATCH_VERSION 341
#define tExp 342
#define tLog 343
#define tLog10 344
#define tSqrt 345
#define tSin 346
#define tAsin 347
#define tCos 348
#define tAcos 349
#define tTan 350
#define tAtan 351
#define tAtan2 352
#define tSinh 353
#define tCosh 354
#define tTanh 355
#define tFabs 356
#define tFloor 357
#define tCeil 358
#define tRound 359
#define tSign 360
#define tFmod 361
#define tModulo 362
#define tHypot 363
#define tRand 364
#define tSolidAngle 365
#define tTrace 366
#define tOrder 367
#define tCrossProduct 368
#define tDofValue 369
#define tMHTransform 370
#define tMHJacNL 371
#define tAppend 372
#define tGroup 373
#define tDefineGroup 374
#define tAll 375
#define tInSupport 376
#define tMovingBand2D 377
#define tDefineFunction 378
#define tUndefineFunction 379
#define tConstraint 380
#define tRegion 381
#define tSubRegion 382
#define tSubRegion2 383
#define tRegionRef 384
#define tSubRegionRef 385
#define tFilter 386
#define tToleranceFactor 387
#define tCoefficient 388
#define tValue 389
#define tTimeFunction 390
#define tBranch 391
#define tNameOfResolution 392
#define tJacobian 393
#define tCase 394
#define tMetricTensor 395
#define tIntegration 396
#define tType 397
#define tSubType 398
#define tCriterion 399
#define tGeoElement 400
#define tNumberOfPoints 401
#define tMaxNumberOfPoints 402
#define tNumberOfDivisions 403
#define tMaxNumberOfDivisions 404
#define tStoppingCriterion 405
#define tFunctionSpace 406
#define tName 407
#define tBasisFunction 408
#define tNameOfCoef 409
#define tFunction 410
#define tdFunction 411
#define tSubFunction 412
#define tSubdFunction 413
#define tSupport 414
#define tEntity 415
#define tSubSpace 416
#define tNameOfBasisFunction 417
#define tGlobalQuantity 418
#define tEntityType 419
#define tAuto 420
#define tEntitySubType 421
#define tNameOfConstraint 422
#define tFormulation 423
#define tQuantity 424
#define tNameOfSpace 425
#define tIndexOfSystem 426
#define tSymmetry 427
#define tGalerkin 428
#define tdeRham 429
#define tGlobalTerm 430
#define tGlobalEquation 431
#define tDt 432
#define tDtDof 433
#define tDtDt 434
#define tDtDtDof 435
#define tDtDtDtDof 436
#define tDtDtDtDtDof 437
#define tDtDtDtDtDtDof 438
#define tJacNL 439
#define tDtDofJacNL 440
#define tNeverDt 441
#define tDtNL 442
#define tAtAnteriorTimeStep 443
#define tMaxOverTime 444
#define tFourierSteinmetz 445
#define tIn 446
#define tFull_Matrix 447
#define tResolution 448
#define tHidden 449
#define tDefineSystem 450
#define tNameOfFormulation 451
#define tNameOfMesh 452
#define tFrequency 453
#define tSolver 454
#define tOriginSystem 455
#define tDestinationSystem 456
#define tOperation 457
#define tOperationEnd 458
#define tSetTime 459
#define tSetTimeStep 460
#define tSetDTime 461
#define tDTime 462
#define tSetFrequency 463
#define tFourierTransform 464
#define tFourierTransformJ 465
#define tCopySolution 466
#define tCopyRHS 467
#define tCopyResidual 468
#define tCopyIncrement 469
#define tCopyDofs 470
#define tGetNormSolution 471
#define tGetNormResidual 472
#define tGetNormRHS 473
#define tGetNormIncrement 474
#define tLanczos 475
#define tEigenSolve 476
#define tEigenSolveJac 477
#define tPerturbation 478
#define tUpdate 479
#define tUpdateConstraint 480
#define tBreak 481
#define tGetResidual 482
#define tCreateSolution 483
#define tEvaluate 484
#define tSelectCorrection 485
#define tAddCorrection 486
#define tMultiplySolution 487
#define tAddOppositeFullSolution 488
#define tSolveAgainWithOther 489
#define tSetGlobalSolverOptions 490
#define tTimeLoopTheta 491
#define tTimeLoopNewmark 492
#define tTimeLoopRungeKutta 493
#define tTimeLoopAdaptive 494
#define tTime0 495
#define tTimeMax 496
#define tTheta 497
#define tBeta 498
#define tGamma 499
#define tIterativeLoop 500
#define tIterativeLoopN 501
#define tIterativeLinearSolver 502
#define tNbrMaxIteration 503
#define tRelaxationFactor 504
#define tIterativeTimeReduction 505
#define tSetCommSelf 506
#define tSetCommWorld 507
#define tBarrier 508
#define tBroadcastFields 509
#define tBroadcastVariables 510
#define tSleep 511
#define tDivisionCoefficient 512
#define tChangeOfState 513
#define tChangeOfCoordinates 514
#define tChangeOfCoordinates2 515
#define tSystemCommand 516
#define tError 517
#define tGmshRead 518
#define tGmshMerge 519
#define tGmshOpen 520
#define tGmshWrite 521
#define tGmshClearAll 522
#define tDelete 523
#define tDeleteFile 524
#define tRenameFile 525
#define tCreateDir 526
#define tGenerateOnly 527
#define tGenerateOnlyJac 528
#define tSolveJac_AdaptRelax 529
#define tSaveSolutionExtendedMH 530
#define tSaveSolutionMHtoTime 531
#define tSaveSolutionWithEntityNum 532
#define tInitMovingBand2D 533
#define tMeshMovingBand2D 534
#define tGenerateMHMoving 535
#define tGenerateMHMovingSeparate 536
#define tAddMHMoving 537
#define tGenerateGroup 538
#define tGenerateJacGroup 539
#define tGenerateRHSGroup 540
#define tGenerateGroupCumulative 541
#define tGenerateJacGroupCumulative 542
#define tGenerateRHSGroupCumulative 543
#define tSaveMesh 544
#define tDeformMesh 545
#define tFrequencySpectrum 546
#define tPostProcessing 547
#define tNameOfSystem 548
#define tPostOperation 549
#define tNameOfPostProcessing 550
#define tUsingPost 551
#define tResampleTime 552
#define tPlot 553
#define tPrint 554
#define tPrintGroup 555
#define tEcho 556
#define tSendMergeFileRequest 557
#define tWrite 558
#define tAdapt 559
#define tOnGlobal 560
#define tOnRegion 561
#define tOnElementsOf 562
#define tOnGrid 563
#define tOnSection 564
#define tOnPoint 565
#define tOnLine 566
#define tOnPlane 567
#define tOnBox 568
#define tWithArgument 569
#define tFile 570
#define tDepth 571
#define tDimension 572
#define tComma 573
#define tTimeStep 574
#define tHarmonicToTime 575
#define tCosineTransform 576
#define tTimeToHarmonic 577
#define tValueIndex 578
#define tValueName 579
#define tFormat 580
#define tHeader 581
#define tFooter 582
#define tSkin 583
#define tSmoothing 584
#define tTarget 585
#define tSort 586
#define tIso 587
#define tNoNewLine 588
#define tNoTitle 589
#define tDecomposeInSimplex 590
#define tChangeOfValues 591
#define tTimeLegend 592
#define tFrequencyLegend 593
#define tEigenvalueLegend 594
#define tEvaluationPoints 595
#define tStoreInRegister 596
#define tStoreInVariable 597
#define tStoreInField 598
#define tStoreInMeshBasedField 599
#define tStoreMaxInRegister 600
#define tStoreMaxXinRegister 601
#define tStoreMaxYinRegister 602
#define tStoreMaxZinRegister 603
#define tStoreMinInRegister 604
#define tStoreMinXinRegister 605
#define tStoreMinYinRegister 606
#define tStoreMinZinRegister 607
#define tLastTimeStepOnly 608
#define tAppendTimeStepToFileName 609
#define tTimeValue 610
#define tTimeImagValue 611
#define tTimeInterval 612
#define tAppendExpressionToFileName 613
#define tAppendExpressionFormat 614
#define tOverrideTimeStepValue 615
#define tNoMesh 616
#define tSendToServer 617
#define tDate 618
#define tOnelabAction 619
#define tCodeName 620
#define tFixRelativePath 621
#define tAppendToExistingFile 622
#define tAppendStringToFileName 623
#define tDEF 624
#define tOR 625
#define tAND 626
#define tAPPROXEQUAL 627
#define tNOTEQUAL 628
#define tEQUAL 629
#define tGREATERGREATER 630
#define tLESSLESS 631
#define tGREATEROREQUAL 632
#define tLESSOREQUAL 633
#define tCROSSPRODUCT 634
#define UNARYPREC 635
#define tSHOW 636
/* Copy the first part of user declarations. */
#line 1 "ProParser.y"
// GetDP - Copyright (C) 1997-2015 P. Dular, C. Geuzaine
//
// See the LICENSE.txt file for license information. Please report all
// bugs and problems to the public mailing list <getdp@onelab.info>.
//
// Contributor(s):
// Ruth Sabariego
// Johan Gyselinck
//
#include <iostream>
#include <algorithm>
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
#include <string.h>
#include <math.h>
#include <time.h>
#include "GetDPConfig.h"
#include "GetDPVersion.h"
#include "ProData.h"
#include "ProDefine.h"
#include "ProDefines.h"
#include "ProParser.h"
#include "MacroManager.h"
#include "MallocUtils.h"
#include "TreeUtils.h"
#include "Message.h"
#include "OS.h"
// Global problem structure filled by the parser
extern struct Problem Problem_S;
// Global parser variables
std::string getdp_yyname;
char getdp_yyincludename[256] = "";
long int getdp_yylinenum = 0;
int getdp_yycolnum = 0;
int getdp_yyincludenum = 0;
int getdp_yyerrorlevel = 0;
std::string getdp_yystring = "";
std::map<std::string, std::vector<double> > CommandLineNumbers;
std::map<std::string, std::vector<std::string> > CommandLineStrings;
std::map<std::string, std::vector<double> > GetDPNumbers;
std::map<std::string, std::vector<std::string> > GetDPStrings;
// Static parser variables (accessible only in this file)
int num_include = 0, level_include = 0;
static Tree_T *ConstantTable_L = 0;
static NameSpaces nameSpaces;
static std::string struct_name, struct_namespace;
static int flag_tSTRING_alloc = 0;
static List_T *ListOfInt_L = 0, *ListOfInt_Save_L = 0;
static List_T *ListOfPointer_L = 0, *ListOfPointer2_L = 0, *ListOfChar_L = 0;
static List_T *ListOfFormulation = 0, *ListOfBasisFunction = 0, *ListOfEntityIndex = 0;
static List_T *Operation_L = 0;
static List_T *Current_BasisFunction_L = 0;
static List_T *Current_WholeQuantity_L = 0;
static List_T *Current_System_L = 0;
static int Num_BasisFunction = 1;
static int FlagError = 0;
static int Type_TermOperator = 0, Type_Function = 0, Type_SuppList = 0, Type_SuppList2 = 0;
static int nb_SuppList, Type_SuppLists[2];
static List_T *ListsOfRegion[2];
static int Quantity_TypeOperator = 0, Quantity_Index = 0;
static int Current_DofIndexInWholeQuantity = 0, Last_DofIndexInWholeQuantity = 0;
static int Current_NoDofIndexInWholeQuantity = 0;
static int Current_System = 0, Constraint_Index = 0;
static int TypeOperatorDofInTrace = 0, DefineQuantityIndexDofInTrace = 0;
static int ImbricatedLoop = 0, ImbricatedTest = 0;
static char *StringForParameter = 0;
static int level_Append = 0, index_Append = -1;
static int level_Append_2 = 0, index_Append_2 = -1; // level 2
#define MAX_RECUR_TESTS 100
static int statusImbricatedTests[MAX_RECUR_TESTS];
#define MAX_RECUR_LOOPS 100
static fpos_t FposImbricatedLoopsTab[MAX_RECUR_LOOPS];
static int LinenoImbricatedLoopsTab[MAX_RECUR_LOOPS];
static double LoopControlVariablesTab[MAX_RECUR_LOOPS][3];
static char *LoopControlVariablesNameTab[MAX_RECUR_LOOPS];
static struct Constant Constant_S, Constant1_S, Constant2_S;
static struct Expression Expression_S, *Expression_P;
static struct ExpressionPerRegion ExpressionPerRegion_S;
static struct ExpressionPerRegion2 ExpressionPerRegion2_S;
static struct Group Group_S;
static struct Constraint Constraint_S, *Constraint_P;
static struct ConstraintPerRegion ConstraintPerRegion_S, *ConstraintPerRegion_P;
static struct MultiConstraintPerRegion MultiConstraintPerRegion_S;
static struct JacobianMethod JacobianMethod_S;
static struct JacobianCase JacobianCase_S;
static struct IntegrationMethod IntegrationMethod_S;
static struct IntegrationCase IntegrationCase_S;
static struct Quadrature QuadratureCase_S;
static struct FunctionSpace FunctionSpace_S;
static struct BasisFunction BasisFunction_S;
static struct GlobalBasisFunction GlobalBasisFunction_S;
static struct SubSpace SubSpace_S;
static struct GlobalQuantity GlobalQuantity_S;
static struct ConstraintInFS ConstraintInFS_S;
static struct Formulation Formulation_S;
static struct DefineQuantity DefineQuantity_S;
static struct EquationTerm EquationTerm_S;
static struct WholeQuantity WholeQuantity_S, *WholeQuantity_P;
static struct GlobalEquationTerm GlobalEquationTerm_S;
static struct Resolution Resolution_S;
static struct DefineSystem DefineSystem_S;
static struct Operation Operation_S, *Operation_P;
static struct ChangeOfState ChangeOfState_S;
static struct TimeLoopAdaptiveSystem TimeLoopAdaptiveSystem_S;
static struct LoopErrorPostOperation TimeLoopAdaptivePO_S, IterativeLoopPO_S;
static struct IterativeLoopSystem IterativeLoopSystem_S;
static struct PostProcessing PostProcessing_S, InteractivePostProcessing_S;
static struct PostQuantity PostQuantity_S;
static struct PostQuantityTerm PostQuantityTerm_S;
static struct PostOperation PostOperation_S;
static struct PostSubOperation PostSubOperation_S;
static std::map<std::string, std::vector<double> > floatOptions;
static std::map<std::string, std::vector<std::string> > charOptions;
static int flag_Enum, member_ValMax;
void init_Options(int member_ValMax_ = 0)
{
floatOptions.clear(); charOptions.clear();
flag_Enum = 0; member_ValMax = member_ValMax_;
}
// External lexer functions
void hack_fsetpos();
void hack_fsetpos_printf();
int getdp_yylex();
// Forward function declarations
void Alloc_ParserVariables();
int Check_NameOfStructExist(const char *Struct, List_T *List_L, void *data,
int (*fcmp)(const void *a, const void *b),
int level_Append);
int Add_Group(struct Group *Group_P, char *Name, bool Flag_Add,
int Flag_Plus, int Num_Index);
int Num_Group(struct Group *Group_P, char *Name, int Num_Group);
void Fill_GroupInitialListFromString(List_T *list, const char *str);
int Add_Expression(struct Expression *Expression_P, char *Name, int Flag_Plus);
bool Is_ExpressionPieceWiseDefined(int index);
void Pro_DefineQuantityIndex(List_T *WholeQuantity_L,int DefineQuantityIndexEqu,
int *NbrQuantityIndex, int **QuantityIndexTable,
int **QuantityTraceGroupIndexTable);
void Pro_DefineQuantityIndex_1(List_T *WholeQuantity_L, int TraceGroupIndex);
void yyerror(const char *s);
void vyyerror(int level, const char *fmt, ...);
double Treat_Struct_FullName_Float
(char* c1, char* c2, int type_var = 1, int index = 0,
double val_default = 0., int type_treat = 0);
double Treat_Struct_FullName_dot_tSTRING_Float
(char* c1, char* c2, char* c3, int index = 0,
double val_default = 0., int type_treat = 0);
List_T * Treat_Struct_FullName_dot_tSTRING_ListOfFloat
(char* c1, char* c2, char* c3);
int Treat_Struct_FullName_dot_tSTRING_Float_getDim
(char* c1, char* c2, char* c3);
char* Treat_Struct_FullName_String
(char* c1, char* c2, int type_var = 1, int index = 0,
char* val_default = NULL, int type_treat = 0);
char* Treat_Struct_FullName_dot_tSTRING_String
(char* c1, char* c2, char* c3, int index = 0,
char* val_default = NULL, int type_treat = 0);
List_T * Treat_Struct_FullName_dot_tSTRING_ListOfString
(char* c1, char* c2, char* c3);
struct doubleXstring{
double d;
char *s;
};
/* Enabling traces. */
#ifndef YYDEBUG
# define YYDEBUG 0
#endif
/* Enabling verbose error messages. */
#ifdef YYERROR_VERBOSE
# undef YYERROR_VERBOSE
# define YYERROR_VERBOSE 1
#else
# define YYERROR_VERBOSE 0
#endif
/* Enabling the token table. */
#ifndef YYTOKEN_TABLE
# define YYTOKEN_TABLE 0
#endif
#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
typedef union YYSTYPE
#line 186 "ProParser.y"
{
char *c;
int i;
double d;
List_T *l;
struct TwoInt t ;
struct TwoChar c2;
}
/* Line 193 of yacc.c. */
#line 1051 "ProParser.tab.c"
YYSTYPE;
# define yystype YYSTYPE /* obsolescent; will be withdrawn */
# define YYSTYPE_IS_DECLARED 1
# define YYSTYPE_IS_TRIVIAL 1
#endif
/* Copy the second part of user declarations. */
/* Line 216 of yacc.c. */
#line 1064 "ProParser.tab.c"
#ifdef short
# undef short
#endif
#ifdef YYTYPE_UINT8
typedef YYTYPE_UINT8 yytype_uint8;
#else
typedef unsigned char yytype_uint8;
#endif
#ifdef YYTYPE_INT8
typedef YYTYPE_INT8 yytype_int8;
#elif (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
typedef signed char yytype_int8;
#else
typedef short int yytype_int8;
#endif
#ifdef YYTYPE_UINT16
typedef YYTYPE_UINT16 yytype_uint16;
#else
typedef unsigned short int yytype_uint16;
#endif
#ifdef YYTYPE_INT16
typedef YYTYPE_INT16 yytype_int16;
#else
typedef short int yytype_int16;
#endif
#ifndef YYSIZE_T
# ifdef __SIZE_TYPE__
# define YYSIZE_T __SIZE_TYPE__
# elif defined size_t
# define YYSIZE_T size_t
# elif ! defined YYSIZE_T && (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
# include <stddef.h> /* INFRINGES ON USER NAME SPACE */
# define YYSIZE_T size_t
# else
# define YYSIZE_T unsigned int
# endif
#endif
#define YYSIZE_MAXIMUM ((YYSIZE_T) -1)
#ifndef YY_
# if defined YYENABLE_NLS && YYENABLE_NLS
# if ENABLE_NLS
# include <libintl.h> /* INFRINGES ON USER NAME SPACE */
# define YY_(msgid) dgettext ("bison-runtime", msgid)
# endif
# endif
# ifndef YY_
# define YY_(msgid) msgid
# endif
#endif
/* Suppress unused-variable warnings by "using" E. */
#if ! defined lint || defined __GNUC__
# define YYUSE(e) ((void) (e))
#else
# define YYUSE(e) /* empty */
#endif
/* Identity function, used to suppress warnings about constant conditions. */
#ifndef lint
# define YYID(n) (n)
#else
#if (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
static int
YYID (int i)
#else
static int
YYID (i)
int i;
#endif
{
return i;
}
#endif
#if ! defined yyoverflow || YYERROR_VERBOSE
/* The parser invokes alloca or malloc; define the necessary symbols. */
# ifdef YYSTACK_USE_ALLOCA
# if YYSTACK_USE_ALLOCA
# ifdef __GNUC__
# define YYSTACK_ALLOC __builtin_alloca
# elif defined __BUILTIN_VA_ARG_INCR
# include <alloca.h> /* INFRINGES ON USER NAME SPACE */
# elif defined _AIX
# define YYSTACK_ALLOC __alloca
# elif defined _MSC_VER
# include <malloc.h> /* INFRINGES ON USER NAME SPACE */
# define alloca _alloca
# else
# define YYSTACK_ALLOC alloca
# if ! defined _ALLOCA_H && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
# ifndef _STDLIB_H
# define _STDLIB_H 1
# endif
# endif
# endif
# endif
# endif
# ifdef YYSTACK_ALLOC
/* Pacify GCC's `empty if-body' warning. */
# define YYSTACK_FREE(Ptr) do { /* empty */; } while (YYID (0))
# ifndef YYSTACK_ALLOC_MAXIMUM
/* The OS might guarantee only one guard page at the bottom of the stack,
and a page size can be as small as 4096 bytes. So we cannot safely
invoke alloca (N) if N exceeds 4096. Use a slightly smaller number
to allow for a few compiler-allocated temporary stack slots. */
# define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2006 */
# endif
# else
# define YYSTACK_ALLOC YYMALLOC
# define YYSTACK_FREE YYFREE
# ifndef YYSTACK_ALLOC_MAXIMUM
# define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM
# endif
# if (defined __cplusplus && ! defined _STDLIB_H \
&& ! ((defined YYMALLOC || defined malloc) \
&& (defined YYFREE || defined free)))
# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */
# ifndef _STDLIB_H
# define _STDLIB_H 1
# endif
# endif
# ifndef YYMALLOC
# define YYMALLOC malloc
# if ! defined malloc && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */
# endif
# endif
# ifndef YYFREE
# define YYFREE free
# if ! defined free && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
void free (void *); /* INFRINGES ON USER NAME SPACE */
# endif
# endif
# endif
#endif /* ! defined yyoverflow || YYERROR_VERBOSE */
#if (! defined yyoverflow \
&& (! defined __cplusplus \
|| (defined YYSTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL)))
/* A type that is properly aligned for any stack member. */
union yyalloc
{
yytype_int16 yyss;
YYSTYPE yyvs;
};
/* The size of the maximum gap between one aligned stack and the next. */
# define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1)
/* The size of an array large to enough to hold all stacks, each with
N elements. */
# define YYSTACK_BYTES(N) \
((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE)) \
+ YYSTACK_GAP_MAXIMUM)
/* Copy COUNT objects from FROM to TO. The source and destination do
not overlap. */
# ifndef YYCOPY
# if defined __GNUC__ && 1 < __GNUC__
# define YYCOPY(To, From, Count) \
__builtin_memcpy (To, From, (Count) * sizeof (*(From)))
# else
# define YYCOPY(To, From, Count) \
do \
{ \
YYSIZE_T yyi; \
for (yyi = 0; yyi < (Count); yyi++) \
(To)[yyi] = (From)[yyi]; \
} \
while (YYID (0))
# endif
# endif
/* Relocate STACK from its old location to the new one. The
local variables YYSIZE and YYSTACKSIZE give the old and new number of
elements in the stack, and YYPTR gives the new location of the
stack. Advance YYPTR to a properly aligned location for the next
stack. */
# define YYSTACK_RELOCATE(Stack) \
do \
{ \
YYSIZE_T yynewbytes; \
YYCOPY (&yyptr->Stack, Stack, yysize); \
Stack = &yyptr->Stack; \
yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \
yyptr += yynewbytes / sizeof (*yyptr); \
} \
while (YYID (0))
#endif
/* YYFINAL -- State number of the termination state. */
#define YYFINAL 3
/* YYLAST -- Last index in YYTABLE. */
#define YYLAST 20127
/* YYNTOKENS -- Number of terminals. */
#define YYNTOKENS 406
/* YYNNTS -- Number of nonterminals. */
#define YYNNTS 239
/* YYNRULES -- Number of rules. */
#define YYNRULES 1090
/* YYNRULES -- Number of states. */
#define YYNSTATES 3037
/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
#define YYUNDEFTOK 2
#define YYMAXUTOK 636
#define YYTRANSLATE(YYX) \
((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK)
/* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX. */
static const yytype_uint16 yytranslate[] =
{
0, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 390, 2, 401, 402, 386, 389, 2,
393, 394, 384, 382, 404, 383, 400, 385, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
376, 2, 377, 370, 405, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 395, 2, 396, 392, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 397, 388, 398, 399, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2, 2, 2, 1, 2, 3, 4,
5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
15, 16, 17, 18, 19, 20, 21, 22, 23, 24,
25, 26, 27, 28, 29, 30, 31, 32, 33, 34,
35, 36, 37, 38, 39, 40, 41, 42, 43, 44,
45, 46, 47, 48, 49, 50, 51, 52, 53, 54,
55, 56, 57, 58, 59, 60, 61, 62, 63, 64,
65, 66, 67, 68, 69, 70, 71, 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, 98, 99, 100, 101, 102, 103, 104,
105, 106, 107, 108, 109, 110, 111, 112, 113, 114,
115, 116, 117, 118, 119, 120, 121, 122, 123, 124,
125, 126, 127, 128, 129, 130, 131, 132, 133, 134,
135, 136, 137, 138, 139, 140, 141, 142, 143, 144,
145, 146, 147, 148, 149, 150, 151, 152, 153, 154,
155, 156, 157, 158, 159, 160, 161, 162, 163, 164,
165, 166, 167, 168, 169, 170, 171, 172, 173, 174,
175, 176, 177, 178, 179, 180, 181, 182, 183, 184,
185, 186, 187, 188, 189, 190, 191, 192, 193, 194,
195, 196, 197, 198, 199, 200, 201, 202, 203, 204,
205, 206, 207, 208, 209, 210, 211, 212, 213, 214,
215, 216, 217, 218, 219, 220, 221, 222, 223, 224,
225, 226, 227, 228, 229, 230, 231, 232, 233, 234,
235, 236, 237, 238, 239, 240, 241, 242, 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,
285, 286, 287, 288, 289, 290, 291, 292, 293, 294,
295, 296, 297, 298, 299, 300, 301, 302, 303, 304,
305, 306, 307, 308, 309, 310, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 324,
325, 326, 327, 328, 329, 330, 331, 332, 333, 334,
335, 336, 337, 338, 339, 340, 341, 342, 343, 344,
345, 346, 347, 348, 349, 350, 351, 352, 353, 354,
355, 356, 357, 358, 359, 360, 361, 362, 363, 364,
365, 366, 367, 368, 369, 371, 372, 373, 374, 375,
378, 379, 380, 381, 387, 391, 403
};
#if YYDEBUG
/* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
YYRHS. */
static const yytype_uint16 yyprhs[] =
{
0, 0, 3, 4, 7, 8, 9, 13, 18, 23,
28, 33, 38, 43, 48, 53, 58, 63, 65, 67,
70, 71, 74, 79, 85, 86, 87, 103, 109, 111,
112, 119, 122, 124, 126, 128, 130, 132, 134, 136,
137, 142, 147, 149, 151, 155, 156, 160, 165, 167,
171, 177, 179, 183, 187, 191, 192, 194, 196, 200,
204, 205, 209, 210, 222, 229, 230, 232, 233, 236,
242, 249, 257, 258, 269, 271, 272, 276, 283, 284,
288, 293, 298, 299, 302, 306, 307, 311, 313, 317,
318, 321, 323, 324, 325, 333, 337, 341, 348, 352,
356, 360, 364, 368, 372, 376, 380, 384, 388, 392,
396, 400, 404, 409, 412, 415, 418, 419, 430, 434,
436, 440, 443, 445, 448, 449, 455, 456, 464, 465,
475, 476, 492, 493, 505, 517, 522, 527, 528, 536,
543, 546, 549, 552, 555, 559, 562, 566, 568, 570,
574, 577, 581, 583, 587, 588, 592, 599, 603, 608,
609, 612, 616, 618, 619, 622, 625, 628, 632, 637,
638, 643, 646, 647, 650, 654, 659, 663, 664, 667,
671, 673, 674, 677, 680, 683, 687, 691, 696, 697,
702, 705, 706, 709, 713, 717, 722, 723, 728, 729,
732, 736, 740, 744, 748, 752, 756, 757, 760, 764,
766, 767, 770, 773, 777, 781, 786, 792, 795, 796,
801, 804, 805, 808, 812, 816, 820, 824, 828, 832,
840, 844, 852, 864, 868, 872, 876, 880, 884, 892,
896, 904, 912, 913, 916, 920, 922, 923, 926, 929,
932, 936, 940, 945, 950, 955, 960, 961, 966, 969,
970, 973, 976, 980, 984, 989, 997, 1007, 1011, 1015,
1019, 1023, 1024, 1045, 1046, 1051, 1054, 1055, 1058, 1061,
1065, 1069, 1073, 1075, 1079, 1080, 1084, 1086, 1090, 1091,
1095, 1096, 1101, 1104, 1105, 1108, 1112, 1116, 1120, 1121,
1126, 1129, 1130, 1133, 1137, 1141, 1145, 1149, 1153, 1154,
1157, 1161, 1163, 1164, 1167, 1170, 1173, 1177, 1181, 1186,
1191, 1192, 1197, 1200, 1201, 1204, 1208, 1212, 1216, 1220,
1224, 1225, 1231, 1235, 1236, 1242, 1246, 1250, 1254, 1258,
1259, 1263, 1264, 1267, 1270, 1275, 1280, 1285, 1290, 1291,
1294, 1297, 1301, 1305, 1309, 1310, 1313, 1317, 1321, 1322,
1325, 1326, 1327, 1337, 1341, 1345, 1349, 1353, 1356, 1362,
1366, 1367, 1370, 1374, 1378, 1379, 1380, 1390, 1391, 1393,
1395, 1397, 1399, 1401, 1403, 1405, 1407, 1409, 1411, 1413,
1418, 1422, 1423, 1426, 1430, 1432, 1433, 1436, 1439, 1443,
1447, 1452, 1453, 1459, 1461, 1462, 1467, 1470, 1471, 1474,
1478, 1482, 1486, 1490, 1494, 1498, 1502, 1506, 1508, 1510,
1514, 1515, 1519, 1521, 1525, 1526, 1530, 1531, 1534, 1535,
1538, 1540, 1542, 1544, 1546, 1548, 1550, 1552, 1554, 1556,
1558, 1560, 1562, 1564, 1566, 1568, 1570, 1572, 1574, 1576,
1578, 1582, 1586, 1590, 1595, 1600, 1605, 1610, 1617, 1623,
1629, 1635, 1641, 1644, 1649, 1652, 1657, 1660, 1665, 1671,
1676, 1679, 1684, 1692, 1703, 1711, 1719, 1727, 1735, 1741,
1749, 1759, 1765, 1774, 1780, 1788, 1798, 1808, 1820, 1832,
1846, 1858, 1864, 1872, 1878, 1886, 1894, 1900, 1918, 1932,
1948, 1966, 1992, 2004, 2016, 2030, 2052, 2077, 2078, 2086,
2087, 2095, 2103, 2115, 2121, 2127, 2133, 2139, 2147, 2150,
2155, 2161, 2169, 2175, 2185, 2191, 2200, 2210, 2220, 2226,
2232, 2244, 2254, 2268, 2282, 2288, 2303, 2316, 2327, 2335,
2345, 2357, 2365, 2373, 2379, 2387, 2397, 2405, 2415, 2417,
2419, 2421, 2423, 2424, 2427, 2431, 2435, 2439, 2442, 2443,
2446, 2451, 2458, 2459, 2465, 2471, 2472, 2483, 2484, 2495,
2496, 2502, 2508, 2509, 2521, 2522, 2533, 2534, 2537, 2541,
2545, 2549, 2553, 2558, 2559, 2562, 2566, 2570, 2574, 2578,
2582, 2587, 2588, 2591, 2595, 2599, 2603, 2607, 2612, 2613,
2616, 2620, 2624, 2628, 2632, 2636, 2641, 2646, 2651, 2652,
2657, 2658, 2661, 2665, 2669, 2673, 2677, 2681, 2685, 2686,
2689, 2693, 2695, 2696, 2699, 2702, 2705, 2709, 2713, 2717,
2722, 2723, 2728, 2731, 2732, 2735, 2738, 2742, 2747, 2748,
2754, 2760, 2763, 2764, 2767, 2768, 2775, 2779, 2783, 2787,
2791, 2795, 2796, 2799, 2803, 2805, 2806, 2809, 2812, 2816,
2820, 2824, 2828, 2832, 2836, 2839, 2843, 2847, 2851, 2855,
2865, 2870, 2872, 2873, 2883, 2884, 2885, 2889, 2897, 2905,
2914, 2926, 2933, 2934, 2945, 2951, 2953, 2957, 2964, 2966,
2968, 2970, 2972, 2973, 2977, 2979, 2982, 2985, 2998, 3001,
3017, 3022, 3035, 3053, 3076, 3089, 3097, 3098, 3101, 3105,
3110, 3115, 3119, 3123, 3126, 3129, 3133, 3137, 3141, 3144,
3147, 3151, 3154, 3158, 3162, 3166, 3170, 3174, 3178, 3186,
3190, 3194, 3198, 3202, 3206, 3210, 3216, 3219, 3222, 3225,
3229, 3239, 3243, 3246, 3256, 3259, 3269, 3272, 3282, 3288,
3293, 3297, 3301, 3305, 3309, 3313, 3317, 3321, 3325, 3329,
3333, 3337, 3340, 3344, 3347, 3351, 3355, 3359, 3363, 3367,
3370, 3374, 3378, 3385, 3389, 3391, 3393, 3400, 3409, 3418,
3429, 3431, 3434, 3437, 3439, 3443, 3450, 3455, 3460, 3462,
3464, 3470, 3472, 3474, 3476, 3478, 3480, 3486, 3492, 3498,
3501, 3509, 3517, 3521, 3527, 3531, 3536, 3543, 3551, 3560,
3569, 3575, 3583, 3589, 3597, 3602, 3611, 3621, 3632, 3638,
3646, 3650, 3654, 3662, 3672, 3678, 3684, 3690, 3699, 3707,
3710, 3714, 3720, 3726, 3727, 3730, 3731, 3733, 3735, 3739,
3742, 3744, 3749, 3752, 3755, 3758, 3761, 3762, 3765, 3767,
3771, 3774, 3777, 3780, 3783, 3786, 3789, 3790, 3794, 3801,
3807, 3816, 3817, 3827, 3828, 3840, 3846, 3847, 3857, 3858,
3862, 3866, 3868, 3870, 3872, 3874, 3876, 3878, 3880, 3882,
3884, 3886, 3888, 3890, 3892, 3894, 3896, 3898, 3900, 3902,
3904, 3906, 3908, 3910, 3912, 3914, 3916, 3918, 3922, 3925,
3928, 3932, 3936, 3940, 3944, 3948, 3952, 3956, 3960, 3964,
3968, 3972, 3976, 3980, 3984, 3988, 3992, 3996, 4000, 4005,
4010, 4015, 4020, 4025, 4030, 4035, 4040, 4045, 4050, 4057,
4062, 4067, 4072, 4077, 4082, 4087, 4092, 4097, 4104, 4111,
4118, 4123, 4129, 4131, 4133, 4136, 4138, 4140, 4142, 4144,
4146, 4148, 4150, 4152, 4154, 4156, 4158, 4160, 4162, 4164,
4166, 4168, 4169, 4176, 4178, 4182, 4189, 4194, 4201, 4203,
4208, 4215, 4220, 4224, 4229, 4234, 4241, 4248, 4254, 4262,
4267, 4268, 4271, 4272, 4275, 4276, 4284, 4286, 4290, 4292,
4294, 4297, 4299, 4301, 4305, 4310, 4316, 4318, 4320, 4324,
4328, 4332, 4338, 4341, 4345, 4349, 4353, 4357, 4361, 4365,
4369, 4373, 4377, 4381, 4387, 4392, 4396, 4403, 4409, 4414,
4419, 4426, 4433, 4440, 4449, 4458, 4463, 4469, 4475, 4484,
4486, 4488, 4493, 4495, 4500, 4502, 4507, 4512, 4517, 4522,
4531, 4540, 4547, 4552, 4559, 4561, 4566, 4568, 4570, 4572,
4574, 4579, 4584, 4586, 4591, 4592, 4599, 4604, 4611, 4617,
4625, 4630, 4633, 4638, 4640, 4642, 4647, 4651, 4658, 4663,
4665, 4667, 4671, 4673, 4675, 4679, 4683, 4685, 4687, 4689,
4691, 4696, 4703, 4708, 4715, 4719, 4724, 4731, 4733, 4736,
4737
};
/* YYRHS -- A `-1'-separated list of the rules' RHS. */
static const yytype_int16 yyrhs[] =
{
407, 0, -1, -1, 408, 409, -1, -1, -1, 409,
410, 411, -1, 118, 397, 412, 398, -1, 155, 397,
430, 398, -1, 125, 397, 472, 398, -1, 138, 397,
455, 398, -1, 141, 397, 462, 398, -1, 151, 397,
479, 398, -1, 168, 397, 500, 398, -1, 193, 397,
526, 398, -1, 292, 397, 568, 398, -1, 294, 397,
579, 398, -1, 583, -1, 596, -1, 49, 633, -1,
-1, 412, 413, -1, 629, 369, 416, 7, -1, 629,
382, 369, 416, 7, -1, -1, -1, 629, 369, 122,
395, 425, 414, 404, 423, 415, 404, 423, 404, 615,
396, 7, -1, 119, 395, 427, 396, 7, -1, 596,
-1, -1, 419, 395, 420, 417, 421, 396, -1, 401,
423, -1, 416, -1, 629, -1, 120, -1, 126, -1,
5, -1, 423, -1, 120, -1, -1, 421, 429, 422,
423, -1, 421, 429, 121, 629, -1, 5, -1, 425,
-1, 397, 424, 398, -1, -1, 424, 429, 425, -1,
424, 429, 383, 425, -1, 3, -1, 3, 8, 3,
-1, 3, 8, 3, 8, 3, -1, 622, -1, 393,
615, 394, -1, 393, 627, 394, -1, 405, 627, 405,
-1, -1, 5, -1, 3, -1, 426, 404, 5, -1,
426, 404, 3, -1, -1, 427, 429, 629, -1, -1,
427, 429, 629, 369, 397, 428, 397, 426, 398, 605,
398, -1, 427, 429, 629, 397, 615, 398, -1, -1,
404, -1, -1, 430, 431, -1, 123, 395, 433, 396,
7, -1, 629, 395, 396, 369, 435, 7, -1, 629,
395, 418, 396, 369, 435, 7, -1, -1, 629, 395,
418, 432, 404, 418, 396, 369, 435, 7, -1, 596,
-1, -1, 433, 429, 629, -1, 433, 429, 629, 397,
615, 398, -1, -1, 434, 429, 629, -1, 51, 395,
615, 396, -1, 155, 395, 5, 396, -1, -1, 436,
439, -1, 384, 384, 384, -1, -1, 397, 438, 398,
-1, 435, -1, 438, 404, 435, -1, -1, 440, 441,
-1, 445, -1, -1, -1, 441, 370, 442, 441, 8,
443, 441, -1, 441, 384, 441, -1, 441, 387, 441,
-1, 113, 395, 441, 404, 441, 396, -1, 441, 385,
441, -1, 441, 382, 441, -1, 441, 383, 441, -1,
441, 386, 441, -1, 441, 392, 441, -1, 441, 376,
441, -1, 441, 377, 441, -1, 441, 381, 441, -1,
441, 380, 441, -1, 441, 375, 441, -1, 441, 374,
441, -1, 441, 373, 441, -1, 441, 372, 441, -1,
441, 371, 441, -1, 402, 629, 369, 441, -1, 383,
441, -1, 382, 441, -1, 390, 441, -1, -1, 376,
57, 395, 441, 396, 377, 444, 395, 441, 396, -1,
393, 441, 394, -1, 616, -1, 614, 452, 454, -1,
5, 525, -1, 525, -1, 525, 452, -1, -1, 177,
446, 395, 439, 396, -1, -1, 188, 447, 395, 439,
404, 3, 396, -1, -1, 189, 448, 395, 439, 404,
615, 404, 615, 396, -1, -1, 190, 449, 395, 439,
404, 615, 404, 615, 404, 615, 404, 615, 404, 615,
396, -1, -1, 115, 395, 614, 450, 395, 439, 396,
396, 397, 615, 398, -1, 116, 395, 614, 452, 454,
396, 397, 615, 404, 615, 398, -1, 110, 395, 525,
396, -1, 112, 395, 525, 396, -1, -1, 111, 451,
395, 439, 404, 418, 396, -1, 376, 5, 377, 395,
439, 396, -1, 402, 629, -1, 402, 319, -1, 402,
207, -1, 402, 3, -1, 445, 401, 615, -1, 401,
615, -1, 445, 403, 615, -1, 641, -1, 642, -1,
395, 400, 396, -1, 395, 396, -1, 395, 453, 396,
-1, 441, -1, 453, 404, 441, -1, -1, 397, 625,
398, -1, 397, 126, 395, 418, 396, 398, -1, 397,
630, 398, -1, 397, 402, 629, 398, -1, -1, 455,
456, -1, 397, 457, 398, -1, 596, -1, -1, 457,
458, -1, 457, 596, -1, 643, 7, -1, 152, 629,
7, -1, 139, 397, 459, 398, -1, -1, 459, 397,
460, 398, -1, 459, 596, -1, -1, 460, 461, -1,
126, 418, 7, -1, 138, 629, 454, 7, -1, 133,
435, 7, -1, -1, 462, 463, -1, 397, 464, 398,
-1, 596, -1, -1, 464, 465, -1, 464, 596, -1,
643, 7, -1, 152, 629, 7, -1, 144, 435, 7,
-1, 139, 397, 466, 398, -1, -1, 466, 397, 467,
398, -1, 466, 596, -1, -1, 467, 468, -1, 142,
5, 7, -1, 143, 5, 7, -1, 139, 397, 469,
398, -1, -1, 469, 397, 470, 398, -1, -1, 470,
471, -1, 145, 5, 7, -1, 146, 615, 7, -1,
147, 615, 7, -1, 148, 615, 7, -1, 149, 615,
7, -1, 150, 615, 7, -1, -1, 472, 473, -1,
397, 474, 398, -1, 596, -1, -1, 474, 475, -1,
643, 7, -1, 152, 629, 7, -1, 142, 5, 7,
-1, 139, 397, 476, 398, -1, 139, 5, 397, 476,
398, -1, 475, 596, -1, -1, 476, 397, 477, 398,
-1, 476, 596, -1, -1, 477, 478, -1, 142, 5,
7, -1, 126, 418, 7, -1, 127, 418, 7, -1,
128, 418, 7, -1, 135, 435, 7, -1, 134, 435,
7, -1, 134, 395, 435, 404, 435, 396, 7, -1,
137, 629, 7, -1, 136, 397, 616, 429, 616, 398,
7, -1, 136, 397, 393, 615, 394, 429, 393, 615,
394, 398, 7, -1, 129, 418, 7, -1, 130, 418,
7, -1, 155, 435, 7, -1, 133, 435, 7, -1,
131, 435, 7, -1, 155, 395, 435, 404, 435, 396,
7, -1, 132, 615, 7, -1, 133, 395, 435, 404,
435, 396, 7, -1, 131, 395, 435, 404, 435, 396,
7, -1, -1, 479, 480, -1, 397, 481, 398, -1,
596, -1, -1, 481, 482, -1, 481, 596, -1, 643,
7, -1, 152, 629, 7, -1, 142, 5, 7, -1,
153, 397, 483, 398, -1, 161, 397, 487, 398, -1,
163, 397, 494, 398, -1, 125, 397, 497, 398, -1,
-1, 483, 397, 484, 398, -1, 483, 596, -1, -1,
484, 485, -1, 643, 7, -1, 152, 629, 7, -1,
154, 629, 7, -1, 155, 5, 486, 7, -1, 156,
397, 5, 429, 5, 398, 7, -1, 156, 397, 5,
429, 5, 429, 5, 398, 7, -1, 157, 437, 7,
-1, 158, 437, 7, -1, 159, 418, 7, -1, 160,
418, 7, -1, -1, 397, 169, 5, 7, 168, 629,
397, 615, 398, 7, 118, 418, 7, 193, 629, 397,
615, 398, 7, 398, -1, -1, 487, 397, 488, 398,
-1, 487, 596, -1, -1, 488, 489, -1, 643, 7,
-1, 152, 5, 7, -1, 162, 490, 7, -1, 154,
492, 7, -1, 5, -1, 397, 491, 398, -1, -1,
491, 429, 5, -1, 5, -1, 397, 493, 398, -1,
-1, 493, 429, 5, -1, -1, 494, 397, 495, 398,
-1, 494, 596, -1, -1, 495, 496, -1, 152, 629,
7, -1, 142, 5, 7, -1, 154, 629, 7, -1,
-1, 497, 397, 498, 398, -1, 497, 596, -1, -1,
498, 499, -1, 154, 629, 7, -1, 164, 419, 7,
-1, 164, 165, 7, -1, 166, 422, 7, -1, 167,
629, 7, -1, -1, 500, 501, -1, 397, 502, 398,
-1, 596, -1, -1, 502, 503, -1, 502, 596, -1,
643, 7, -1, 152, 629, 7, -1, 142, 5, 7,
-1, 169, 397, 504, 398, -1, 5, 397, 510, 398,
-1, -1, 504, 397, 505, 398, -1, 504, 596, -1,
-1, 505, 506, -1, 152, 629, 7, -1, 142, 163,
7, -1, 142, 173, 7, -1, 142, 5, 7, -1,
291, 624, 7, -1, -1, 170, 629, 507, 509, 7,
-1, 171, 615, 7, -1, -1, 395, 508, 439, 396,
7, -1, 191, 418, 7, -1, 141, 5, 7, -1,
138, 629, 7, -1, 172, 3, 7, -1, -1, 395,
629, 396, -1, -1, 510, 511, -1, 510, 596, -1,
173, 397, 516, 398, -1, 174, 397, 516, 398, -1,
175, 397, 520, 398, -1, 176, 397, 512, 398, -1,
-1, 512, 513, -1, 512, 596, -1, 142, 5, 7,
-1, 167, 629, 7, -1, 397, 514, 398, -1, -1,
514, 515, -1, 5, 525, 7, -1, 191, 418, 7,
-1, -1, 516, 517, -1, -1, -1, 524, 395, 518,
439, 519, 404, 439, 396, 7, -1, 191, 418, 7,
-1, 127, 418, 7, -1, 138, 629, 7, -1, 141,
629, 7, -1, 192, 7, -1, 5, 395, 3, 396,
7, -1, 140, 435, 7, -1, -1, 520, 521, -1,
191, 418, 7, -1, 143, 5, 7, -1, -1, -1,
524, 395, 522, 439, 523, 404, 525, 396, 7, -1,
-1, 177, -1, 178, -1, 179, -1, 180, -1, 181,
-1, 182, -1, 183, -1, 184, -1, 185, -1, 186,
-1, 187, -1, 397, 5, 629, 398, -1, 397, 629,
398, -1, -1, 526, 527, -1, 397, 528, 398, -1,
596, -1, -1, 528, 529, -1, 643, 7, -1, 152,
629, 7, -1, 194, 615, 7, -1, 195, 397, 531,
398, -1, -1, 202, 530, 397, 538, 398, -1, 596,
-1, -1, 531, 397, 532, 398, -1, 531, 596, -1,
-1, 532, 533, -1, 152, 629, 7, -1, 142, 5,
7, -1, 196, 534, 7, -1, 197, 633, 7, -1,
200, 536, 7, -1, 201, 629, 7, -1, 198, 624,
7, -1, 199, 633, 7, -1, 596, -1, 629, -1,
397, 535, 398, -1, -1, 535, 429, 629, -1, 629,
-1, 397, 537, 398, -1, -1, 537, 429, 629, -1,
-1, 538, 544, -1, -1, 404, 615, -1, 263, -1,
265, -1, 264, -1, 266, -1, 283, -1, 284, -1,
285, -1, 286, -1, 287, -1, 288, -1, 211, -1,
212, -1, 213, -1, 214, -1, 215, -1, 227, -1,
216, -1, 218, -1, 217, -1, 219, -1, 5, 629,
7, -1, 204, 435, 7, -1, 205, 435, 7, -1,
236, 397, 557, 398, -1, 237, 397, 559, 398, -1,
245, 397, 561, 398, -1, 250, 397, 563, 398, -1,
5, 395, 629, 539, 396, 7, -1, 204, 395, 435,
396, 7, -1, 205, 395, 435, 396, 7, -1, 206,
395, 435, 396, 7, -1, 256, 395, 435, 396, 7,
-1, 251, 7, -1, 251, 395, 396, 7, -1, 252,
7, -1, 252, 395, 396, 7, -1, 253, 7, -1,
253, 395, 396, 7, -1, 254, 395, 624, 396, 7,
-1, 255, 395, 396, 7, -1, 226, 7, -1, 226,
395, 396, 7, -1, 41, 395, 435, 396, 397, 538,
398, -1, 41, 395, 435, 396, 397, 538, 398, 397,
538, 398, -1, 42, 395, 435, 396, 397, 538, 398,
-1, 208, 395, 629, 404, 435, 396, 7, -1, 272,
395, 629, 404, 624, 396, 7, -1, 273, 395, 629,
404, 624, 396, 7, -1, 224, 395, 629, 396, 7,
-1, 224, 395, 629, 404, 435, 396, 7, -1, 225,
395, 629, 404, 418, 404, 629, 396, 7, -1, 225,
395, 629, 396, 7, -1, 543, 395, 629, 404, 402,
629, 396, 7, -1, 228, 395, 629, 396, 7, -1,
228, 395, 629, 404, 615, 396, 7, -1, 209, 395,
629, 404, 629, 404, 624, 396, 7, -1, 210, 395,
629, 404, 629, 404, 615, 396, 7, -1, 220, 395,
629, 404, 615, 404, 624, 404, 615, 396, 7, -1,
221, 395, 629, 404, 615, 404, 615, 404, 615, 396,
7, -1, 221, 395, 629, 404, 615, 404, 615, 404,
615, 404, 435, 396, 7, -1, 222, 395, 629, 404,
615, 404, 615, 404, 615, 396, 7, -1, 229, 395,
438, 396, 7, -1, 230, 395, 629, 404, 615, 396,
7, -1, 231, 395, 629, 396, 7, -1, 231, 395,
629, 404, 615, 396, 7, -1, 232, 395, 629, 404,
615, 396, 7, -1, 233, 395, 629, 396, 7, -1,
223, 395, 629, 404, 629, 404, 629, 404, 615, 404,
624, 404, 615, 404, 615, 396, 7, -1, 236, 395,
615, 404, 615, 404, 435, 404, 435, 396, 397, 538,
398, -1, 237, 395, 615, 404, 615, 404, 435, 404,
615, 404, 615, 396, 397, 538, 398, -1, 238, 395,
629, 404, 615, 404, 615, 404, 435, 404, 624, 404,
624, 404, 624, 396, 7, -1, 239, 395, 615, 404,
615, 404, 615, 404, 615, 404, 615, 404, 633, 404,
624, 404, 551, 550, 396, 397, 538, 398, 397, 538,
398, -1, 246, 395, 615, 404, 435, 404, 554, 396,
397, 538, 398, -1, 245, 395, 615, 404, 615, 404,
435, 396, 397, 538, 398, -1, 245, 395, 615, 404,
615, 404, 435, 404, 615, 396, 397, 538, 398, -1,
247, 395, 633, 404, 633, 404, 615, 404, 615, 404,
615, 404, 624, 404, 624, 404, 624, 396, 397, 538,
398, -1, 247, 395, 633, 404, 633, 404, 615, 404,
615, 404, 615, 404, 624, 404, 624, 404, 624, 396,
397, 538, 398, 397, 538, 398, -1, -1, 299, 545,
395, 547, 548, 396, 7, -1, -1, 303, 546, 395,
547, 548, 396, 7, -1, 259, 395, 418, 404, 435,
396, 7, -1, 259, 395, 418, 404, 435, 404, 615,
404, 435, 396, 7, -1, 294, 395, 629, 396, 7,
-1, 261, 395, 633, 396, 7, -1, 262, 395, 633,
396, 7, -1, 540, 395, 633, 396, 7, -1, 540,
395, 633, 404, 615, 396, 7, -1, 267, 7, -1,
267, 395, 396, 7, -1, 269, 395, 633, 396, 7,
-1, 270, 395, 633, 404, 633, 396, 7, -1, 271,
395, 633, 396, 7, -1, 274, 395, 629, 404, 624,
404, 615, 396, 7, -1, 277, 395, 629, 396, 7,
-1, 277, 395, 629, 404, 418, 539, 396, 7, -1,
275, 395, 629, 404, 615, 404, 633, 396, 7, -1,
276, 395, 629, 404, 624, 404, 633, 396, 7, -1,
278, 395, 629, 396, 7, -1, 279, 395, 629, 396,
7, -1, 289, 395, 629, 404, 418, 404, 633, 404,
435, 396, 7, -1, 289, 395, 629, 404, 418, 404,
633, 396, 7, -1, 280, 395, 629, 404, 629, 404,
615, 404, 615, 396, 397, 538, 398, -1, 281, 395,
629, 404, 629, 404, 615, 404, 615, 396, 397, 538,
398, -1, 282, 395, 629, 396, 7, -1, 290, 395,
629, 404, 629, 404, 197, 633, 404, 615, 404, 418,
396, 7, -1, 290, 395, 629, 404, 629, 404, 197,
633, 404, 615, 396, 7, -1, 290, 395, 629, 404,
629, 404, 197, 633, 396, 7, -1, 290, 395, 629,
404, 629, 396, 7, -1, 290, 395, 629, 404, 629,
404, 615, 396, 7, -1, 290, 395, 629, 404, 629,
404, 615, 404, 418, 396, 7, -1, 541, 395, 629,
404, 418, 396, 7, -1, 234, 395, 629, 404, 629,
396, 7, -1, 235, 395, 633, 396, 7, -1, 542,
395, 629, 404, 630, 396, 7, -1, 542, 395, 629,
404, 629, 393, 394, 396, 7, -1, 542, 395, 630,
404, 629, 396, 7, -1, 542, 395, 629, 393, 394,
404, 629, 396, 7, -1, 596, -1, 437, -1, 629,
-1, 6, -1, -1, 548, 549, -1, 404, 315, 633,
-1, 404, 319, 624, -1, 404, 325, 633, -1, 404,
624, -1, -1, 404, 615, -1, 404, 615, 404, 615,
-1, 404, 615, 404, 615, 404, 615, -1, -1, 551,
195, 397, 552, 398, -1, 551, 294, 397, 553, 398,
-1, -1, 552, 397, 629, 404, 615, 404, 615, 404,
5, 398, -1, -1, 553, 397, 629, 404, 615, 404,
615, 404, 5, 398, -1, -1, 554, 195, 397, 555,
398, -1, 554, 294, 397, 556, 398, -1, -1, 555,
397, 629, 404, 615, 404, 615, 404, 5, 5, 398,
-1, -1, 556, 397, 629, 404, 615, 404, 615, 404,
5, 398, -1, -1, 557, 558, -1, 240, 615, 7,
-1, 241, 615, 7, -1, 207, 435, 7, -1, 242,
435, 7, -1, 202, 397, 538, 398, -1, -1, 559,
560, -1, 240, 615, 7, -1, 241, 615, 7, -1,
207, 435, 7, -1, 243, 615, 7, -1, 244, 615,
7, -1, 202, 397, 538, 398, -1, -1, 561, 562,
-1, 248, 615, 7, -1, 144, 615, 7, -1, 249,
435, 7, -1, 44, 615, 7, -1, 202, 397, 538,
398, -1, -1, 563, 564, -1, 248, 615, 7, -1,
257, 615, 7, -1, 144, 615, 7, -1, 44, 615,
7, -1, 195, 629, 7, -1, 258, 397, 565, 398,
-1, 202, 397, 538, 398, -1, 203, 397, 538, 398,
-1, -1, 565, 397, 566, 398, -1, -1, 566, 567,
-1, 142, 5, 7, -1, 169, 5, 7, -1, 191,
418, 7, -1, 144, 615, 7, -1, 155, 435, 7,
-1, 44, 5, 7, -1, -1, 568, 569, -1, 397,
570, 398, -1, 596, -1, -1, 570, 571, -1, 570,
596, -1, 643, 7, -1, 152, 629, 7, -1, 196,
629, 7, -1, 293, 629, 7, -1, 169, 397, 572,
398, -1, -1, 572, 397, 573, 398, -1, 572, 596,
-1, -1, 573, 574, -1, 643, 7, -1, 152, 629,
7, -1, 134, 397, 575, 398, -1, -1, 575, 173,
397, 576, 398, -1, 575, 5, 397, 576, 398, -1,
575, 596, -1, -1, 576, 577, -1, -1, 524, 395,
578, 439, 396, 7, -1, 142, 5, 7, -1, 191,
418, 7, -1, 127, 418, 7, -1, 138, 629, 7,
-1, 141, 629, 7, -1, -1, 579, 580, -1, 397,
581, 398, -1, 596, -1, -1, 581, 582, -1, 643,
7, -1, 152, 629, 7, -1, 194, 615, 7, -1,
295, 629, 7, -1, 325, 5, 7, -1, 355, 624,
7, -1, 356, 624, 7, -1, 353, 7, -1, 353,
615, 7, -1, 367, 615, 7, -1, 361, 615, 7,
-1, 360, 615, 7, -1, 297, 395, 615, 404, 615,
404, 615, 396, 7, -1, 202, 397, 585, 398, -1,
596, -1, -1, 294, 644, 629, 296, 629, 584, 397,
585, 398, -1, -1, -1, 585, 586, 587, -1, 298,
395, 589, 592, 593, 396, 7, -1, 299, 395, 589,
592, 593, 396, 7, -1, 299, 395, 6, 404, 435,
593, 396, 7, -1, 299, 395, 6, 404, 10, 395,
633, 396, 593, 396, 7, -1, 301, 395, 633, 593,
396, 7, -1, -1, 300, 395, 418, 588, 404, 191,
418, 593, 396, 7, -1, 302, 395, 633, 396, 7,
-1, 596, -1, 629, 591, 404, -1, 629, 591, 590,
5, 591, 404, -1, 384, -1, 385, -1, 382, -1,
383, -1, -1, 395, 418, 396, -1, 305, -1, 306,
418, -1, 307, 418, -1, 309, 397, 397, 625, 398,
397, 625, 398, 397, 625, 398, 398, -1, 308, 418,
-1, 308, 397, 435, 404, 435, 404, 435, 398, 397,
624, 404, 624, 404, 624, 398, -1, 310, 397, 625,
398, -1, 311, 397, 397, 625, 398, 397, 625, 398,
398, 397, 615, 398, -1, 312, 397, 397, 625, 398,
397, 625, 398, 397, 625, 398, 398, 397, 615, 404,
615, 398, -1, 313, 397, 397, 625, 398, 397, 625,
398, 397, 625, 398, 397, 625, 398, 398, 397, 615,
404, 615, 404, 615, 398, -1, 306, 418, 314, 5,
397, 615, 404, 615, 398, 397, 615, 398, -1, 306,
418, 314, 5, 397, 615, 398, -1, -1, 593, 594,
-1, 404, 315, 633, -1, 404, 315, 377, 633, -1,
404, 315, 378, 633, -1, 404, 367, 615, -1, 404,
316, 615, -1, 404, 328, -1, 404, 329, -1, 404,
329, 615, -1, 404, 320, 615, -1, 404, 322, 615,
-1, 404, 321, -1, 404, 209, -1, 404, 325, 5,
-1, 404, 318, -1, 404, 323, 615, -1, 404, 324,
633, -1, 404, 152, 633, -1, 404, 317, 615, -1,
404, 319, 624, -1, 404, 355, 624, -1, 404, 357,
397, 615, 404, 615, 398, -1, 404, 356, 624, -1,
404, 304, 5, -1, 404, 331, 5, -1, 404, 330,
615, -1, 404, 134, 624, -1, 404, 332, 615, -1,
404, 332, 397, 625, 398, -1, 404, 333, -1, 404,
334, -1, 404, 335, -1, 404, 198, 624, -1, 404,
259, 397, 435, 404, 435, 404, 435, 398, -1, 404,
336, 437, -1, 404, 337, -1, 404, 337, 397, 615,
404, 615, 404, 615, 398, -1, 404, 338, -1, 404,
338, 397, 615, 404, 615, 404, 615, 398, -1, 404,
339, -1, 404, 339, 397, 615, 404, 615, 404, 615,
398, -1, 404, 340, 397, 625, 398, -1, 404, 342,
402, 629, -1, 404, 341, 615, -1, 404, 349, 615,
-1, 404, 350, 615, -1, 404, 351, 615, -1, 404,
352, 615, -1, 404, 345, 615, -1, 404, 346, 615,
-1, 404, 347, 615, -1, 404, 348, 615, -1, 404,
343, 615, -1, 404, 344, 615, -1, 404, 353, -1,
404, 353, 615, -1, 404, 354, -1, 404, 354, 615,
-1, 404, 358, 435, -1, 404, 359, 633, -1, 404,
368, 633, -1, 404, 360, 615, -1, 404, 361, -1,
404, 361, 615, -1, 404, 362, 633, -1, 404, 362,
633, 397, 625, 398, -1, 404, 5, 633, -1, 629,
-1, 630, -1, 31, 393, 615, 8, 615, 394, -1,
31, 393, 615, 8, 615, 8, 615, 394, -1, 31,
629, 191, 397, 615, 8, 615, 398, -1, 31, 629,
191, 397, 615, 8, 615, 8, 615, 398, -1, 32,
-1, 37, 5, -1, 37, 630, -1, 38, -1, 39,
595, 7, -1, 40, 393, 615, 394, 595, 7, -1,
33, 393, 615, 394, -1, 34, 393, 615, 394, -1,
35, -1, 36, -1, 43, 638, 633, 639, 7, -1,
599, -1, 14, -1, 15, -1, 377, -1, 378, -1,
58, 395, 608, 396, 7, -1, 59, 395, 612, 396,
7, -1, 124, 395, 434, 396, 7, -1, 620, 7,
-1, 67, 638, 633, 404, 615, 639, 7, -1, 68,
638, 633, 404, 633, 639, 7, -1, 268, 629, 7,
-1, 268, 395, 629, 396, 7, -1, 268, 62, 7,
-1, 629, 369, 624, 7, -1, 629, 393, 394, 369,
624, 7, -1, 629, 393, 625, 394, 369, 624, 7,
-1, 629, 393, 625, 394, 382, 369, 624, 7, -1,
629, 393, 625, 394, 383, 369, 624, 7, -1, 629,
382, 369, 624, 7, -1, 629, 393, 394, 382, 369,
624, 7, -1, 629, 383, 369, 624, 7, -1, 629,
393, 394, 383, 369, 624, 7, -1, 629, 369, 630,
7, -1, 629, 393, 394, 369, 10, 395, 396, 7,
-1, 629, 393, 394, 369, 10, 638, 635, 639, 7,
-1, 629, 393, 394, 382, 369, 10, 638, 635, 639,
7, -1, 597, 638, 630, 639, 7, -1, 597, 638,
630, 639, 598, 633, 7, -1, 597, 629, 7, -1,
597, 401, 7, -1, 597, 638, 630, 404, 625, 639,
7, -1, 597, 638, 630, 404, 625, 639, 598, 633,
7, -1, 262, 393, 633, 394, 7, -1, 16, 393,
629, 394, 7, -1, 16, 395, 629, 396, 7, -1,
16, 393, 629, 394, 395, 615, 396, 7, -1, 16,
395, 629, 404, 615, 398, 7, -1, 17, 7, -1,
615, 369, 633, -1, 600, 404, 615, 369, 633, -1,
627, 369, 629, 393, 394, -1, -1, 404, 603, -1,
-1, 603, -1, 604, -1, 603, 404, 604, -1, 5,
624, -1, 5, -1, 5, 397, 600, 398, -1, 5,
630, -1, 5, 634, -1, 152, 630, -1, 142, 624,
-1, -1, 404, 606, -1, 607, -1, 606, 404, 607,
-1, 5, 615, -1, 5, 630, -1, 152, 630, -1,
37, 630, -1, 5, 636, -1, 5, 634, -1, -1,
608, 429, 629, -1, 608, 429, 629, 397, 615, 398,
-1, 608, 429, 629, 369, 615, -1, 608, 429, 629,
393, 394, 369, 397, 398, -1, -1, 608, 429, 629,
369, 397, 624, 609, 601, 398, -1, -1, 608, 429,
629, 393, 394, 369, 397, 624, 610, 601, 398, -1,
608, 429, 629, 369, 630, -1, -1, 608, 429, 629,
369, 397, 630, 611, 605, 398, -1, -1, 612, 429,
630, -1, 612, 429, 629, -1, 87, -1, 88, -1,
89, -1, 90, -1, 91, -1, 92, -1, 93, -1,
94, -1, 95, -1, 96, -1, 97, -1, 98, -1,
99, -1, 100, -1, 101, -1, 102, -1, 103, -1,
104, -1, 105, -1, 106, -1, 107, -1, 108, -1,
109, -1, 613, -1, 629, -1, 616, -1, 393, 615,
394, -1, 383, 615, -1, 390, 615, -1, 615, 383,
615, -1, 615, 382, 615, -1, 615, 384, 615, -1,
615, 388, 615, -1, 615, 389, 615, -1, 615, 385,
615, -1, 615, 386, 615, -1, 615, 392, 615, -1,
615, 376, 615, -1, 615, 377, 615, -1, 615, 381,
615, -1, 615, 380, 615, -1, 615, 375, 615, -1,
615, 374, 615, -1, 615, 372, 615, -1, 615, 371,
615, -1, 615, 378, 615, -1, 615, 379, 615, -1,
87, 395, 615, 396, -1, 88, 395, 615, 396, -1,
89, 395, 615, 396, -1, 90, 395, 615, 396, -1,
91, 395, 615, 396, -1, 92, 395, 615, 396, -1,
93, 395, 615, 396, -1, 94, 395, 615, 396, -1,
95, 395, 615, 396, -1, 96, 395, 615, 396, -1,
97, 395, 615, 404, 615, 396, -1, 98, 395, 615,
396, -1, 99, 395, 615, 396, -1, 100, 395, 615,
396, -1, 101, 395, 615, 396, -1, 102, 395, 615,
396, -1, 103, 395, 615, 396, -1, 104, 395, 615,
396, -1, 105, 395, 615, 396, -1, 106, 395, 615,
404, 615, 396, -1, 107, 395, 615, 404, 615, 396,
-1, 108, 395, 615, 404, 615, 396, -1, 109, 395,
615, 396, -1, 615, 370, 615, 8, 615, -1, 641,
-1, 642, -1, 615, 401, -1, 4, -1, 3, -1,
69, -1, 72, -1, 73, -1, 74, -1, 75, -1,
70, -1, 71, -1, 84, -1, 85, -1, 86, -1,
77, -1, 76, -1, 78, -1, 50, -1, -1, 60,
395, 615, 617, 601, 396, -1, 620, -1, 622, 400,
623, -1, 622, 400, 623, 393, 615, 394, -1, 65,
638, 633, 639, -1, 65, 638, 633, 404, 615, 639,
-1, 622, -1, 401, 622, 393, 394, -1, 401, 622,
400, 623, 393, 394, -1, 64, 638, 629, 639, -1,
64, 638, 639, -1, 622, 393, 615, 394, -1, 45,
638, 622, 639, -1, 45, 638, 622, 400, 623, 639,
-1, 45, 638, 629, 395, 396, 639, -1, 47, 638,
622, 618, 639, -1, 47, 638, 622, 400, 623, 618,
639, -1, 46, 638, 633, 639, -1, -1, 404, 615,
-1, -1, 404, 633, -1, -1, 62, 622, 644, 621,
395, 602, 396, -1, 629, -1, 629, 9, 629, -1,
5, -1, 142, -1, 397, 398, -1, 615, -1, 627,
-1, 397, 625, 398, -1, 383, 397, 625, 398, -1,
615, 384, 397, 625, 398, -1, 615, -1, 627, -1,
625, 404, 615, -1, 625, 404, 627, -1, 622, 393,
394, -1, 622, 400, 623, 393, 394, -1, 383, 627,
-1, 615, 384, 627, -1, 627, 384, 615, -1, 615,
385, 627, -1, 627, 385, 615, -1, 627, 392, 615,
-1, 627, 382, 627, -1, 627, 383, 627, -1, 627,
384, 627, -1, 627, 385, 627, -1, 615, 8, 615,
-1, 615, 8, 615, 8, 615, -1, 28, 395, 418,
396, -1, 622, 393, 394, -1, 622, 393, 397, 625,
398, 394, -1, 622, 400, 623, 393, 394, -1, 52,
395, 629, 396, -1, 52, 395, 627, 396, -1, 52,
395, 397, 625, 398, 396, -1, 53, 395, 629, 404,
629, 396, -1, 53, 395, 627, 404, 627, 396, -1,
54, 395, 615, 404, 615, 404, 615, 396, -1, 55,
395, 615, 404, 615, 404, 615, 396, -1, 56, 395,
633, 396, -1, 5, 399, 397, 615, 398, -1, 628,
399, 397, 615, 398, -1, 29, 395, 633, 396, 399,
397, 615, 398, -1, 5, -1, 628, -1, 29, 395,
633, 396, -1, 6, -1, 30, 395, 629, 396, -1,
640, -1, 23, 395, 633, 396, -1, 24, 395, 633,
396, -1, 25, 395, 633, 396, -1, 10, 638, 637,
639, -1, 21, 638, 615, 404, 633, 404, 633, 639,
-1, 22, 638, 633, 404, 615, 404, 615, 639, -1,
22, 638, 633, 404, 615, 639, -1, 13, 638, 633,
639, -1, 13, 638, 633, 404, 625, 639, -1, 363,
-1, 363, 638, 633, 639, -1, 364, -1, 365, -1,
83, -1, 79, -1, 80, 638, 633, 639, -1, 81,
638, 633, 639, -1, 82, -1, 366, 638, 633, 639,
-1, -1, 61, 395, 630, 631, 605, 396, -1, 66,
638, 633, 639, -1, 66, 638, 633, 404, 633, 639,
-1, 48, 393, 622, 619, 394, -1, 48, 393, 622,
400, 623, 619, 394, -1, 63, 638, 632, 639, -1,
401, 615, -1, 629, 9, 401, 615, -1, 630, -1,
622, -1, 622, 393, 615, 394, -1, 622, 400, 623,
-1, 622, 400, 623, 393, 615, 394, -1, 10, 638,
636, 639, -1, 637, -1, 636, -1, 397, 637, 398,
-1, 633, -1, 626, -1, 637, 404, 633, -1, 637,
404, 626, -1, 393, -1, 395, -1, 394, -1, 396,
-1, 12, 638, 637, 639, -1, 18, 638, 633, 404,
633, 639, -1, 20, 638, 633, 639, -1, 19, 638,
633, 404, 633, 639, -1, 26, 395, 396, -1, 26,
395, 629, 396, -1, 27, 395, 629, 404, 615, 396,
-1, 117, -1, 117, 615, -1, -1, 393, 643, 394,
-1
};
/* YYRLINE[YYN] -- source line where rule number YYN was defined. */
static const yytype_uint16 yyrline[] =
{
0, 395, 395, 395, 405, 409, 408, 416, 417, 418,
419, 420, 421, 422, 423, 424, 425, 427, 429, 431,
444, 447, 453, 456, 460, 476, 459, 487, 489, 495,
494, 525, 536, 541, 556, 564, 567, 580, 581, 588,
590, 600, 625, 637, 644, 651, 655, 662, 673, 678,
686, 698, 736, 743, 757, 772, 776, 782, 789, 795,
803, 807, 820, 819, 839, 858, 858, 865, 868, 873,
875, 896, 947, 946, 1007, 1011, 1014, 1025, 1042, 1045,
1062, 1068, 1076, 1076, 1083, 1091, 1095, 1101, 1104, 1111,
1111, 1124, 1127, 1140, 1126, 1168, 1176, 1184, 1192, 1200,
1208, 1216, 1224, 1232, 1240, 1248, 1256, 1264, 1273, 1281,
1289, 1297, 1306, 1313, 1321, 1323, 1332, 1331, 1362, 1364,
1370, 1447, 1481, 1490, 1503, 1502, 1516, 1515, 1530, 1529,
1546, 1545, 1566, 1564, 1582, 1663, 1669, 1676, 1675, 1706,
1732, 1747, 1753, 1760, 1766, 1773, 1780, 1787, 1793, 1803,
1804, 1805, 1810, 1811, 1817, 1819, 1822, 1830, 1833, 1845,
1850, 1856, 1864, 1870, 1874, 1875, 1881, 1884, 1897, 1905,
1910, 1912, 1919, 1923, 1929, 1937, 1967, 1979, 1984, 1989,
1997, 2003, 2010, 2011, 2017, 2020, 2033, 2036, 2044, 2049,
2051, 2058, 2063, 2069, 2079, 2089, 2097, 2099, 2107, 2116,
2122, 2170, 2173, 2176, 2179, 2182, 2194, 2198, 2203, 2211,
2217, 2224, 2230, 2233, 2246, 2255, 2262, 2279, 2286, 2292,
2297, 2307, 2315, 2321, 2331, 2336, 2342, 2348, 2355, 2365,
2375, 2383, 2392, 2401, 2420, 2429, 2437, 2445, 2455, 2465,
2474, 2484, 2505, 2510, 2515, 2523, 2530, 2536, 2538, 2544,
2547, 2560, 2569, 2571, 2573, 2575, 2582, 2589, 2615, 2622,
2639, 2645, 2650, 2664, 2671, 2685, 2708, 2739, 2744, 2749,
2754, 2783, 2787, 2844, 2850, 2858, 2865, 2871, 2877, 2882,
2895, 2898, 2905, 2924, 2932, 2937, 2958, 2972, 2980, 2985,
3002, 3008, 3014, 3021, 3026, 3032, 3039, 3050, 3066, 3072,
3117, 3124, 3134, 3140, 3175, 3178, 3183, 3186, 3204, 3208,
3213, 3221, 3228, 3234, 3236, 3242, 3245, 3258, 3268, 3270,
3280, 3286, 3291, 3298, 3313, 3319, 3322, 3326, 3329, 3339,
3344, 3343, 3377, 3383, 3382, 3650, 3655, 3666, 3677, 3682,
3685, 3728, 3734, 3739, 3748, 3751, 3754, 3757, 3765, 3770,
3771, 3776, 3786, 3797, 3812, 3818, 3822, 3834, 3843, 3862,
3869, 3877, 3868, 4010, 4015, 4020, 4031, 4042, 4047, 4054,
4064, 4079, 4084, 4089, 4101, 4109, 4100, 4181, 4182, 4183,
4184, 4185, 4186, 4187, 4188, 4189, 4190, 4191, 4192, 4198,
4219, 4244, 4248, 4253, 4261, 4268, 4276, 4282, 4285, 4298,
4300, 4304, 4303, 4308, 4314, 4321, 4330, 4340, 4352, 4358,
4367, 4376, 4379, 4385, 4396, 4401, 4406, 4411, 4417, 4427,
4435, 4437, 4450, 4461, 4468, 4470, 4484, 4494, 4505, 4506,
4511, 4512, 4513, 4514, 4517, 4518, 4519, 4520, 4521, 4522,
4525, 4526, 4527, 4528, 4529, 4532, 4533, 4534, 4535, 4536,
4542, 4566, 4573, 4580, 4586, 4592, 4598, 4606, 4629, 4636,
4643, 4650, 4657, 4663, 4669, 4675, 4681, 4687, 4693, 4700,
4706, 4712, 4718, 4729, 4741, 4751, 4764, 4786, 4808, 4821,
4834, 4855, 4869, 4890, 4903, 4916, 4934, 4954, 4977, 4993,
5010, 5026, 5033, 5046, 5059, 5072, 5085, 5097, 5132, 5145,
5159, 5178, 5198, 5209, 5222, 5235, 5254, 5275, 5274, 5284,
5283, 5292, 5303, 5315, 5325, 5333, 5341, 5351, 5361, 5368,
5375, 5384, 5395, 5404, 5418, 5432, 5447, 5461, 5475, 5486,
5497, 5512, 5527, 5547, 5567, 5579, 5598, 5616, 5633, 5650,
5667, 5685, 5699, 5716, 5723, 5738, 5753, 5768, 5783, 5792,
5798, 5809, 5818, 5823, 5827, 5830, 5842, 5847, 5863, 5869,
5876, 5883, 5894, 5901, 5906, 5916, 5920, 5941, 5945, 5962,
5969, 5974, 5984, 5988, 6016, 6020, 6041, 6050, 6056, 6060,
6064, 6068, 6073, 6085, 6095, 6101, 6105, 6109, 6113, 6117,
6122, 6134, 6143, 6148, 6152, 6156, 6160, 6164, 6176, 6188,
6193, 6197, 6201, 6205, 6210, 6221, 6227, 6233, 6244, 6246,
6252, 6264, 6269, 6279, 6307, 6310, 6313, 6321, 6340, 6346,
6351, 6359, 6364, 6373, 6375, 6379, 6382, 6395, 6409, 6414,
6420, 6426, 6434, 6439, 6446, 6451, 6456, 6469, 6476, 6488,
6494, 6506, 6512, 6522, 6527, 6526, 6562, 6573, 6578, 6583,
6594, 6614, 6620, 6625, 6633, 6638, 6654, 6658, 6661, 6674,
6676, 6689, 6700, 6705, 6710, 6715, 6720, 6725, 6730, 6735,
6743, 6748, 6754, 6753, 6804, 6812, 6811, 6905, 6911, 6916,
6925, 6934, 6944, 6943, 6956, 6962, 6971, 6984, 7010, 7011,
7012, 7013, 7019, 7020, 7026, 7032, 7039, 7046, 7070, 7077,
7089, 7102, 7122, 7148, 7182, 7202, 7224, 7226, 7230, 7235,
7240, 7245, 7249, 7253, 7257, 7261, 7265, 7269, 7273, 7277,
7281, 7291, 7295, 7299, 7303, 7307, 7314, 7325, 7329, 7335,
7339, 7348, 7357, 7364, 7373, 7377, 7387, 7391, 7395, 7399,
7408, 7414, 7418, 7426, 7433, 7441, 7448, 7456, 7463, 7471,
7475, 7479, 7483, 7487, 7491, 7495, 7499, 7503, 7507, 7511,
7515, 7519, 7523, 7527, 7531, 7535, 7539, 7543, 7547, 7551,
7555, 7559, 7563, 7568, 7591, 7593, 7599, 7616, 7633, 7655,
7676, 7713, 7721, 7729, 7735, 7742, 7750, 7770, 7796, 7808,
7814, 7819, 7828, 7829, 7833, 7837, 7845, 7847, 7849, 7851,
7853, 7859, 7866, 7876, 7886, 7891, 7906, 7914, 7942, 7970,
7998, 8020, 8037, 8072, 8102, 8109, 8117, 8125, 8142, 8147,
8162, 8179, 8184, 8198, 8221, 8228, 8239, 8251, 8266, 8281,
8288, 8294, 8299, 8331, 8333, 8336, 8338, 8342, 8343, 8348,
8361, 8375, 8390, 8399, 8411, 8419, 8431, 8433, 8437, 8438,
8443, 8451, 8460, 8468, 8476, 8490, 8505, 8508, 8516, 8532,
8540, 8549, 8548, 8575, 8574, 8586, 8595, 8594, 8607, 8610,
8618, 8633, 8634, 8635, 8636, 8637, 8638, 8639, 8640, 8641,
8642, 8643, 8644, 8645, 8646, 8647, 8648, 8649, 8650, 8651,
8652, 8653, 8654, 8655, 8659, 8660, 8664, 8665, 8666, 8667,
8668, 8669, 8670, 8671, 8672, 8673, 8674, 8675, 8676, 8677,
8678, 8679, 8680, 8681, 8682, 8683, 8684, 8685, 8686, 8687,
8688, 8689, 8690, 8691, 8692, 8693, 8694, 8695, 8696, 8697,
8698, 8699, 8700, 8701, 8702, 8703, 8704, 8705, 8706, 8707,
8708, 8710, 8712, 8714, 8716, 8721, 8722, 8723, 8724, 8725,
8726, 8727, 8728, 8729, 8730, 8731, 8732, 8733, 8735, 8736,
8737, 8741, 8740, 8750, 8753, 8758, 8763, 8769, 8775, 8780,
8800, 8805, 8811, 8817, 8822, 8827, 8832, 8841, 8846, 8851,
8861, 8862, 8868, 8869, 8875, 8874, 8897, 8899, 8904, 8906,
8913, 8916, 8922, 8925, 8928, 8937, 8950, 8956, 8959, 8962,
8975, 8979, 8987, 8996, 9005, 9014, 9023, 9032, 9041, 9056,
9071, 9086, 9101, 9109, 9121, 9132, 9152, 9180, 9186, 9203,
9208, 9213, 9254, 9274, 9283, 9292, 9324, 9333, 9342, 9354,
9357, 9361, 9366, 9369, 9372, 9377, 9387, 9397, 9408, 9428,
9440, 9449, 9458, 9463, 9483, 9492, 9505, 9512, 9517, 9522,
9529, 9535, 9541, 9546, 9553, 9552, 9563, 9569, 9577, 9582,
9587, 9611, 9613, 9620, 9623, 9630, 9635, 9640, 9647, 9652,
9654, 9659, 9664, 9669, 9671, 9673, 9688, 9688, 9689, 9689,
9693, 9715, 9726, 9736, 9750, 9759, 9770, 9796, 9798, 9804,
9805
};
#endif
#if YYDEBUG || YYERROR_VERBOSE || YYTOKEN_TABLE
/* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
First, the terminals, then, starting at YYNTOKENS, nonterminals. */
static const char *const yytname[] =
{
"$end", "error", "$undefined", "tINT", "tFLOAT", "tSTRING", "tBIGSTR",
"tEND", "tDOTS", "tSCOPE", "tStr", "tStrList", "tStrCat", "tSprintf",
"tPrintf", "tMPI_Printf", "tRead", "tPrintConstants", "tStrCmp",
"tStrFind", "tStrLen", "tStrChoice", "tStrSub", "tUpperCase",
"tLowerCase", "tLowerCaseIn", "tNbrRegions", "tGetRegion", "tGetRegions",
"tStringToName", "tNameToString", "tFor", "tEndFor", "tIf", "tElseIf",
"tElse", "tEndIf", "tMacro", "tReturn", "tCall", "tCallTest", "tTest",
"tWhile", "tParse", "tFlag", "tExists", "tFileExists", "tGetForced",
"tGetForcedStr", "tInclude", "tLevelInclude", "tConstant", "tList",
"tListAlt", "tLinSpace", "tLogSpace", "tListFromFile",
"tChangeCurrentPosition", "tDefineConstant", "tUndefineConstant",
"tDefineNumber", "tDefineString", "tDefineStruct", "tNameStruct",
"tDimNameSpace", "tGetNumber", "tGetString", "tSetNumber", "tSetString",
"tPi", "tMPI_Rank", "tMPI_Size", "t0D", "t1D", "t2D", "t3D",
"tLevelTest", "tTotalMemory", "tNumInclude", "tCurrentDirectory",
"tAbsolutePath", "tDirName", "tBaseFileName", "tCurrentFileName",
"tGETDP_MAJOR_VERSION", "tGETDP_MINOR_VERSION", "tGETDP_PATCH_VERSION",
"tExp", "tLog", "tLog10", "tSqrt", "tSin", "tAsin", "tCos", "tAcos",
"tTan", "tAtan", "tAtan2", "tSinh", "tCosh", "tTanh", "tFabs", "tFloor",
"tCeil", "tRound", "tSign", "tFmod", "tModulo", "tHypot", "tRand",
"tSolidAngle", "tTrace", "tOrder", "tCrossProduct", "tDofValue",
"tMHTransform", "tMHJacNL", "tAppend", "tGroup", "tDefineGroup", "tAll",
"tInSupport", "tMovingBand2D", "tDefineFunction", "tUndefineFunction",
"tConstraint", "tRegion", "tSubRegion", "tSubRegion2", "tRegionRef",
"tSubRegionRef", "tFilter", "tToleranceFactor", "tCoefficient", "tValue",
"tTimeFunction", "tBranch", "tNameOfResolution", "tJacobian", "tCase",
"tMetricTensor", "tIntegration", "tType", "tSubType", "tCriterion",
"tGeoElement", "tNumberOfPoints", "tMaxNumberOfPoints",
"tNumberOfDivisions", "tMaxNumberOfDivisions", "tStoppingCriterion",
"tFunctionSpace", "tName", "tBasisFunction", "tNameOfCoef", "tFunction",
"tdFunction", "tSubFunction", "tSubdFunction", "tSupport", "tEntity",
"tSubSpace", "tNameOfBasisFunction", "tGlobalQuantity", "tEntityType",
"tAuto", "tEntitySubType", "tNameOfConstraint", "tFormulation",
"tQuantity", "tNameOfSpace", "tIndexOfSystem", "tSymmetry", "tGalerkin",
"tdeRham", "tGlobalTerm", "tGlobalEquation", "tDt", "tDtDof", "tDtDt",
"tDtDtDof", "tDtDtDtDof", "tDtDtDtDtDof", "tDtDtDtDtDtDof", "tJacNL",
"tDtDofJacNL", "tNeverDt", "tDtNL", "tAtAnteriorTimeStep",
"tMaxOverTime", "tFourierSteinmetz", "tIn", "tFull_Matrix",
"tResolution", "tHidden", "tDefineSystem", "tNameOfFormulation",
"tNameOfMesh", "tFrequency", "tSolver", "tOriginSystem",
"tDestinationSystem", "tOperation", "tOperationEnd", "tSetTime",
"tSetTimeStep", "tSetDTime", "tDTime", "tSetFrequency",
"tFourierTransform", "tFourierTransformJ", "tCopySolution", "tCopyRHS",
"tCopyResidual", "tCopyIncrement", "tCopyDofs", "tGetNormSolution",
"tGetNormResidual", "tGetNormRHS", "tGetNormIncrement", "tLanczos",
"tEigenSolve", "tEigenSolveJac", "tPerturbation", "tUpdate",
"tUpdateConstraint", "tBreak", "tGetResidual", "tCreateSolution",
"tEvaluate", "tSelectCorrection", "tAddCorrection", "tMultiplySolution",
"tAddOppositeFullSolution", "tSolveAgainWithOther",
"tSetGlobalSolverOptions", "tTimeLoopTheta", "tTimeLoopNewmark",
"tTimeLoopRungeKutta", "tTimeLoopAdaptive", "tTime0", "tTimeMax",
"tTheta", "tBeta", "tGamma", "tIterativeLoop", "tIterativeLoopN",
"tIterativeLinearSolver", "tNbrMaxIteration", "tRelaxationFactor",
"tIterativeTimeReduction", "tSetCommSelf", "tSetCommWorld", "tBarrier",
"tBroadcastFields", "tBroadcastVariables", "tSleep",
"tDivisionCoefficient", "tChangeOfState", "tChangeOfCoordinates",
"tChangeOfCoordinates2", "tSystemCommand", "tError", "tGmshRead",
"tGmshMerge", "tGmshOpen", "tGmshWrite", "tGmshClearAll", "tDelete",
"tDeleteFile", "tRenameFile", "tCreateDir", "tGenerateOnly",
"tGenerateOnlyJac", "tSolveJac_AdaptRelax", "tSaveSolutionExtendedMH",
"tSaveSolutionMHtoTime", "tSaveSolutionWithEntityNum",
"tInitMovingBand2D", "tMeshMovingBand2D", "tGenerateMHMoving",
"tGenerateMHMovingSeparate", "tAddMHMoving", "tGenerateGroup",
"tGenerateJacGroup", "tGenerateRHSGroup", "tGenerateGroupCumulative",
"tGenerateJacGroupCumulative", "tGenerateRHSGroupCumulative",
"tSaveMesh", "tDeformMesh", "tFrequencySpectrum", "tPostProcessing",
"tNameOfSystem", "tPostOperation", "tNameOfPostProcessing", "tUsingPost",
"tResampleTime", "tPlot", "tPrint", "tPrintGroup", "tEcho",
"tSendMergeFileRequest", "tWrite", "tAdapt", "tOnGlobal", "tOnRegion",
"tOnElementsOf", "tOnGrid", "tOnSection", "tOnPoint", "tOnLine",
"tOnPlane", "tOnBox", "tWithArgument", "tFile", "tDepth", "tDimension",
"tComma", "tTimeStep", "tHarmonicToTime", "tCosineTransform",
"tTimeToHarmonic", "tValueIndex", "tValueName", "tFormat", "tHeader",
"tFooter", "tSkin", "tSmoothing", "tTarget", "tSort", "tIso",
"tNoNewLine", "tNoTitle", "tDecomposeInSimplex", "tChangeOfValues",
"tTimeLegend", "tFrequencyLegend", "tEigenvalueLegend",
"tEvaluationPoints", "tStoreInRegister", "tStoreInVariable",
"tStoreInField", "tStoreInMeshBasedField", "tStoreMaxInRegister",
"tStoreMaxXinRegister", "tStoreMaxYinRegister", "tStoreMaxZinRegister",
"tStoreMinInRegister", "tStoreMinXinRegister", "tStoreMinYinRegister",
"tStoreMinZinRegister", "tLastTimeStepOnly", "tAppendTimeStepToFileName",
"tTimeValue", "tTimeImagValue", "tTimeInterval",
"tAppendExpressionToFileName", "tAppendExpressionFormat",
"tOverrideTimeStepValue", "tNoMesh", "tSendToServer", "tDate",
"tOnelabAction", "tCodeName", "tFixRelativePath",
"tAppendToExistingFile", "tAppendStringToFileName", "tDEF", "'?'", "tOR",
"tAND", "tAPPROXEQUAL", "tNOTEQUAL", "tEQUAL", "'<'", "'>'",
"tGREATERGREATER", "tLESSLESS", "tGREATEROREQUAL", "tLESSOREQUAL", "'+'",
"'-'", "'*'", "'/'", "'%'", "tCROSSPRODUCT", "'|'", "'&'", "'!'",
"UNARYPREC", "'^'", "'('", "')'", "'['", "']'", "'{'", "'}'", "'~'",
"'.'", "'#'", "'$'", "tSHOW", "','", "'@'", "$accept", "Stats", "@1",
"ProblemDefinitions", "@2", "ProblemDefinition", "Groups", "Group", "@3",
"@4", "ReducedGroupRHS", "@5", "GroupRHS", "FunctionForGroup",
"ListOfRegionOrAll", "SuppListOfRegion", "SuppListTypeForGroup",
"ListOfRegion", "RecursiveListOfRegion", "IRegion",
"ListOfStringsForCharOptions", "DefineGroups", "@6", "Comma",
"Functions", "Function", "@7", "DefineFunctions", "UndefineFunctions",
"Expression", "@8", "ListOfExpression", "RecursiveListOfExpression",
"WholeQuantityExpression", "@9", "WholeQuantity", "@10", "@11", "@12",
"WholeQuantity_Single", "@13", "@14", "@15", "@16", "@17", "@18",
"ArgumentsForFunction", "RecursiveListOfQuantity",
"ParametersForFunction", "JacobianMethods", "BracedJacobianMethod",
"JacobianMethod", "JacobianMethodTerm", "JacobianCases", "JacobianCase",
"JacobianCaseTerm", "IntegrationMethods", "BracedIntegrationMethod",
"IntegrationMethod", "IntegrationMethodTerm", "IntegrationCases",
"IntegrationCase", "IntegrationCaseTerm", "QuadratureCases",
"QuadratureCase", "QuadratureCaseTerm", "Constraints",
"BracedConstraint", "Constraint", "ConstraintTerm", "ConstraintCases",
"ConstraintCase", "ConstraintCaseTerm", "FunctionSpaces",
"BracedFunctionSpace", "FunctionSpace", "FunctionSpaceTerm",
"BasisFunctions", "BasisFunction", "BasisFunctionTerm",
"OptionalParametersForBasisFunction", "SubSpaces", "SubSpace",
"SubSpaceTerm", "ListOfBasisFunction", "RecursiveListOfBasisFunction",
"ListOfBasisFunctionCoef", "RecursiveListOfBasisFunctionCoef",
"GlobalQuantities", "GlobalQuantity", "GlobalQuantityTerm",
"ConstraintInFSs", "ConstraintInFS", "ConstraintInFSTerm",
"Formulations", "BracedFormulation", "Formulation", "FormulationTerm",
"DefineQuantities", "DefineQuantity", "DefineQuantityTerm", "@19", "@20",
"IndexInFunctionSpace", "Equations", "EquationTerm", "GlobalEquation",
"GlobalEquationTerm", "GlobalEquationTermTerm",
"GlobalEquationTermTermTerm", "LocalTerm", "LocalTermTerm", "@21", "@22",
"GlobalTerm", "GlobalTermTerm", "@23", "@24", "TermOperator",
"Quantity_Def", "Resolutions", "BracedResolution", "Resolution",
"ResolutionTerm", "@25", "DefineSystems", "DefineSystem",
"DefineSystemTerm", "ListOfFormulation", "RecursiveListOfFormulation",
"ListOfSystem", "RecursiveListOfSystem", "Operation",
"CommaFExprOrNothing", "GmshOperation", "GenerateGroupOperation",
"CopyOperation", "GetOperation", "OperationTerm", "@26", "@27",
"PrintOperation", "PrintOperationOptions", "PrintOperationOption",
"TLAoptions", "LTEdefinitions", "TimeLoopAdaptiveSystems",
"TimeLoopAdaptivePOs", "IterativeLoopDefinitions",
"IterativeLoopSystems", "IterativeLoopPOs", "TimeLoopTheta",
"TimeLoopThetaTerm", "TimeLoopNewmark", "TimeLoopNewmarkTerm",
"IterativeLoop", "IterativeLoopTerm", "IterativeTimeReduction",
"IterativeTimeReductionTerm", "ChangeOfStates", "ChangeOfState",
"ChangeOfStateTerm", "PostProcessings", "BracedPostProcessing",
"PostProcessing", "PostProcessingTerm", "PostQuantities", "PostQuantity",
"PostQuantityTerm", "SubPostQuantities", "SubPostQuantity",
"SubPostQuantityTerm", "@28", "PostOperations", "BracedPostOperation",
"PostOperation", "PostOperationTerm", "SeparatePostOperation", "@29",
"PostSubOperations", "@30", "PostSubOperation", "@31",
"PostQuantitiesToPrint", "Combination", "PostQuantitySupport",
"PrintSubType", "PrintOptions", "PrintOption", "CallArg", "Loop",
"Printf", "SendToFile", "Affectation", "Enumeration",
"FloatParameterOptionsOrNone", "FloatParameterOptionsOrNone_NoComma",
"FloatParameterOptions", "FloatParameterOption",
"CharParameterOptionsOrNone", "CharParameterOptions",
"CharParameterOption", "DefineConstants", "@32", "@33", "@34",
"UndefineConstants", "NameForMathFunction", "NameForFunction", "FExpr",
"OneFExpr", "@35", "GetForced_Default", "GetForcedStr_Default",
"DefineStruct", "@36", "Struct_FullName", "tSTRING_Member",
"ListOfFExpr", "RecursiveListOfFExpr", "MultiCharExpr", "MultiFExpr",
"StringIndex", "String__Index", "CharExprNoVar", "@37", "NameStruct_Arg",
"CharExpr", "Str_BracedRecursiveListOfCharExpr",
"BracedOrNotRecursiveListOfCharExpr", "BracedRecursiveListOfCharExpr",
"RecursiveListOfCharExpr", "LP", "RP", "StrCat", "StrCmp", "NbrRegions",
"Append", "AppendOrNot", 0
};
#endif
# ifdef YYPRINT
/* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to
token YYLEX-NUM. */
static const yytype_uint16 yytoknum[] =
{
0, 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,
285, 286, 287, 288, 289, 290, 291, 292, 293, 294,
295, 296, 297, 298, 299, 300, 301, 302, 303, 304,
305, 306, 307, 308, 309, 310, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 324,
325, 326, 327, 328, 329, 330, 331, 332, 333, 334,
335, 336, 337, 338, 339, 340, 341, 342, 343, 344,
345, 346, 347, 348, 349, 350, 351, 352, 353, 354,
355, 356, 357, 358, 359, 360, 361, 362, 363, 364,
365, 366, 367, 368, 369, 370, 371, 372, 373, 374,
375, 376, 377, 378, 379, 380, 381, 382, 383, 384,
385, 386, 387, 388, 389, 390, 391, 392, 393, 394,
395, 396, 397, 398, 399, 400, 401, 402, 403, 404,
405, 406, 407, 408, 409, 410, 411, 412, 413, 414,
415, 416, 417, 418, 419, 420, 421, 422, 423, 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, 466, 467, 468, 469, 470, 471, 472, 473, 474,
475, 476, 477, 478, 479, 480, 481, 482, 483, 484,
485, 486, 487, 488, 489, 490, 491, 492, 493, 494,
495, 496, 497, 498, 499, 500, 501, 502, 503, 504,
505, 506, 507, 508, 509, 510, 511, 512, 513, 514,
515, 516, 517, 518, 519, 520, 521, 522, 523, 524,
525, 526, 527, 528, 529, 530, 531, 532, 533, 534,
535, 536, 537, 538, 539, 540, 541, 542, 543, 544,
545, 546, 547, 548, 549, 550, 551, 552, 553, 554,
555, 556, 557, 558, 559, 560, 561, 562, 563, 564,
565, 566, 567, 568, 569, 570, 571, 572, 573, 574,
575, 576, 577, 578, 579, 580, 581, 582, 583, 584,
585, 586, 587, 588, 589, 590, 591, 592, 593, 594,
595, 596, 597, 598, 599, 600, 601, 602, 603, 604,
605, 606, 607, 608, 609, 610, 611, 612, 613, 614,
615, 616, 617, 618, 619, 620, 621, 622, 623, 624,
63, 625, 626, 627, 628, 629, 60, 62, 630, 631,
632, 633, 43, 45, 42, 47, 37, 634, 124, 38,
33, 635, 94, 40, 41, 91, 93, 123, 125, 126,
46, 35, 36, 636, 44, 64
};
# endif
/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
static const yytype_uint16 yyr1[] =
{
0, 406, 408, 407, 409, 410, 409, 411, 411, 411,
411, 411, 411, 411, 411, 411, 411, 411, 411, 411,
412, 412, 413, 413, 414, 415, 413, 413, 413, 417,
416, 416, 418, 418, 418, 419, 419, 420, 420, 421,
421, 421, 422, 423, 423, 424, 424, 424, 425, 425,
425, 425, 425, 425, 425, 426, 426, 426, 426, 426,
427, 427, 428, 427, 427, 429, 429, 430, 430, 431,
431, 431, 432, 431, 431, 433, 433, 433, 434, 434,
435, 435, 436, 435, 435, 437, 437, 438, 438, 440,
439, 441, 442, 443, 441, 441, 441, 441, 441, 441,
441, 441, 441, 441, 441, 441, 441, 441, 441, 441,
441, 441, 441, 441, 441, 441, 444, 441, 445, 445,
445, 445, 445, 445, 446, 445, 447, 445, 448, 445,
449, 445, 450, 445, 445, 445, 445, 451, 445, 445,
445, 445, 445, 445, 445, 445, 445, 445, 445, 452,
452, 452, 453, 453, 454, 454, 454, 454, 454, 455,
455, 456, 456, 457, 457, 457, 458, 458, 458, 459,
459, 459, 460, 460, 461, 461, 461, 462, 462, 463,
463, 464, 464, 464, 465, 465, 465, 465, 466, 466,
466, 467, 467, 468, 468, 468, 469, 469, 470, 470,
471, 471, 471, 471, 471, 471, 472, 472, 473, 473,
474, 474, 475, 475, 475, 475, 475, 475, 476, 476,
476, 477, 477, 478, 478, 478, 478, 478, 478, 478,
478, 478, 478, 478, 478, 478, 478, 478, 478, 478,
478, 478, 479, 479, 480, 480, 481, 481, 481, 482,
482, 482, 482, 482, 482, 482, 483, 483, 483, 484,
484, 485, 485, 485, 485, 485, 485, 485, 485, 485,
485, 486, 486, 487, 487, 487, 488, 488, 489, 489,
489, 489, 490, 490, 491, 491, 492, 492, 493, 493,
494, 494, 494, 495, 495, 496, 496, 496, 497, 497,
497, 498, 498, 499, 499, 499, 499, 499, 500, 500,
501, 501, 502, 502, 502, 503, 503, 503, 503, 503,
504, 504, 504, 505, 505, 506, 506, 506, 506, 506,
507, 506, 506, 508, 506, 506, 506, 506, 506, 509,
509, 510, 510, 510, 511, 511, 511, 511, 512, 512,
512, 513, 513, 513, 514, 514, 515, 515, 516, 516,
518, 519, 517, 517, 517, 517, 517, 517, 517, 517,
520, 520, 521, 521, 522, 523, 521, 524, 524, 524,
524, 524, 524, 524, 524, 524, 524, 524, 524, 525,
525, 526, 526, 527, 527, 528, 528, 529, 529, 529,
529, 530, 529, 529, 531, 531, 531, 532, 532, 533,
533, 533, 533, 533, 533, 533, 533, 533, 534, 534,
535, 535, 536, 536, 537, 537, 538, 538, 539, 539,
540, 540, 540, 540, 541, 541, 541, 541, 541, 541,
542, 542, 542, 542, 542, 543, 543, 543, 543, 543,
544, 544, 544, 544, 544, 544, 544, 544, 544, 544,
544, 544, 544, 544, 544, 544, 544, 544, 544, 544,
544, 544, 544, 544, 544, 544, 544, 544, 544, 544,
544, 544, 544, 544, 544, 544, 544, 544, 544, 544,
544, 544, 544, 544, 544, 544, 544, 544, 544, 544,
544, 544, 544, 544, 544, 544, 544, 545, 544, 546,
544, 544, 544, 544, 544, 544, 544, 544, 544, 544,
544, 544, 544, 544, 544, 544, 544, 544, 544, 544,
544, 544, 544, 544, 544, 544, 544, 544, 544, 544,
544, 544, 544, 544, 544, 544, 544, 544, 544, 547,
547, 547, 548, 548, 549, 549, 549, 549, 550, 550,
550, 550, 551, 551, 551, 552, 552, 553, 553, 554,
554, 554, 555, 555, 556, 556, 557, 557, 558, 558,
558, 558, 558, 559, 559, 560, 560, 560, 560, 560,
560, 561, 561, 562, 562, 562, 562, 562, 563, 563,
564, 564, 564, 564, 564, 564, 564, 564, 565, 565,
566, 566, 567, 567, 567, 567, 567, 567, 568, 568,
569, 569, 570, 570, 570, 571, 571, 571, 571, 571,
572, 572, 572, 573, 573, 574, 574, 574, 575, 575,
575, 575, 576, 576, 578, 577, 577, 577, 577, 577,
577, 579, 579, 580, 580, 581, 581, 582, 582, 582,
582, 582, 582, 582, 582, 582, 582, 582, 582, 582,
582, 582, 584, 583, 585, 586, 585, 587, 587, 587,
587, 587, 588, 587, 587, 587, 589, 589, 590, 590,
590, 590, 591, 591, 592, 592, 592, 592, 592, 592,
592, 592, 592, 592, 592, 592, 593, 593, 594, 594,
594, 594, 594, 594, 594, 594, 594, 594, 594, 594,
594, 594, 594, 594, 594, 594, 594, 594, 594, 594,
594, 594, 594, 594, 594, 594, 594, 594, 594, 594,
594, 594, 594, 594, 594, 594, 594, 594, 594, 594,
594, 594, 594, 594, 594, 594, 594, 594, 594, 594,
594, 594, 594, 594, 594, 594, 594, 594, 594, 594,
594, 594, 594, 594, 595, 595, 596, 596, 596, 596,
596, 596, 596, 596, 596, 596, 596, 596, 596, 596,
596, 596, 597, 597, 598, 598, 599, 599, 599, 599,
599, 599, 599, 599, 599, 599, 599, 599, 599, 599,
599, 599, 599, 599, 599, 599, 599, 599, 599, 599,
599, 599, 599, 599, 599, 599, 599, 599, 599, 599,
600, 600, 600, 601, 601, 602, 602, 603, 603, 604,
604, 604, 604, 604, 604, 604, 605, 605, 606, 606,
607, 607, 607, 607, 607, 607, 608, 608, 608, 608,
608, 609, 608, 610, 608, 608, 611, 608, 612, 612,
612, 613, 613, 613, 613, 613, 613, 613, 613, 613,
613, 613, 613, 613, 613, 613, 613, 613, 613, 613,
613, 613, 613, 613, 614, 614, 615, 615, 615, 615,
615, 615, 615, 615, 615, 615, 615, 615, 615, 615,
615, 615, 615, 615, 615, 615, 615, 615, 615, 615,
615, 615, 615, 615, 615, 615, 615, 615, 615, 615,
615, 615, 615, 615, 615, 615, 615, 615, 615, 615,
615, 615, 615, 615, 615, 616, 616, 616, 616, 616,
616, 616, 616, 616, 616, 616, 616, 616, 616, 616,
616, 617, 616, 616, 616, 616, 616, 616, 616, 616,
616, 616, 616, 616, 616, 616, 616, 616, 616, 616,
618, 618, 619, 619, 621, 620, 622, 622, 623, 623,
624, 624, 624, 624, 624, 624, 625, 625, 625, 625,
626, 626, 627, 627, 627, 627, 627, 627, 627, 627,
627, 627, 627, 627, 627, 627, 627, 627, 627, 627,
627, 627, 627, 627, 627, 627, 628, 628, 628, 629,
629, 629, 630, 630, 630, 630, 630, 630, 630, 630,
630, 630, 630, 630, 630, 630, 630, 630, 630, 630,
630, 630, 630, 630, 631, 630, 630, 630, 630, 630,
630, 632, 632, 633, 633, 633, 633, 633, 634, 635,
635, 636, 637, 637, 637, 637, 638, 638, 639, 639,
640, 641, 641, 641, 642, 642, 642, 643, 643, 644,
644
};
/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
static const yytype_uint8 yyr2[] =
{
0, 2, 0, 2, 0, 0, 3, 4, 4, 4,
4, 4, 4, 4, 4, 4, 4, 1, 1, 2,
0, 2, 4, 5, 0, 0, 15, 5, 1, 0,
6, 2, 1, 1, 1, 1, 1, 1, 1, 0,
4, 4, 1, 1, 3, 0, 3, 4, 1, 3,
5, 1, 3, 3, 3, 0, 1, 1, 3, 3,
0, 3, 0, 11, 6, 0, 1, 0, 2, 5,
6, 7, 0, 10, 1, 0, 3, 6, 0, 3,
4, 4, 0, 2, 3, 0, 3, 1, 3, 0,
2, 1, 0, 0, 7, 3, 3, 6, 3, 3,
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
3, 3, 4, 2, 2, 2, 0, 10, 3, 1,
3, 2, 1, 2, 0, 5, 0, 7, 0, 9,
0, 15, 0, 11, 11, 4, 4, 0, 7, 6,
2, 2, 2, 2, 3, 2, 3, 1, 1, 3,
2, 3, 1, 3, 0, 3, 6, 3, 4, 0,
2, 3, 1, 0, 2, 2, 2, 3, 4, 0,
4, 2, 0, 2, 3, 4, 3, 0, 2, 3,
1, 0, 2, 2, 2, 3, 3, 4, 0, 4,
2, 0, 2, 3, 3, 4, 0, 4, 0, 2,
3, 3, 3, 3, 3, 3, 0, 2, 3, 1,
0, 2, 2, 3, 3, 4, 5, 2, 0, 4,
2, 0, 2, 3, 3, 3, 3, 3, 3, 7,
3, 7, 11, 3, 3, 3, 3, 3, 7, 3,
7, 7, 0, 2, 3, 1, 0, 2, 2, 2,
3, 3, 4, 4, 4, 4, 0, 4, 2, 0,
2, 2, 3, 3, 4, 7, 9, 3, 3, 3,
3, 0, 20, 0, 4, 2, 0, 2, 2, 3,
3, 3, 1, 3, 0, 3, 1, 3, 0, 3,
0, 4, 2, 0, 2, 3, 3, 3, 0, 4,
2, 0, 2, 3, 3, 3, 3, 3, 0, 2,
3, 1, 0, 2, 2, 2, 3, 3, 4, 4,
0, 4, 2, 0, 2, 3, 3, 3, 3, 3,
0, 5, 3, 0, 5, 3, 3, 3, 3, 0,
3, 0, 2, 2, 4, 4, 4, 4, 0, 2,
2, 3, 3, 3, 0, 2, 3, 3, 0, 2,
0, 0, 9, 3, 3, 3, 3, 2, 5, 3,
0, 2, 3, 3, 0, 0, 9, 0, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 4,
3, 0, 2, 3, 1, 0, 2, 2, 3, 3,
4, 0, 5, 1, 0, 4, 2, 0, 2, 3,
3, 3, 3, 3, 3, 3, 3, 1, 1, 3,
0, 3, 1, 3, 0, 3, 0, 2, 0, 2,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
3, 3, 3, 4, 4, 4, 4, 6, 5, 5,
5, 5, 2, 4, 2, 4, 2, 4, 5, 4,
2, 4, 7, 10, 7, 7, 7, 7, 5, 7,
9, 5, 8, 5, 7, 9, 9, 11, 11, 13,
11, 5, 7, 5, 7, 7, 5, 17, 13, 15,
17, 25, 11, 11, 13, 21, 24, 0, 7, 0,
7, 7, 11, 5, 5, 5, 5, 7, 2, 4,
5, 7, 5, 9, 5, 8, 9, 9, 5, 5,
11, 9, 13, 13, 5, 14, 12, 10, 7, 9,
11, 7, 7, 5, 7, 9, 7, 9, 1, 1,
1, 1, 0, 2, 3, 3, 3, 2, 0, 2,
4, 6, 0, 5, 5, 0, 10, 0, 10, 0,
5, 5, 0, 11, 0, 10, 0, 2, 3, 3,
3, 3, 4, 0, 2, 3, 3, 3, 3, 3,
4, 0, 2, 3, 3, 3, 3, 4, 0, 2,
3, 3, 3, 3, 3, 4, 4, 4, 0, 4,
0, 2, 3, 3, 3, 3, 3, 3, 0, 2,
3, 1, 0, 2, 2, 2, 3, 3, 3, 4,
0, 4, 2, 0, 2, 2, 3, 4, 0, 5,
5, 2, 0, 2, 0, 6, 3, 3, 3, 3,
3, 0, 2, 3, 1, 0, 2, 2, 3, 3,
3, 3, 3, 3, 2, 3, 3, 3, 3, 9,
4, 1, 0, 9, 0, 0, 3, 7, 7, 8,
11, 6, 0, 10, 5, 1, 3, 6, 1, 1,
1, 1, 0, 3, 1, 2, 2, 12, 2, 15,
4, 12, 17, 22, 12, 7, 0, 2, 3, 4,
4, 3, 3, 2, 2, 3, 3, 3, 2, 2,
3, 2, 3, 3, 3, 3, 3, 3, 7, 3,
3, 3, 3, 3, 3, 5, 2, 2, 2, 3,
9, 3, 2, 9, 2, 9, 2, 9, 5, 4,
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
3, 2, 3, 2, 3, 3, 3, 3, 3, 2,
3, 3, 6, 3, 1, 1, 6, 8, 8, 10,
1, 2, 2, 1, 3, 6, 4, 4, 1, 1,
5, 1, 1, 1, 1, 1, 5, 5, 5, 2,
7, 7, 3, 5, 3, 4, 6, 7, 8, 8,
5, 7, 5, 7, 4, 8, 9, 10, 5, 7,
3, 3, 7, 9, 5, 5, 5, 8, 7, 2,
3, 5, 5, 0, 2, 0, 1, 1, 3, 2,
1, 4, 2, 2, 2, 2, 0, 2, 1, 3,
2, 2, 2, 2, 2, 2, 0, 3, 6, 5,
8, 0, 9, 0, 11, 5, 0, 9, 0, 3,
3, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 3, 2, 2,
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 3, 3, 3, 3, 3, 4, 4,
4, 4, 4, 4, 4, 4, 4, 4, 6, 4,
4, 4, 4, 4, 4, 4, 4, 6, 6, 6,
4, 5, 1, 1, 2, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 0, 6, 1, 3, 6, 4, 6, 1, 4,
6, 4, 3, 4, 4, 6, 6, 5, 7, 4,
0, 2, 0, 2, 0, 7, 1, 3, 1, 1,
2, 1, 1, 3, 4, 5, 1, 1, 3, 3,
3, 5, 2, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 5, 4, 3, 6, 5, 4, 4,
6, 6, 6, 8, 8, 4, 5, 5, 8, 1,
1, 4, 1, 4, 1, 4, 4, 4, 4, 8,
8, 6, 4, 6, 1, 4, 1, 1, 1, 1,
4, 4, 1, 4, 0, 6, 4, 6, 5, 7,
4, 2, 4, 1, 1, 4, 3, 6, 4, 1,
1, 3, 1, 1, 3, 3, 1, 1, 1, 1,
4, 6, 4, 6, 3, 4, 6, 1, 2, 0,
3
};
/* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state
STATE-NUM when YYTABLE doesn't specify something else to do. Zero
means the default is an error. */
static const yytype_uint16 yydefact[] =
{
2, 0, 4, 1, 5, 0, 1029, 792, 793, 0,
0, 0, 0, 780, 0, 0, 788, 789, 0, 783,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 1089, 6, 17, 18, 0, 791, 0, 1030, 0,
0, 0, 0, 829, 0, 0, 0, 0, 0, 781,
1032, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 1049, 0, 0, 1052, 1048, 1044,
1046, 1047, 0, 782, 1034, 0, 774, 775, 0, 1076,
1077, 0, 1064, 986, 1063, 19, 856, 868, 1089, 0,
0, 20, 78, 206, 159, 177, 242, 67, 308, 391,
0, 0, 0, 0, 618, 0, 651, 0, 0, 0,
0, 799, 0, 0, 0, 0, 0, 0, 0, 0,
0, 946, 945, 0, 0, 0, 0, 0, 0, 0,
0, 960, 0, 0, 0, 947, 952, 953, 948, 949,
950, 951, 958, 957, 959, 954, 955, 956, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 896, 963, 968, 942,
943, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 784, 0, 0, 0, 0, 0, 65, 65, 984,
0, 0, 0, 65, 0, 0, 0, 0, 0, 0,
0, 0, 804, 0, 802, 0, 1087, 0, 0, 0,
821, 820, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 991, 968, 0, 992, 0, 0, 0, 0,
0, 996, 0, 997, 0, 0, 0, 0, 1031, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 898, 899, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 944, 0, 0,
0, 786, 787, 1064, 1073, 1072, 0, 0, 0, 0,
0, 0, 0, 0, 0, 982, 1054, 0, 0, 0,
0, 0, 0, 0, 0, 0, 1078, 1079, 0, 0,
988, 989, 1066, 987, 0, 66, 0, 0, 0, 0,
0, 0, 0, 7, 21, 28, 0, 0, 0, 210,
9, 207, 209, 163, 10, 160, 162, 181, 11, 178,
180, 246, 12, 243, 245, 0, 8, 68, 74, 0,
312, 13, 309, 311, 395, 14, 392, 394, 0, 0,
622, 15, 619, 621, 1088, 1090, 655, 16, 652, 654,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 898, 1002, 990, 0, 0, 0, 0, 0, 0,
805, 0, 0, 0, 0, 0, 814, 0, 0, 0,
0, 0, 0, 0, 0, 1026, 825, 0, 826, 0,
0, 0, 0, 0, 1084, 0, 0, 0, 986, 0,
980, 961, 0, 972, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 897, 0,
0, 0, 0, 915, 914, 913, 912, 908, 909, 916,
917, 911, 910, 901, 900, 902, 905, 906, 903, 904,
907, 0, 964, 0, 0, 0, 0, 1038, 1080, 0,
1042, 0, 0, 1035, 1036, 1037, 1033, 0, 0, 0,
846, 1061, 0, 1060, 0, 1056, 1050, 1051, 1045, 1053,
0, 790, 1065, 0, 796, 857, 797, 870, 869, 835,
0, 0, 60, 0, 0, 798, 79, 0, 0, 0,
0, 75, 0, 0, 0, 824, 803, 0, 0, 672,
0, 818, 794, 795, 0, 1027, 1029, 34, 35, 0,
32, 0, 0, 33, 0, 0, 0, 986, 0, 986,
0, 0, 0, 0, 993, 1012, 0, 902, 1003, 905,
1005, 1015, 0, 964, 1008, 1009, 1004, 1010, 1006, 1011,
1007, 810, 812, 0, 0, 0, 0, 0, 0, 0,
998, 999, 0, 0, 0, 0, 0, 1082, 1085, 0,
0, 974, 0, 979, 0, 0, 0, 833, 971, 0,
966, 918, 919, 920, 921, 922, 923, 924, 925, 926,
927, 0, 929, 930, 931, 932, 933, 934, 935, 936,
0, 0, 0, 940, 969, 0, 0, 776, 0, 973,
0, 0, 1000, 1066, 1075, 1074, 0, 0, 0, 982,
983, 1058, 0, 0, 0, 0, 785, 0, 0, 0,
0, 840, 0, 0, 0, 836, 837, 0, 0, 65,
0, 0, 0, 0, 0, 0, 0, 208, 211, 0,
0, 0, 161, 164, 165, 0, 0, 82, 0, 179,
182, 183, 0, 0, 0, 0, 0, 0, 0, 244,
247, 248, 0, 65, 0, 72, 1029, 0, 0, 0,
310, 313, 314, 0, 0, 0, 0, 401, 393, 396,
403, 0, 0, 0, 0, 0, 620, 623, 624, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 653, 656, 671, 0, 0, 0, 0, 48,
0, 45, 0, 31, 43, 51, 1014, 0, 0, 1019,
1018, 0, 0, 0, 0, 1025, 994, 0, 0, 0,
0, 1077, 0, 806, 0, 0, 0, 0, 0, 0,
0, 828, 0, 0, 0, 0, 0, 0, 980, 981,
977, 0, 0, 0, 0, 0, 0, 0, 0, 0,
941, 0, 0, 0, 1043, 0, 0, 1041, 0, 0,
0, 0, 847, 848, 1055, 1062, 1057, 1067, 0, 859,
865, 0, 0, 0, 0, 839, 842, 843, 845, 844,
985, 0, 800, 801, 0, 0, 0, 51, 22, 0,
0, 218, 0, 0, 217, 212, 169, 0, 166, 188,
0, 0, 0, 0, 89, 0, 184, 298, 0, 0,
256, 273, 290, 249, 0, 0, 82, 0, 0, 341,
0, 0, 320, 315, 0, 0, 404, 0, 397, 0,
630, 0, 0, 625, 0, 0, 674, 0, 0, 0,
664, 0, 0, 0, 0, 0, 0, 657, 674, 822,
0, 819, 0, 0, 0, 65, 0, 38, 29, 37,
0, 0, 0, 0, 0, 1013, 995, 0, 1017, 0,
0, 0, 1070, 1069, 0, 811, 813, 807, 0, 0,
827, 1028, 1081, 1083, 1086, 975, 976, 0, 834, 962,
967, 928, 937, 938, 939, 970, 777, 965, 0, 778,
1001, 0, 0, 1059, 850, 851, 855, 854, 853, 852,
0, 861, 866, 0, 858, 0, 0, 996, 997, 838,
27, 61, 24, 23, 218, 0, 214, 213, 0, 167,
0, 0, 0, 0, 186, 83, 0, 185, 0, 251,
250, 0, 0, 0, 69, 76, 0, 82, 0, 0,
317, 316, 0, 398, 399, 0, 426, 626, 0, 627,
628, 658, 659, 675, 660, 0, 661, 665, 662, 663,
668, 667, 666, 675, 0, 49, 52, 53, 44, 0,
54, 39, 1020, 1022, 1021, 0, 0, 1016, 815, 0,
0, 0, 808, 809, 978, 0, 1039, 1040, 849, 833,
846, 0, 0, 841, 0, 0, 0, 0, 0, 0,
0, 221, 215, 220, 172, 168, 171, 191, 187, 190,
0, 0, 84, 1029, 871, 872, 873, 874, 875, 876,
877, 878, 879, 880, 881, 882, 883, 884, 885, 886,
887, 888, 889, 890, 891, 892, 893, 0, 137, 0,
0, 0, 0, 124, 126, 128, 130, 0, 0, 0,
0, 0, 0, 0, 0, 90, 91, 122, 894, 0,
119, 986, 147, 148, 301, 255, 300, 259, 252, 258,
276, 253, 275, 293, 254, 292, 0, 70, 0, 0,
0, 0, 0, 0, 319, 342, 343, 323, 318, 322,
407, 400, 406, 0, 633, 629, 632, 670, 0, 0,
673, 823, 0, 0, 46, 65, 0, 0, 1071, 816,
0, 779, 0, 0, 860, 863, 1068, 0, 830, 0,
62, 0, 0, 216, 0, 0, 0, 80, 81, 121,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 114, 113, 115, 0, 1029, 0, 145, 968,
143, 142, 141, 140, 92, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 123, 154, 0, 0, 0, 0,
0, 71, 0, 358, 358, 370, 348, 0, 0, 1029,
0, 0, 82, 82, 0, 0, 0, 0, 440, 441,
442, 443, 444, 446, 448, 447, 449, 0, 0, 0,
0, 0, 0, 0, 445, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
430, 432, 431, 433, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 434,
435, 436, 437, 438, 439, 0, 0, 0, 507, 509,
402, 0, 0, 0, 0, 427, 548, 0, 0, 0,
0, 0, 0, 676, 685, 0, 50, 47, 30, 0,
1023, 1024, 817, 862, 867, 833, 0, 0, 0, 64,
25, 0, 0, 0, 0, 0, 82, 0, 82, 82,
82, 0, 0, 0, 82, 219, 222, 0, 82, 0,
170, 173, 0, 0, 0, 189, 192, 0, 89, 0,
0, 132, 895, 0, 89, 89, 89, 89, 0, 0,
118, 0, 390, 0, 0, 0, 0, 111, 110, 109,
108, 107, 103, 104, 106, 105, 99, 100, 95, 98,
101, 96, 102, 144, 146, 150, 0, 152, 0, 0,
120, 0, 0, 0, 0, 299, 302, 0, 0, 0,
0, 85, 85, 0, 0, 257, 260, 0, 0, 0,
0, 274, 277, 0, 0, 0, 0, 291, 294, 77,
82, 377, 377, 377, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 333, 321, 324, 0, 0, 0,
0, 0, 0, 0, 0, 405, 408, 417, 0, 0,
82, 82, 82, 0, 82, 0, 82, 0, 0, 0,
0, 0, 0, 0, 0, 0, 470, 0, 0, 82,
0, 0, 0, 0, 0, 0, 0, 576, 0, 583,
0, 0, 0, 591, 0, 0, 598, 462, 0, 464,
0, 466, 0, 0, 0, 82, 0, 0, 0, 518,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 631, 634, 0, 0,
0, 0, 0, 0, 0, 42, 0, 0, 0, 831,
832, 55, 0, 0, 0, 0, 0, 0, 82, 0,
0, 82, 0, 82, 0, 0, 0, 0, 0, 82,
0, 0, 0, 154, 196, 0, 0, 135, 0, 136,
0, 0, 154, 0, 0, 0, 0, 89, 0, 389,
964, 112, 0, 149, 151, 0, 0, 0, 0, 0,
0, 36, 0, 0, 0, 0, 0, 0, 271, 0,
82, 0, 0, 0, 0, 261, 0, 286, 288, 0,
282, 284, 0, 278, 0, 0, 0, 0, 0, 0,
0, 82, 0, 378, 379, 380, 381, 382, 383, 384,
385, 386, 387, 388, 0, 0, 344, 359, 0, 345,
0, 0, 346, 371, 0, 0, 0, 354, 347, 349,
350, 0, 0, 0, 0, 0, 0, 330, 0, 0,
0, 0, 89, 0, 0, 420, 0, 418, 0, 0,
0, 424, 0, 422, 0, 428, 450, 0, 0, 0,
451, 0, 452, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 87, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 85, 85, 0, 0, 0, 0, 0, 638, 0,
635, 0, 692, 0, 0, 682, 706, 0, 0, 41,
40, 864, 57, 56, 0, 0, 224, 225, 226, 233,
234, 0, 237, 239, 0, 236, 0, 228, 227, 0,
65, 230, 223, 0, 235, 174, 176, 0, 0, 193,
194, 0, 0, 89, 0, 125, 0, 0, 0, 0,
0, 0, 93, 153, 0, 0, 155, 157, 303, 305,
304, 306, 307, 262, 263, 0, 0, 65, 0, 267,
268, 269, 270, 279, 65, 281, 65, 280, 296, 295,
297, 73, 0, 0, 0, 0, 0, 0, 367, 360,
0, 0, 374, 0, 0, 0, 337, 336, 328, 326,
327, 325, 339, 332, 338, 335, 329, 0, 410, 409,
65, 411, 412, 415, 416, 65, 413, 414, 0, 0,
0, 0, 0, 0, 0, 82, 0, 0, 0, 0,
0, 0, 0, 82, 0, 0, 471, 0, 0, 0,
82, 0, 0, 0, 0, 0, 0, 0, 0, 0,
82, 0, 0, 82, 453, 577, 0, 0, 82, 0,
0, 0, 0, 454, 584, 0, 0, 0, 0, 0,
0, 0, 82, 455, 592, 82, 0, 0, 0, 0,
0, 0, 0, 0, 0, 456, 599, 463, 465, 467,
0, 469, 0, 82, 0, 0, 519, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 551, 549, 552, 550, 552,
0, 0, 0, 0, 0, 0, 0, 0, 636, 694,
0, 0, 0, 0, 0, 0, 0, 0, 706, 0,
0, 82, 706, 0, 0, 0, 0, 846, 0, 0,
82, 82, 82, 0, 0, 82, 175, 198, 195, 0,
97, 0, 0, 0, 0, 0, 139, 116, 0, 0,
158, 0, 264, 0, 86, 287, 0, 283, 0, 0,
364, 365, 369, 366, 363, 89, 373, 372, 89, 351,
352, 0, 0, 353, 355, 0, 0, 0, 419, 0,
423, 0, 429, 0, 426, 426, 458, 459, 460, 0,
0, 0, 0, 0, 0, 0, 478, 0, 481, 0,
483, 0, 491, 88, 0, 493, 0, 0, 496, 0,
543, 0, 426, 0, 0, 0, 0, 0, 426, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 426,
0, 0, 0, 0, 0, 0, 0, 426, 426, 0,
0, 608, 468, 461, 0, 514, 515, 520, 0, 522,
0, 0, 0, 0, 0, 524, 428, 528, 529, 0,
0, 534, 0, 0, 513, 0, 0, 516, 0, 0,
0, 0, 0, 0, 0, 1029, 0, 637, 641, 695,
696, 82, 698, 0, 0, 0, 0, 0, 0, 0,
690, 691, 688, 689, 686, 0, 0, 706, 0, 0,
0, 0, 707, 684, 669, 0, 59, 58, 0, 0,
0, 0, 65, 0, 0, 0, 138, 0, 0, 127,
0, 0, 0, 94, 0, 0, 65, 289, 285, 0,
361, 375, 0, 0, 0, 331, 334, 421, 425, 457,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 82, 0, 580, 578,
579, 581, 82, 0, 587, 585, 586, 588, 589, 0,
0, 82, 596, 594, 0, 593, 595, 569, 0, 603,
602, 604, 0, 0, 600, 601, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 553, 0, 0, 0, 0, 0, 0,
0, 0, 642, 642, 0, 0, 0, 0, 0, 0,
0, 0, 693, 692, 0, 0, 0, 0, 681, 0,
0, 0, 0, 719, 0, 0, 0, 0, 0, 721,
0, 0, 718, 0, 0, 0, 0, 713, 714, 0,
0, 0, 736, 737, 738, 85, 742, 744, 746, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 761, 763, 0, 0, 0, 82, 0, 0,
769, 0, 0, 0, 63, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 197, 199,
0, 0, 0, 0, 0, 156, 0, 0, 0, 368,
0, 0, 356, 357, 340, 472, 474, 475, 0, 0,
0, 0, 0, 0, 479, 0, 484, 492, 494, 495,
542, 0, 582, 0, 590, 0, 0, 0, 597, 0,
0, 606, 607, 610, 605, 511, 0, 521, 476, 477,
0, 0, 0, 0, 0, 0, 0, 538, 0, 0,
508, 0, 0, 0, 557, 510, 517, 541, 0, 0,
544, 546, 0, 377, 377, 0, 82, 0, 700, 0,
0, 0, 677, 0, 0, 0, 678, 706, 773, 733,
724, 739, 82, 730, 0, 0, 708, 712, 725, 726,
716, 717, 722, 723, 720, 715, 732, 731, 0, 734,
741, 0, 0, 0, 0, 750, 0, 759, 760, 755,
756, 757, 758, 751, 752, 753, 754, 762, 764, 727,
729, 0, 765, 766, 768, 770, 771, 711, 767, 0,
241, 240, 229, 0, 231, 238, 0, 0, 0, 0,
0, 0, 0, 0, 129, 0, 0, 0, 265, 0,
89, 0, 426, 0, 0, 0, 0, 0, 0, 0,
82, 0, 82, 0, 0, 0, 0, 0, 0, 0,
0, 82, 0, 0, 0, 525, 0, 0, 0, 82,
0, 0, 0, 554, 555, 556, 0, 0, 482, 0,
0, 0, 0, 0, 640, 0, 643, 639, 0, 0,
0, 0, 0, 0, 687, 706, 679, 0, 0, 709,
710, 0, 0, 0, 0, 0, 749, 0, 0, 26,
0, 200, 201, 202, 203, 204, 205, 0, 0, 0,
117, 0, 0, 0, 0, 0, 485, 486, 0, 0,
0, 0, 480, 0, 0, 0, 0, 426, 0, 572,
574, 426, 0, 0, 0, 0, 82, 0, 0, 609,
611, 0, 523, 526, 527, 0, 0, 531, 0, 0,
0, 539, 0, 547, 545, 0, 0, 0, 0, 0,
644, 0, 82, 0, 0, 0, 0, 0, 0, 82,
735, 0, 0, 0, 748, 0, 0, 0, 133, 134,
0, 0, 266, 0, 0, 473, 0, 0, 82, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 537, 0, 0, 648, 649, 650, 646, 647, 89,
705, 0, 0, 0, 0, 0, 0, 0, 683, 0,
0, 0, 0, 0, 772, 0, 0, 0, 362, 376,
487, 488, 0, 490, 0, 426, 0, 0, 0, 503,
426, 0, 570, 0, 571, 502, 0, 617, 612, 615,
616, 613, 614, 512, 426, 426, 530, 0, 0, 540,
0, 0, 0, 0, 0, 0, 0, 680, 82, 0,
0, 0, 728, 232, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 536, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 489, 0, 498, 426, 0, 0, 504,
0, 0, 0, 532, 533, 0, 645, 0, 0, 0,
0, 0, 0, 740, 743, 745, 747, 131, 0, 0,
0, 0, 0, 0, 0, 0, 535, 0, 0, 0,
0, 0, 0, 0, 0, 499, 0, 0, 0, 0,
0, 704, 0, 697, 701, 0, 0, 0, 0, 0,
562, 0, 0, 0, 0, 0, 0, 0, 497, 500,
558, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 699, 0, 0, 0, 565,
567, 559, 0, 0, 575, 426, 0, 0, 0, 0,
0, 0, 426, 573, 0, 702, 0, 0, 0, 563,
0, 564, 560, 0, 505, 0, 0, 0, 0, 0,
0, 426, 0, 272, 0, 0, 561, 426, 0, 0,
0, 0, 0, 506, 0, 0, 0, 501, 703, 0,
0, 0, 0, 0, 0, 566, 568
};
/* YYDEFGOTO[NTERM-NUM]. */
static const yytype_int16 yydefgoto[] =
{
-1, 1, 2, 4, 5, 42, 222, 374, 1099, 1622,
590, 1071, 591, 592, 948, 1205, 1617, 793, 945, 794,
1844, 709, 1398, 366, 228, 397, 908, 743, 223, 1775,
894, 2046, 1776, 1025, 1026, 1155, 1446, 2098, 2272, 1156,
1236, 1237, 1238, 1239, 1651, 1231, 1274, 1468, 1470, 225,
385, 568, 723, 1018, 1225, 1421, 226, 389, 569, 730,
1020, 1226, 1426, 1868, 2265, 2449, 224, 381, 567, 718,
1015, 1224, 1416, 227, 393, 570, 740, 1031, 1277, 1486,
1896, 1032, 1278, 1492, 1692, 1906, 1689, 1904, 1033, 1279,
1498, 1028, 1276, 1476, 229, 402, 573, 751, 1042, 1287,
1516, 1932, 1742, 2126, 1039, 1185, 1504, 1729, 1925, 2124,
1501, 1717, 2115, 2460, 1503, 1723, 2118, 2461, 1718, 1157,
230, 406, 574, 759, 917, 1045, 1288, 1526, 1746, 1940,
1752, 1945, 1193, 1949, 1371, 1372, 1373, 1374, 1375, 1598,
1599, 2047, 2215, 2353, 2971, 2960, 2989, 2990, 2489, 2777,
2778, 1784, 1985, 1786, 1994, 1790, 2004, 1793, 2016, 2336,
2630, 2720, 235, 412, 577, 767, 1048, 1377, 1607, 2057,
2523, 2656, 2799, 238, 418, 578, 783, 43, 786, 1053,
1198, 1383, 2073, 1831, 2245, 2070, 2068, 2074, 2252, 85,
1376, 45, 584, 46, 1006, 832, 704, 705, 706, 693,
852, 853, 217, 1089, 1395, 1090, 218, 1158, 1159, 252,
186, 647, 646, 539, 187, 369, 188, 362, 254, 434,
334, 255, 48, 93, 94, 540, 349, 335, 867, 961,
962, 336, 91, 358, 84, 189, 190, 237, 117
};
/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
STATE-NUM. */
#define YYPACT_NINF -2059
static const yytype_int16 yypact[] =
{
-2059, 109, -2059, -2059, 131, 15863, -305, -2059, -2059, 98,
178, -194, 43, -2059, -180, -177, -2059, -2059, 14583, -2059,
14322, -121, 376, 14322, -85, -74, 237, 376, 376, -41,
-10, -2, 30, 71, 87, 113, 125, 173, 70, 100,
193, -88, -2059, -2059, -2059, 1, -2059, 489, 218, -79,
246, 237, 237, -2059, 14322, 9110, 362, 9110, 9110, -2059,
-2059, 376, 376, 376, 376, 376, 253, 268, 288, 303,
286, 320, 376, 376, -2059, 376, 376, -2059, -2059, 376,
-2059, -2059, 376, -2059, -2059, 536, -2059, -2059, 9110, -2059,
-2059, 14322, 106, 711, -2059, -2059, -2059, -2059, 341, 14322,
14322, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
14322, 732, 237, 828, -2059, 607, -2059, 237, 868, 878,
3571, -2059, 534, 5957, 414, 430, 7505, 9110, 507, -251,
531, -2059, -2059, 376, 376, 376, 547, 608, 376, 376,
376, -2059, 623, 376, 376, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, 627, 637,
655, 656, 672, 694, 706, 718, 727, 743, 771, 783,
787, 796, 797, 803, 824, 832, 837, 839, 840, 842,
843, 9110, 9110, 9110, 237, 6368, -2059, -2059, 249, -2059,
-2059, 665, 11905, 12775, 14322, 14322, 14322, 9110, 14322, 14322,
14322, 14322, 237, 237, 3571, 22, 14322, 14322, 14322, 14322,
14322, -2059, 13645, 356, 9110, 48, 237, -140, -120, -2059,
690, 767, 9672, -63, 9962, 10017, 10257, 10542, 10832, 11122,
11177, 793, -2059, 844, -2059, 11417, 9110, 845, 11702, 946,
-2059, -2059, -3, 9110, 848, 849, 850, 851, 852, 853,
7639, 7756, 7245, 281, 1242, 676, 1259, 7863, 7863, 8216,
-25, 9062, -7, 676, 17542, 49, 1260, 9110, 870, 14322,
14322, 14322, 26, 237, 237, 14322, 237, 9110, 129, 14322,
9110, 9110, 9110, 9110, 9110, 9110, 9110, 9110, 9110, 9110,
9110, 9110, 9110, 9110, 9110, 9110, 9110, 9110, 9110, 9110,
9110, 9110, 9110, -67, -67, 17574, 328, 9110, 9110, 9110,
9110, 9110, 9110, 9110, 9110, 9110, 9110, 9110, 9110, 9110,
9110, 9110, 9110, 9110, 9110, 9110, 9110, -2059, 9110, 48,
9110, -2059, -2059, 494, -2059, -2059, 13, 13, 301, 10531,
867, 876, 877, 879, 880, -14, -2059, 9110, 1265, 356,
357, 356, 356, 356, 356, 14322, -2059, -2059, 1270, 17602,
-2059, -2059, 886, -2059, 1273, -2059, 237, 1274, 14322, 887,
9110, 14322, 890, -2059, -2059, -2059, 343, 1280, 237, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, 893, -2059, -2059, -2059, 324,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, 1282, 1283,
-2059, -2059, -2059, -2059, 19726, -2059, -2059, -2059, -2059, -2059,
237, 8216, 34, 17630, 23, 7992, 8216, 9110, 9110, 14322,
8216, -67, 899, -2059, 130, 9110, 8106, 8216, 8326, 48,
-2059, 8216, 8216, 8216, 8216, 9110, -2059, 1285, 1287, 5203,
926, 927, 8216, 144, 8216, -2059, -2059, 9110, -2059, 17662,
900, 894, 895, 356, -2059, 905, 898, 66, 94, 356,
6, 19726, 356, -2059, 392, 17694, 17722, 17750, 17778, 17806,
17834, 17862, 17890, 17918, 17946, 11117, 17974, 18002, 18030, 18058,
18086, 18114, 18142, 18170, 11987, 12271, 12857, 18198, -2059, 910,
48, 6156, 9377, 3457, 2582, 776, 776, 696, 696, 696,
696, 696, 696, 504, 504, 284, 284, 284, -67, -67,
-67, 18226, 914, 9956, 3245, 48, 14322, -2059, -2059, 8216,
-2059, 14322, 9110, -2059, -2059, -2059, -2059, 48, 14322, 915,
904, 19726, 909, -2059, 14322, -2059, -2059, -2059, -2059, -2059,
1306, -2059, -2059, 9110, -2059, -82, -2059, -2059, -2059, 118,
17514, 356, -2059, 5846, 945, -2059, -2059, 146, 15544, 15300,
9344, -2059, 154, 15367, 15109, -2059, -2059, 15240, 14869, -2059,
398, -2059, -2059, -2059, 14322, -2059, 285, -2059, -2059, 32,
-2059, 919, 923, -2059, 8216, 9062, 499, 78, 444, -1,
13141, 13727, 924, 240, -2059, 10241, 8216, 284, 899, 284,
899, -2059, 8216, 928, 148, 148, 1262, 899, 1262, 899,
2735, -2059, -2059, 427, 1312, 7040, 7863, 7863, 953, 954,
9062, 676, 18254, 1317, 9110, 14322, 14322, -2059, -2059, 9110,
48, -2059, 930, -2059, 48, 9110, 356, 925, -2059, 9110,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, 9110, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
9110, 9110, 9110, -2059, -2059, 937, 9110, -2059, 9110, -2059,
9110, 9110, -2059, 938, -2059, -2059, 398, 929, 2211, 932,
-2059, -2059, 252, 936, 9110, 356, -2059, 18282, 6580, 940,
9110, 6398, 7863, 3571, 941, 934, -2059, 1332, 1333, 77,
947, 32, 1336, 7286, 11, 1342, 237, -2059, 11742, 1341,
955, 237, -2059, -2059, -2059, 1344, 956, 59, 237, -2059,
-2059, -2059, 1347, 959, 1352, 237, 961, 962, 963, -2059,
-2059, -2059, 1355, 142, 996, 970, 500, 1362, 237, 971,
-2059, -2059, -2059, 1364, 237, 9110, 975, -2059, -2059, -2059,
-2059, 1366, 237, 977, 237, 237, -2059, -2059, -2059, 1369,
237, 9110, 980, 237, 984, 1375, 4069, 7863, 7863, 9110,
9110, 9110, -2059, -2059, -2059, 1374, 985, 36, 1388, 1394,
8216, -2059, 8216, -2059, -2059, -2059, -2059, 72, 368, -2059,
-2059, 8216, 237, 9110, 9110, -2059, -2059, 9110, 452, 528,
8440, 1010, 14293, -2059, 376, 1402, 1403, 1404, 7863, 7863,
1406, -2059, 18310, 356, 356, 18342, 356, 356, 1020, 19726,
-2059, 118, 1037, 17514, 18370, 18398, 18426, 18454, 1041, 18482,
19726, 18510, 6190, 8550, -2059, 14322, 9110, -2059, 1042, 6797,
3571, 3571, 1038, -2059, -2059, 19726, -2059, -2059, 5957, 19726,
-2059, 1074, 18538, 376, 7756, -2059, -2059, -2059, -2059, -2059,
-2059, 118, -2059, -2059, 1437, 237, 99, 328, -2059, 1439,
1050, -2059, 1441, 1445, -2059, -2059, -2059, 1446, -2059, -2059,
1061, 1062, 1077, 1455, -2059, 1456, -2059, -2059, 1458, 1460,
-2059, -2059, -2059, -2059, 1461, 237, 59, 1101, 1067, -2059,
1467, 1468, -2059, -2059, 1481, 532, -2059, 1092, -2059, 1486,
-2059, 1487, 1488, -2059, 1489, 1298, -2059, 1490, 9110, 1491,
-2059, 1348, 1495, 1498, 1767, 2147, 2296, -2059, -2059, -2059,
14322, -2059, 1505, 6322, 480, 555, 425, -2059, -2059, -2059,
1113, 691, 1114, 14321, 14580, 19726, -2059, 1117, -2059, 1508,
14322, 356, -2059, 1108, 14293, -2059, -2059, -2059, 1509, 1515,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, 356, 934, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, 9110, -2059,
-2059, 356, 17514, -2059, 19726, -2059, -2059, -2059, -2059, -2059,
252, -2059, -2059, 1127, -2059, 14293, 577, 6538, 395, -2059,
-2059, -253, -2059, -2059, -2059, 11992, -2059, -2059, 12047, -2059,
12287, 9110, 1520, 1142, -2059, -2059, 3637, -2059, 12572, -2059,
-2059, 12862, 12917, 13157, -2059, 1130, 1522, 59, 23, 15489,
-2059, -2059, 13442, -2059, -2059, 13732, -2059, -2059, 13787, -2059,
-2059, -2059, -2059, 1132, -2059, 15079, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, 1133, 1534, 1536, -2059, -2059, -2059, 92,
-2059, -2059, -2059, -2059, -2059, 9110, 9110, -2059, -2059, 601,
1535, 356, -2059, -2059, -2059, 18570, -2059, -2059, -2059, 925,
904, 7398, 356, -2059, 9110, 14322, 237, 1153, 9110, 1147,
14027, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
18602, 1156, -2059, 579, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, 1158, -2059, 1172,
1173, 1174, 1177, -2059, -2059, -2059, -2059, 127, 3637, 3637,
3637, 3637, 270, 9110, 242, 3583, 699, 1178, -2059, 1178,
-2059, 124, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, 9110, -2059, 1567, 1179,
1180, 1181, 1197, 1204, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, 9304, -2059, -2059, -2059, -2059, 4935, 9110,
-2059, -2059, 1573, 99, -2059, 153, 18630, 18658, -2059, -2059,
1595, -2059, 1205, 1209, -2059, -2059, -2059, 11035, -2059, 1216,
-2059, 18686, 32, -2059, 449, 60, 139, -2059, -2059, -2059,
1213, 1222, 1213, 3637, 6199, 6199, 1223, 1232, 1235, 1251,
1272, 1252, 1261, 1261, 1261, 1045, 62, 1254, 230, 530,
-2059, -2059, -2059, 1286, -2059, 3637, 3637, 3637, 3637, 3637,
3637, 3637, 3637, 3637, 3637, 3637, 3637, 3637, 3637, 3637,
3637, 9110, 9110, 3409, -2059, 1264, 524, 212, 191, 54,
18718, -2059, 1288, -2059, -2059, -2059, -2059, 643, 6116, 95,
1263, 1269, 88, 136, 1271, 1276, 1290, 1293, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, 1296, 1297, 1303,
1305, 1307, 1309, 61, -2059, 1311, 1313, 1315, 1316, 1318,
1319, 1320, 1322, 742, 753, 1340, 1343, 800, 1346, 1350,
1268, 64, 69, 76, 1351, 1353, 1356, 1358, 1360, 825,
-2059, -2059, -2059, -2059, 91, 1361, 1363, 1367, 1368, 1370,
1372, 1373, 1376, 1377, 1378, 1380, 1383, 1384, 1385, -2059,
-2059, -2059, -2059, -2059, -2059, 1386, 1387, 1393, -2059, -2059,
-2059, 1395, 1396, 1397, 1400, -2059, -2059, 2, 1401, 1405,
1407, 1408, 1409, -2059, -2059, 15341, -2059, -2059, -2059, 158,
-2059, -2059, -2059, -2059, -2059, 925, 14322, 1299, 1304, -2059,
-2059, 23, 23, 23, 23, 23, 140, 9110, 152, 161,
59, 1310, 237, 1651, 167, -2059, -2059, 23, 59, 237,
-2059, -2059, 1345, 1662, 1707, -2059, -2059, 1365, -2059, 1410,
2987, -2059, -2059, 1178, -2059, -2059, -2059, -2059, 1412, 3637,
-2059, 1349, -2059, 8668, 48, 3637, 3637, 563, 1239, 1100,
1100, 1100, 748, 748, 748, 748, 459, 459, 1261, 1261,
1261, 1261, 1261, 230, 230, -2059, 1415, 3583, 156, 4513,
-2059, 237, 135, 1738, 237, -2059, -2059, 237, 237, 1752,
1392, 1411, 1411, 23, 23, -2059, -2059, 1757, 1764, 21,
37, -2059, -2059, 1763, 1778, 237, 237, -2059, -2059, -2059,
59, 197, 473, 786, 7187, 237, 1793, 120, 237, 237,
9110, 1796, 23, 7863, -2059, -2059, -2059, 1800, 237, 101,
14322, 7863, 14322, 108, 237, -2059, -2059, -2059, 237, 1794,
59, 59, 59, 1811, 59, 1812, 59, 237, 237, 237,
237, 237, 237, 237, 237, 237, -2059, 1425, 237, 59,
237, 237, 237, 237, 237, 14322, 9110, -2059, 9110, -2059,
237, 9110, 9110, -2059, 9110, 14322, -2059, -2059, 1426, -2059,
1427, -2059, 1428, 7863, 1429, 59, 23, 14322, 14322, -2059,
1431, 14322, 14322, 14322, 237, 237, 237, 237, 237, 237,
237, 237, 237, 237, 237, 237, 237, 237, 1433, 1434,
14322, 237, 14322, 237, 1436, 237, -2059, -2059, 1823, 237,
175, 23, 14322, 14322, 9110, -2059, 237, 32, 1438, -2059,
-2059, 1220, 1430, 1824, 1828, 1830, 1831, 1832, 59, 1833,
2548, 59, 1834, 59, 1835, 1836, 2346, 1840, 1841, 59,
1843, 1844, 1845, 1264, -2059, 1846, 1847, -2059, 1451, -2059,
3637, 1462, 1264, 1465, 1452, 1459, 1463, -2059, 4477, -2059,
1471, 3583, 829, -2059, -2059, 3637, 1473, 237, 604, 1472,
1862, -2059, 1864, 1865, 1866, 1867, 1868, 1869, 1480, 1873,
59, 1878, 1879, 1880, 1881, -2059, 1883, -2059, -2059, 1884,
-2059, -2059, 1885, -2059, 1887, 1888, 1890, 1891, 1485, 23,
237, 59, 237, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, 23, 1893, -2059, -2059, 1507, -2059,
1898, 23, -2059, -2059, 1510, 1899, 237, -2059, -2059, -2059,
-2059, 1900, 1901, 1903, 1904, 1908, 1909, -2059, 2787, 1910,
1911, 1912, -2059, 1914, 1915, -2059, 1917, -2059, 1918, 1920,
1921, -2059, 1923, -2059, 1924, 1502, -2059, 1537, 1538, 1539,
-2059, 1540, -2059, 1541, 1528, 1542, 1543, 1544, 1545, 1546,
1549, 162, 192, 1931, 216, -2059, 241, 1551, 318, 1553,
1548, 1554, 1563, 15396, 468, 15569, 460, 1557, 15658, 15693,
150, 15728, 1559, 543, 1932, 1933, 1934, 1569, 1935, 1571,
1564, 1574, 1576, 1962, 1577, 1570, 1580, 1578, 1579, 1581,
1582, 1583, 331, 1584, 1588, 1601, 1604, 1613, 1606, 1607,
1617, 112, 112, 351, 1621, -178, 1625, 1626, -2059, 1970,
-2059, 1079, 1637, 1629, 1079, -2059, -2059, 1640, 18750, -2059,
-2059, -2059, -2059, -2059, 621, 32, -2059, -2059, -2059, -2059,
-2059, 1636, -2059, -2059, 1638, -2059, 1639, -2059, -2059, 9110,
1642, -2059, -2059, 1644, -2059, -2059, -2059, 2034, -170, -2059,
-2059, 23, 4974, -2059, 1648, -2059, 2048, 9110, 9110, 1657,
1677, 8775, -2059, 3583, 23, 1660, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, 1894, 2052, 1642, 631, -2059,
-2059, -2059, -2059, -2059, 632, -2059, 649, -2059, -2059, -2059,
-2059, -2059, 2057, 2055, 2059, 2060, 2061, 2062, -2059, -2059,
2063, 2064, -2059, 2066, 2067, 18, -2059, -2059, -2059, -2059,
-2059, -2059, 1681, -2059, -2059, -2059, -2059, 1684, -2059, -2059,
650, -2059, -2059, -2059, -2059, 666, -2059, -2059, 9110, 1686,
1680, 1687, 2076, 2078, 2079, 59, 237, 237, 9110, 9110,
9110, 237, 2080, 59, 2081, 23, -2059, 2082, 9110, 2083,
59, 9110, 2085, 9110, 9110, 2087, 237, 2088, 9110, 1699,
59, 9110, 9110, 59, -2059, -2059, 9110, 1700, 59, 9110,
9110, 9110, 9110, -2059, -2059, 9110, 9110, 9110, 9110, 9110,
1701, 9110, 59, -2059, -2059, 59, 14322, 9110, 9110, 237,
1702, 1703, 9110, 9110, 1705, -2059, -2059, -2059, -2059, -2059,
2096, -2059, 2097, 59, 2098, 2099, -2059, 2100, 14322, 2101,
7863, 7863, 7863, 9110, 7863, 2102, 23, 2104, 2105, 237,
237, 2106, 23, 237, 2107, -2059, -2059, -2059, -2059, -2059,
2108, 9110, 23, 1722, 14322, 237, 1716, 9226, -2059, -2059,
23, 23, 79, 1725, 1728, 1730, 1731, 1732, -2059, 23,
63, 137, -2059, 1715, 352, 2123, 2124, 904, 1221, 1729,
59, 59, 59, 18778, 2409, 59, -2059, -2059, -2059, 1736,
-2059, 1739, 1737, 1740, 15764, 15799, -2059, -2059, 3637, 1761,
-2059, 2153, -2059, 2155, -2059, -2059, 2156, -2059, 2157, 1768,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, 1213, 23, -2059, -2059, 237, 2158, 2159, -2059, 237,
-2059, 237, 19726, 2163, -2059, -2059, -2059, -2059, -2059, 1775,
1759, 1769, 15834, 15869, 15904, 1771, -2059, 1780, -2059, 1773,
-2059, 18806, -2059, -2059, 18834, -2059, 18862, 18890, -2059, 1787,
-2059, 15939, -2059, 2177, 3387, 3532, 2178, 15974, -2059, 2179,
3609, 3810, 3854, 3882, 16009, 16044, 16079, 3937, 3969, -2059,
4041, 2180, 1784, 1785, 4121, 4303, 2183, -2059, -2059, 4454,
4547, -2059, -2059, -2059, 371, -2059, -2059, -2059, 1795, -2059,
1798, 1799, 1788, 16114, 1792, -2059, 1502, -2059, -2059, 1797,
1801, -2059, 1805, 386, -2059, 402, 428, -2059, 18918, 1802,
1808, 1804, 1806, 1807, 237, 834, 1803, -2059, -2059, 1902,
-2059, 59, -2059, 1818, 8216, 1820, 1839, 1842, 429, 1825,
-2059, -2059, -2059, -2059, -2059, 2199, 1838, -2059, 456, 2029,
2220, 15505, -2059, -2059, -2059, 1849, -2059, -2059, 9110, 1852,
1854, 1855, 1642, 1856, 1859, 89, -2059, 1860, 9110, -2059,
9110, 9110, 1848, 3583, 1861, 2221, 667, -2059, -2059, 2222,
-2059, -2059, 2225, 2227, 1870, -2059, -2059, -2059, -2059, -2059,
9594, 9884, 2230, 7863, 9110, 7863, 9110, 9110, 237, 2233,
237, 2234, 2250, 2251, 2254, 2256, 59, 10174, -2059, -2059,
-2059, -2059, 59, 10464, -2059, -2059, -2059, -2059, -2059, 9110,
9110, 59, -2059, -2059, 10754, -2059, -2059, -2059, 9110, -2059,
-2059, -2059, 11044, 11334, -2059, -2059, 53, 2258, 9110, 2261,
2262, 2263, 9110, 14322, 14322, 1875, 9110, 9110, 14322, 2266,
8885, 2270, 6933, -2059, 2271, 2272, 2280, 237, 1895, 2281,
2283, 1896, -2059, -2059, 2286, 1892, 8216, 688, 8216, 8216,
8216, 2287, -2059, 1637, 14322, 465, 2290, 23, -2059, 14322,
7863, 14322, 7863, -2059, 1907, 2293, 2201, 9110, 9110, -2059,
7863, 9110, -2059, 9110, 9110, 14322, 2294, -2059, 9110, 9110,
2295, 9003, -2059, -2059, -2059, 1411, 1913, 1916, 1919, 1925,
9110, 1905, 9110, 9110, 9110, 9110, 9110, 9110, 9110, 9110,
9110, 9110, 9110, 9110, 7863, 7863, 1926, 59, 14322, 9110,
9110, 14322, 9110, 14322, -2059, 18946, 2298, 2299, 2302, 1927,
2304, 2305, 2312, 9110, 9110, 9110, 9110, 9110, -2059, -2059,
1928, 16149, 18974, 16184, 3637, -2059, 2133, 2311, 2316, -2059,
1922, 1929, -2059, -2059, -2059, 1937, -2059, -2059, 1936, 19002,
1938, 16219, 16254, 1939, -2059, 1940, -2059, -2059, -2059, -2059,
-2059, 1941, -2059, 1942, -2059, 16289, 16324, 556, -2059, -156,
16359, -2059, -2059, -2059, -2059, -2059, 16394, -2059, -2059, -2059,
19030, 1943, 1945, 2317, 16429, 16464, 578, -2059, 14322, 4418,
-2059, 14322, 7863, 14322, -2059, -2059, -2059, -2059, 1948, 1951,
-2059, -2059, 2322, 1379, 1837, 1956, 59, 692, -2059, 695,
700, 714, -2059, 1950, 1959, 2323, -2059, -2059, -2059, -2059,
-2059, -2059, 59, -2059, 14322, 14322, -2059, 19726, 19726, -2059,
19726, 19726, 19726, -2059, -2059, 19726, 19726, -2059, 8216, 19726,
-2059, 9110, 9110, 9110, 8216, 19726, 237, 19726, 19726, 19726,
19726, 19726, 19726, 19726, 19726, 19726, 19726, 19726, 19726, -2059,
-2059, 9110, -2059, -2059, 19726, 19726, 1961, 19726, -2059, 2328,
-2059, -2059, -2059, 9110, -2059, -2059, 2331, 4637, 5100, 5236,
5429, 5698, 9110, 9110, -2059, 9110, 5452, 237, -2059, 1963,
-2059, 1213, -2059, 2352, 2353, 9110, 9110, 9110, 9110, 2355,
59, 9110, 59, 9110, 1966, 9110, 1967, 1968, 1971, 9110,
527, 59, 2360, 2362, 2363, -2059, 9110, 9110, 2364, 59,
610, 2367, 23, -2059, -2059, -2059, 2369, 2371, -2059, 23,
237, 237, 2374, 23, -2059, 1985, -2059, -2059, 9110, 1977,
1987, 1989, 1990, 1991, -2059, -2059, -2059, 613, 1978, -2059,
-2059, 716, 16499, 16534, 16569, 717, -2059, 16604, 8216, -2059,
19058, -2059, -2059, -2059, -2059, -2059, -2059, 19086, 19118, 16639,
-2059, 1992, 2383, 1998, 1999, 11624, -2059, -2059, 19150, 5179,
19178, 16674, -2059, 2001, 16709, 1995, 16744, -2059, 19206, -2059,
-2059, -2059, 16779, 2395, 2396, 9110, 59, 2397, 23, -2059,
-2059, 2008, -2059, -2059, -2059, 19234, 19262, -2059, 2009, 2400,
9110, -2059, 2013, -2059, -2059, 2418, 2419, 2420, 2421, 2422,
-2059, 2505, 59, 8216, 8216, 8216, 8216, 616, 2426, 59,
-2059, 9110, 9110, 9110, -2059, 9110, 719, 2037, -2059, -2059,
9110, 9110, -2059, 2429, 2430, -2059, 2434, 2436, 59, 2437,
7863, 2049, 9110, 7863, 9110, 11914, 2050, 406, 421, 12204,
9110, 2438, 2441, 5726, 2443, 2444, 2445, 2446, 2065, 2068,
2450, -2059, 6891, 2451, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, 9110, 2069, 738, 765, 772, 777, 2453, -2059, 2071,
16814, 16849, 16884, 19290, -2059, 2454, 16919, 19322, -2059, -2059,
-2059, -2059, 2070, -2059, 2072, -2059, 19354, 2073, 16954, -2059,
-2059, 237, -2059, 237, -2059, -2059, 16989, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, 2456, 23, -2059,
2092, 19382, 2075, 2093, 2091, 2094, 2095, -2059, 59, 9110,
9110, 9110, -2059, -2059, 9110, 2461, 2489, 9110, 12494, 2103,
7863, 14322, 12784, 2112, 2116, 7863, 13074, 13364, -2059, 2109,
2494, 2110, 7863, 8216, 2111, 8216, 8216, 2136, 19414, 19446,
19478, 19510, 2384, -2059, 17024, -2059, -2059, 2134, 2137, -2059,
9110, 9110, 2138, -2059, -2059, 2496, -2059, 9110, 2139, 781,
9110, 782, 785, -2059, -2059, -2059, -2059, -2059, 23, 9110,
13654, 7863, 7863, 17059, 17094, 7863, -2059, 19538, 7863, 2142,
19570, 2146, 2140, 2497, 19602, -2059, 2113, 2141, 9110, 9110,
2143, -2059, 2145, -2059, -2059, 2149, 8216, 2313, 2543, 2544,
-2059, 17129, 17164, 7863, 7863, 9110, 792, 237, -2059, -2059,
-146, 2547, 2551, 2162, 2164, 17199, 2165, 2160, 2171, 2172,
9110, 2174, 2554, 2173, 2176, -2059, 9110, 2207, 9110, -2059,
-2059, 17234, 2212, 2210, -2059, -2059, 19630, 9110, 19662, 441,
560, 9110, -2059, -2059, 13944, -2059, 17269, 2546, 237, -2059,
237, -2059, 17304, 14234, 2213, 9110, 2216, 2170, 2219, 9110,
2228, -2059, 17339, -2059, 9110, 9110, 19726, -2059, 14524, 9110,
17374, 17409, 14814, -2059, 19694, 9110, 9110, -2059, -2059, 17444,
17479, 2555, 2572, 2218, 2231, -2059, -2059
};
/* YYPGOTO[NTERM-NUM]. */
static const yytype_int16 yypgoto[] =
{
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-448, -2059, -276, 1145, -2059, -2059, 1159, -796, -2059, -838,
-2059, -2059, -2059, -201, -2059, -2059, -2059, -2059, -2059, -677,
-2059, -1477, 951, -1416, -2059, -1091, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -1071, -2059, -1303, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
1612, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
1354, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -1478, -1110,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -818, 433, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, 812, 587, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
-2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059,
277, -2059, -2059, -2059, -2059, -2059, -2059, -2059, -2059, 1709,
-2059, -2059, -2059, 1031, -2059, 280, 809, -2058, -2059, 2300,
881, -2059, 1871, -2059, -2059, -1056, -2059, 1826, 1783, -1077,
-2059, 1656, -2059, -2059, -2059, -2059, -2059, -2059, -255, 2772,
-272, -2059, 1858, 1972, 24, -2059, 3851, -293, -172, -94,
2166, -124, -2059, -5, -9, -2059, -2059, 232, 1810, 1698,
-795, -171, 17, 2161, -2059, -634, 733, -504, 2566
};
/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
positive, shift that token. If negative, reduce the rule which
number is the opposite. If zero, do what YYDEFACT says.
If YYTABLE_NINF, syntax error. */
#define YYTABLE_NINF -896
static const yytype_int16 yytable[] =
{
49, 949, 263, 1229, 1681, 1682, 6, 56, 216, 83,
2238, 87, 1648, 1213, 2248, 86, 880, 368, 1653, 1654,
1655, 1656, 378, 2121, 337, 1724, 1687, 6, 586, 47,
11, 6, 262, 1212, 113, 789, 522, 6, 1012, 2626,
119, 581, 1690, 939, 99, 100, 128, 129, 6, 2968,
893, 11, 11, 360, 997, 11, 456, 1242, 1243, 1244,
1245, 11, 120, 719, 725, 732, 742, 6, 1546, 753,
761, 1567, 11, 769, 785, 789, 1569, 6, 194, 195,
196, 197, 198, 1571, 586, 447, 448, 216, 1275, 205,
206, 11, 207, 208, 50, 789, 209, 6, 1579, 210,
6, 11, 789, 216, 6, 6, 6, 233, 11, 3,
890, 242, 239, 6, 256, 712, 1097, 6, 2045, 236,
1427, 11, 1429, 701, 11, 1733, 432, 263, 11, 11,
11, -3, 1240, 216, 6, 432, 1604, 11, 2627, 890,
1671, 11, 1430, 587, 1098, 266, 613, 2246, 2969, 588,
269, 270, 271, 267, 1605, 274, 275, 276, 11, 586,
278, 279, 111, 1615, 1447, 1448, 1449, 1450, 1451, 1452,
1453, 1454, 1455, 1456, 1457, 1458, 1459, 1460, 1461, 1462,
6, 1833, 1467, 11, 1241, 53, 1417, 890, 890, 2375,
361, 890, 947, 1418, 1998, 346, 1494, 344, 1419, 587,
348, 54, 1698, 890, 11, 588, 1495, 675, 1496, 2122,
1092, 363, 890, 57, 891, 2053, 58, 376, 890, 49,
49, 49, 49, 399, 49, 49, 2054, 2087, 2088, 1036,
49, 1204, 683, 49, 2442, 2443, 2444, 2445, 2446, 2447,
2628, 1879, 6, 891, 689, 1250, 47, 6, 47, 47,
47, 47, 47, 47, 47, 95, 364, 849, 2970, 47,
702, 588, 47, 236, 365, 879, 11, 465, 466, 468,
703, 11, 88, 472, 587, 1246, 367, 624, 1422, 1616,
588, 1423, 1424, 1734, 365, 714, 130, 698, 715, 850,
123, 891, 891, 1735, 1999, 891, 745, 263, 716, 11,
1672, 596, 598, 124, 125, 115, 263, 891, 236, 116,
96, 699, 608, 610, 126, 700, 891, 614, 615, 617,
619, 97, 891, 213, 1699, 326, 1937, 580, 608, 236,
631, 220, 221, 377, 327, 1700, 603, 1701, 1702, 1618,
1867, 365, 231, 1488, 449, 1489, 87, 826, 1658, 1874,
86, 828, 2000, 1490, 1661, 1662, 101, 450, 451, 558,
1178, 555, 1652, 557, 1477, 1387, 1478, 1479, 1480, 1481,
1482, 1483, 1484, 566, 1703, 1704, 1705, 1706, 1707, 1708,
1709, 1710, 1711, 1712, 1713, 102, 537, 453, 1714, 1715,
538, 356, 1162, 357, 89, 103, 90, 454, 2001, 2002,
1606, 421, 118, 802, 851, 263, 644, 356, 881, 357,
645, 582, 583, 582, 583, 579, 2123, 526, 1688, 593,
597, 599, 464, 347, 589, 790, 1400, 104, 338, 791,
340, 341, 342, 343, 1691, 686, 55, 792, 350, 351,
352, 353, 354, 892, 457, 2240, 2241, 2242, 2243, 1251,
2493, 2494, 1497, 815, 816, 817, 1547, 2091, 1420, 1568,
356, 50, 357, 110, 1570, 790, 640, 2244, 105, 791,
263, 1572, 892, 874, 800, 1203, 2231, 792, 1698, 2667,
589, 365, 263, 1532, 106, 790, 1580, 2448, 263, 642,
1528, 51, 790, 52, 50, 112, 121, 792, 1745, 214,
798, 461, 462, 463, 792, 1751, 215, 469, 875, 1680,
107, 474, 808, 627, 1162, 1162, 1162, 1162, 809, -895,
892, 892, 108, 356, 892, 357, 628, 629, 604, 865,
868, 1534, 443, 444, 454, 1628, 892, 1425, 904, 1044,
445, 447, 905, 211, 717, 892, 365, 1631, 2003, 1388,
744, 892, 1664, 191, 256, 589, 1633, 365, 1962, 1872,
1665, 1252, 1639, 49, 49, 49, 1963, 593, 49, 49,
109, 2713, 49, 49, 1883, 1401, 1402, 1403, 1404, 1405,
1406, 1407, 1408, 1409, 1410, 1411, 1412, 2007, 1964, 1491,
114, 1413, 47, 47, 47, 1716, 1965, 47, 47, 1162,
1699, 47, 47, 561, 1414, 932, 933, 2747, 315, 316,
1485, 1700, 1967, 1701, 1702, 1533, 1535, 122, 324, 325,
1968, 1162, 1162, 1162, 1162, 1162, 1162, 1162, 1162, 1162,
1162, 1162, 1162, 1162, 1162, 1162, 1162, 1969, 806, 1162,
812, 963, 328, 127, 454, 1970, 968, 969, 199, 329,
1703, 1704, 1705, 1706, 1707, 1708, 1709, 1710, 1711, 1712,
1713, 602, 1987, 200, 1714, 1715, 944, 1988, 946, 2714,
1979, 2715, 324, 325, 438, 1980, 326, 951, 1471, 203,
-36, 439, 2716, 201, 50, 327, 1001, 2008, 1472, 860,
1473, 1474, 866, 123, 869, 356, 2717, 357, 202, 2280,
1989, 1990, 2281, 1991, 1992, 529, 124, 125, 1981, 1982,
1983, 883, 563, 49, 1972, 204, 887, 126, 2718, 572,
216, 499, 1973, 895, 236, 564, 125, 2035, 500, 1629,
899, 1632, 1634, 1635, 115, 2036, 126, 1640, 2009, 232,
1008, 1642, 47, 911, 1069, 2010, 2011, 2050, 2250, 914,
356, 356, 357, 357, 1160, 2051, 2251, 919, 685, 921,
922, 544, 1179, 687, 1096, 924, 950, 2337, 927, 89,
690, 90, 454, 1487, 1493, 2338, 695, 441, 442, 443,
444, 1505, 2349, 257, 1506, 1507, 356, 445, 357, 1079,
2350, 2012, 356, 963, 357, 1508, 649, 952, 2351, 258,
2013, 2014, 454, 2831, 2832, 1162, 2352, 441, 442, 443,
444, 1162, 1162, 1509, 1510, 1511, 788, 445, 2833, 2834,
89, 1840, 811, 1697, 2354, 2371, 441, 442, 443, 444,
1070, 964, 2352, 2251, 1512, 234, 445, 1882, 2998, 2999,
995, 998, 999, 1266, 1267, 1268, 1269, 1415, 801, 1002,
956, 1270, 2376, 1757, 1758, 1759, 454, 1761, 1993, 1763,
2251, 2535, 441, 442, 443, 444, 1984, 823, 824, 2251,
1011, 1719, 445, 1608, 1067, 240, 1160, 1160, 1160, 1160,
1005, 441, 442, 443, 444, 241, 44, 524, 321, 322,
323, 445, 324, 325, 525, 799, 326, 909, 1799, 50,
1035, 265, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 1215,
324, 325, 1475, 1443, 326, 2719, 957, 268, 2560, 1720,
1444, 243, 454, 327, 1513, 1256, 1257, 1258, 1259, 1260,
1261, 2015, 272, 1262, 1263, 1264, 1265, 1266, 1267, 1268,
1269, 1851, 2624, 1068, 1854, 1270, 1856, 3000, 3001, 365,
2625, 1160, 1863, 1703, 1704, 1705, 1706, 1707, 1708, 1709,
1710, 1711, 1712, 1713, 2638, 1093, 1152, 1721, 50, 1431,
1433, 1094, 2639, 1160, 1160, 1160, 1160, 1160, 1160, 1160,
1160, 1160, 1160, 1160, 1160, 1160, 1160, 1160, 1160, 1208,
2255, 1160, 1886, 273, 1389, 526, 2729, 2273, 454, 2748,
49, 2282, 2807, 49, 2730, 49, 1162, 2251, 277, 2077,
2251, 1161, 280, 49, 1915, 2078, 49, 49, 49, 2104,
2105, 1162, 281, 593, 49, 1970, 365, 49, 1514, 47,
49, 1515, 47, 49, 47, 2655, 2655, 2107, 2128, 2079,
282, 283, 47, 365, 365, 47, 47, 47, 441, 442,
443, 444, 330, 47, 2130, 2457, 47, 284, 445, 47,
365, 365, 47, 441, 442, 443, 444, 991, 319, 320,
321, 322, 323, 445, 324, 325, 2528, 1073, 326, 285,
2660, 1219, 454, 2661, 370, 49, 454, 327, 2662, 454,
1271, 286, 1272, 375, 454, 382, 386, 390, 394, 398,
403, 407, 2663, 287, 2750, 2754, 413, 2814, 454, 419,
454, 454, 288, 454, 47, 1623, 1624, 1625, 1626, 1627,
1264, 1265, 1266, 1267, 1268, 1269, 2853, 1556, 289, 1557,
1270, 1641, 454, 1161, 1161, 1161, 1161, 1247, 1558, 1253,
1559, 1660, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 2854, 324, 325, 290, 1160, 326, 454,
2855, 371, 1064, 1160, 1160, 2856, 454, 327, 291, 2929,
2931, 454, 292, 2932, 1722, 454, 454, 408, 49, 454,
2966, 293, 294, 49, 2693, 1562, 454, 1563, 295, 1254,
1255, 1256, 1257, 1258, 1259, 1260, 1261, 1683, 1684, 1262,
1263, 1264, 1265, 1266, 1267, 1268, 1269, 47, 110, 296,
1578, 1270, 47, 1842, 2256, 1843, 2257, 297, 1161, 1432,
1432, 2362, 298, 50, 299, 300, 1740, 301, 302, 415,
409, 1441, 420, 424, 425, 426, 427, 428, 429, 440,
1161, 1161, 1161, 1161, 1161, 1161, 1161, 1161, 1161, 1161,
1161, 1161, 1161, 1161, 1161, 1161, 446, 458, 1161, 460,
435, 532, 533, 534, 542, 535, 536, 551, 2139, 553,
554, 556, 559, 49, 1529, 562, 2147, 565, 571, 575,
576, 445, 621, 2153, 622, 625, 626, 634, 635, 636,
1800, 638, 639, 2163, 674, 1052, 2166, 680, 692, 691,
694, 2169, 47, 696, 713, 796, 2290, 2291, 797, 813,
805, 810, 818, 819, 821, 2181, 827, 1218, 2182, 831,
838, 843, 854, 845, 861, 1835, 538, 870, 871, 872,
873, 1741, 876, 878, 2307, 263, 2194, 882, 885, 1749,
2313, 888, 886, 889, 896, 1057, 897, 898, 900, 901,
902, 2324, 903, 2606, 1860, 906, 907, 910, 912, 2332,
2333, 913, 916, 918, 920, 1668, 923, 926, 1160, 928,
929, 937, 938, 2850, 2059, 2060, 2061, 2062, 2063, 2064,
2065, 2066, 2067, 1160, 2247, 941, 593, 593, 593, 593,
593, 1797, 942, 2259, 2260, 2261, 959, 1637, 2264, 965,
966, 967, 593, 970, 1643, 1254, 1255, 1256, 1257, 1258,
1259, 1260, 1261, 1913, 645, 1262, 1263, 1264, 1265, 1266,
1267, 1268, 1269, 979, 1161, 985, 993, 1270, 1917, 1440,
1161, 1161, 1000, 1003, 1010, 1921, 1013, 1014, 1016, 724,
731, 741, 1017, 1019, 752, 760, 1021, 1022, 768, 784,
1669, 1023, 1024, 1027, 1162, 1029, 1670, 1030, 1034, 1675,
1037, 1038, 1676, 1677, 1040, 1041, 1260, 1261, 593, 593,
1262, 1263, 1264, 1265, 1266, 1267, 1268, 1269, 1043, 1046,
1695, 1696, 1270, 1047, 1049, 1050, 1051, 1054, 1056, 49,
1731, 2694, 1058, 1736, 1737, 1059, 2649, 593, 1065, 1072,
1074, 1077, 526, 1744, 1747, 1078, 1082, 2650, 1753, 1754,
2651, 2652, 1083, 1755, 1091, 1111, 1112, 1176, 47, 1177,
1197, 1200, 1764, 1765, 1766, 1767, 1768, 1769, 1770, 1771,
1772, 1201, 1209, 1774, 1202, 1777, 1778, 1779, 1780, 1781,
1220, 1222, 1228, 1230, 2365, 1787, 1703, 1704, 1705, 1706,
1707, 1708, 1709, 1710, 1711, 1712, 1713, 1232, 1233, 1234,
2653, 593, 1235, 1273, 1281, 1282, 1386, 1283, 1284, 1807,
1808, 1809, 1810, 1811, 1812, 1813, 1814, 1815, 1816, 1817,
1818, 1819, 1820, 1826, 1285, 2089, 1824, 1825, 1827, 884,
1829, 1286, 1392, 1393, 1832, 1832, 593, 1394, 2099, 1397,
1152, 1839, 1257, 1258, 1259, 1260, 1261, 1428, 1434, 1262,
1263, 1264, 1265, 1266, 1267, 1268, 1269, 1435, 1619, 2481,
1436, 1270, 308, 309, 310, 2483, 311, 312, 313, 314,
315, 316, 317, 318, 2487, 1161, 1437, 1439, 323, 1438,
324, 325, 1442, 1270, 326, 1445, 1638, 1500, 1530, 2084,
1161, 1469, 1885, 327, 1531, 1566, 1536, 1645, 308, 309,
310, 1537, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 1538, 324, 325, 1539, 2149,
326, 1540, 1541, 1620, 593, 1914, 2103, 1916, 1542, 327,
1543, 1621, 1544, 2106, 1545, 2108, 1548, 1636, 1549, 593,
1550, 1551, 1646, 1552, 1553, 1554, 593, 1555, 308, 309,
310, 1924, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 1560, 324, 325, 1561, 2129,
326, 1564, 1644, 1615, 2131, 1565, 1573, 1659, 1574, 327,
2582, 1575, 1748, 1576, 1750, 1577, 1581, 1678, 1582, 1163,
2206, 1647, 1583, 1584, 1685, 1585, 2212, 1586, 1587, 1686,
1693, 1588, 1589, 1590, 1060, 1591, 2219, 2654, 1592, 1593,
1594, 1595, 1596, 1694, 2229, 2230, 2232, 1782, 1597, 1679,
1600, 1601, 1602, 2239, 2695, 1603, 1609, 1792, 1732, 1739,
1610, 1756, 1611, 1612, 1613, 1743, 1649, 1657, 1680, 1801,
1802, 1663, 2263, 1804, 1805, 1806, 2048, 2048, 1760, 1762,
1162, 1773, 1794, 1795, 1796, 1798, 1160, 1803, 1821, 1822,
1830, 1846, 1823, 1828, 1845, 1847, 1841, 1848, 1849, 1850,
1852, 1855, 1857, 1858, 1836, 1837, 2283, 1861, 1862, 2659,
1864, 1865, 1866, 1869, 1870, 1871, 1876, 1873, 2200, 2201,
2202, 1875, 2204, 1877, 1881, 2668, 593, 1878, 1884, 1888,
1887, 1889, 1890, 1891, 1892, 1893, 1894, 1895, 1897, 593,
1912, 1163, 1163, 1163, 1163, 1899, 1900, 1901, 1902, 2775,
1903, 1905, 1907, 2779, 1908, 1909, 1103, 1910, 1911, 1106,
1918, 1109, 1919, 1920, 1923, 1922, 1948, 1926, 1927, 1166,
1928, 1929, 1169, 1172, 1175, 1930, 1931, 1934, 1935, 1936,
1186, 1938, 1939, 1189, 1941, 1942, 1192, 1943, 1944, 1196,
1946, 1947, 1955, 1950, 1951, 1952, 1953, 1954, 1966, 2017,
2018, 2019, 2021, 2703, 1975, 2705, 1956, 1957, 1958, 1959,
1960, 2140, 2141, 1961, 2721, 1971, 2145, 1974, 1976, 1977,
593, 1995, 2728, 2006, 2649, 2020, 1163, 2022, 2023, 2026,
2024, 2159, 2025, 2027, 2028, 2650, 2029, 2058, 2651, 2652,
2037, 1103, 2030, 2031, 2038, 2032, 2033, 2034, 1163, 1163,
1163, 1163, 1163, 1163, 1163, 1163, 1163, 1163, 1163, 1163,
1163, 1163, 1163, 1163, 2186, 2039, 1163, 2868, 2040, 2041,
2042, 2043, 2872, 2044, 1703, 1704, 1705, 1706, 1707, 1708,
1709, 1710, 1711, 1712, 1713, 2052, 2876, 2877, 2653, 2055,
2056, 593, 2069, 2071, 2209, 2210, 2075, 593, 2213, 2784,
2080, 2086, 2081, 2082, 2092, 2222, 365, 593, 2085, 2221,
2223, 2093, 49, 2096, 2097, 593, 593, 593, 2100, 2102,
2109, 2439, 2110, 2101, 593, 2802, 2111, 2112, 2113, 2114,
2116, 2117, 2809, 2119, 2120, 2458, 2125, 2134, 2920, 1384,
2127, 47, 2133, 2136, 2135, 2137, 2138, 2146, 2148, 2150,
2152, 2822, 2155, 1161, 2158, 2160, 2162, 2168, 2179, 2187,
2188, 2537, 2191, 2192, 2193, 2195, 2196, 2197, 2199, 2205,
263, 2207, 2208, 2211, 2214, 2217, 2220, 593, 2224, 2249,
2284, 2468, 2233, 2470, 2287, 2234, 2288, 2235, 2236, 2237,
2253, 2254, 2266, 2258, 2268, 2267, 2269, 308, 309, 310,
2367, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 1061, 324, 325, 2274, 2275, 326,
2276, 2277, 2278, 2293, 2279, 2285, 2286, 2994, 327, 1527,
2289, 2292, 1163, 2294, 3003, 2298, 2299, 2300, 1163, 1163,
2514, 2887, 1160, 2305, 2308, 2311, 2314, 2326, 2327, 2328,
2331, 2339, 2342, 3018, 2340, 2341, 2344, 2358, 2356, 3022,
2363, 2346, 2359, 2360, 2373, 2347, 6, 60, 2539, 2348,
2541, 61, 2357, 62, 63, 2366, 2364, 2368, 2549, 2361,
2377, 2372, 64, 65, 66, 67, 68, 2378, 2456, 2459,
11, 69, 2462, 2374, 2463, 2657, 2369, 2467, 2183, 2370,
2474, 2476, 263, 2454, 263, 263, 263, 2434, 2436, 70,
2437, 2438, 2579, 2580, 2440, 2441, 2450, 2477, 2478, 2455,
2198, 2479, 71, 2480, 72, 2495, 2464, 73, 2497, 2498,
2499, 2503, 2527, 2507, 2529, 2530, 2531, 2510, 2515, 2516,
74, 75, 76, 77, 78, 49, 49, 2517, 2520, 2519,
2521, 2525, 2522, 2473, 2532, 2475, 2526, 2536, 2543, 2554,
2557, 2607, 49, 1062, 2542, 2590, 2591, 2566, 49, 2592,
2561, 2594, 2595, 2562, 47, 47, 2563, 2596, 2608, 49,
2593, 2609, 2564, 2581, 2635, 2602, 2610, 49, 49, 2648,
2666, 47, 2613, 2611, 2612, 2679, 2619, 47, 2681, 2633,
2644, 2634, 2615, 2618, 2646, 2620, 2621, 2647, 47, 131,
132, 6, 2518, 2658, 2664, 2665, 47, 47, 2678, 2696,
2697, 2692, 2702, 2707, 2709, 2710, 2732, 2722, 2711, 2723,
2724, 2727, 593, 2735, 2731, 11, 2733, 2739, 2734, 2738,
2740, 2742, 2749, 1163, 2743, 1730, 2744, 2745, 2746, 2761,
2762, 138, 139, 140, 2763, 2764, 141, 2771, 1163, 2773,
2781, 2782, 2785, 422, 2787, 2790, 142, 2791, 26, 2793,
143, 144, 131, 132, 6, 145, 146, 147, 148, 149,
150, 151, 152, 153, 154, 2794, 2795, 2796, 2797, 2798,
155, 156, 157, 2808, 263, 2815, 2818, 2819, 11, 473,
263, 2820, 2786, 2821, 2823, 2837, 2825, 2830, 2838, 1161,
2840, 2841, 2842, 2843, 138, 139, 140, 2846, 2849, 141,
2857, 2863, 2844, 2878, 2671, 2845, 2866, 2852, 2892, 142,
2675, 26, 2882, 143, 144, 2858, 2867, 2870, 145, 146,
147, 148, 149, 150, 151, 152, 153, 154, 2880, 2884,
2883, 2885, 2886, 155, 156, 157, 2893, 527, 528, 530,
2896, 2906, 2918, 2926, 2947, 2905, 2957, 2907, 2910, 2949,
543, 545, 546, 547, 548, 549, 2900, 308, 309, 310,
2901, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 2913, 324, 325, 2946, 2921, 326,
2943, 2922, 2925, 2928, 2945, 2950, 2955, 2953, 327, 2954,
2958, 2959, 2972, 3006, 263, 1853, 2973, 2978, 2974, 2983,
3033, 2676, 2975, 2977, 79, 80, 81, 82, 2979, 2980,
2982, 2984, 2879, 2985, 3014, 2501, 2502, 3034, 2544, 2545,
2506, 308, 309, 310, 2756, 311, 312, 313, 314, 315,
316, 317, 318, 319, 320, 321, 322, 323, 2824, 324,
325, 2827, 2691, 326, 2987, 356, 2534, 357, 2993, 2992,
3011, 2538, 327, 2540, 3013, 846, 3035, 1673, 2546, 263,
263, 263, 263, 3015, 637, 3017, 1100, 2553, 641, 3036,
643, 1898, 1674, 648, 2049, 650, 2216, 593, 1502, 2345,
2524, 1834, 2933, 2072, 593, 2736, 2737, 1063, 593, 2803,
2804, 2805, 2806, 2533, 1009, 550, 1088, 978, 940, 996,
2583, 848, 1081, 2586, 219, 2588, 308, 309, 310, 0,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 977, 0, 326, 0,
49, 0, 684, 0, 0, 0, 0, 327, 2897, 0,
0, 0, 0, 2902, 0, 0, 0, 0, 0, 0,
2908, 0, 0, 593, 0, 0, 0, 0, 0, 47,
0, 707, 708, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 1859,
2640, 787, 0, 2643, 0, 2645, 0, 184, 0, 2936,
2937, 0, 0, 2940, 0, 0, 2942, 0, 0, 263,
0, 263, 263, 0, 0, 0, 0, 0, 0, 0,
49, 0, 0, 0, 49, 0, 2669, 2670, 0, 0,
0, 2963, 2964, 0, 0, 0, 0, 0, 0, 2909,
0, 2911, 2912, 0, 1933, 0, 0, 0, 0, 47,
0, 0, 0, 47, 0, 0, 0, 830, 0, 0,
184, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 263, 0, 0, 0, 2873, 185, 2874, 192,
193, 1163, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 593, 0, 0, 0, 844, 0, 847,
0, 0, 2956, 0, 0, 0, 856, 0, 0, 0,
212, 0, 0, 49, 0, 0, 0, 49, 0, 0,
0, 49, 49, 0, 0, 308, 309, 310, 0, 311,
312, 313, 314, 315, 316, 317, 318, 319, 320, 321,
322, 323, 47, 324, 325, 0, 47, 326, 261, 264,
47, 47, 0, 2800, 0, 0, 327, 0, 0, 2801,
0, 0, 0, 593, 0, 49, 0, 0, 308, 309,
310, 0, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 2228, 0,
326, 0, 0, 0, 47, 0, 0, 0, 0, 327,
0, 0, 2967, 303, 304, 305, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 339,
324, 325, 0, 0, 326, 0, 0, 0, 0, 0,
0, 0, 0, 327, 972, 973, 359, 975, 976, 49,
0, 0, 0, 3007, 980, 3008, 0, 0, 49, 0,
0, 0, 0, 0, 0, 0, 0, 0, 414, 0,
0, 0, 0, 49, 0, 423, 0, 49, 47, 0,
0, 0, 431, 261, 0, 0, 0, 47, 0, 0,
0, 431, 0, 0, 0, 0, 0, 0, 0, 459,
0, 0, 47, 0, 0, 0, 47, 0, 0, 471,
0, 0, 475, 476, 477, 478, 479, 480, 481, 482,
483, 484, 485, 486, 487, 488, 489, 490, 491, 492,
493, 494, 495, 496, 497, 0, 0, 0, 0, 501,
502, 503, 504, 505, 506, 507, 508, 509, 510, 511,
512, 513, 514, 515, 516, 517, 518, 519, 520, 0,
521, 0, 523, 2898, 0, 308, 309, 310, 0, 311,
312, 313, 314, 315, 316, 317, 318, 0, 0, 541,
0, 323, 1080, 324, 325, 0, 0, 326, 0, 0,
0, 0, 0, 0, 0, 0, 327, 0, 1084, 0,
0, 0, 560, 0, 0, 0, 0, 0, 0, 0,
0, 0, 1086, 1087, 0, 0, 0, 308, 309, 310,
0, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 0, 324, 325, 0, 0, 326,
0, 0, 0, 0, 0, 0, 0, 1163, 327, 0,
0, 0, 0, 261, 0, 0, 0, 595, 595, 600,
601, 0, 261, 0, 0, 0, 0, 605, 607, 609,
521, 0, 0, 595, 595, 616, 618, 620, 0, 0,
0, 0, 0, 0, 607, 0, 630, 0, 0, 632,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 1210, 0, 0, 0, 0, 0, 131, 132,
6, 0, 0, 1216, 0, 0, 0, 0, 0, 0,
0, 0, 0, 133, 134, 135, 0, 0, 0, 0,
0, 136, 137, 0, 11, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
138, 139, 140, 0, 0, 141, 359, 0, 0, 0,
0, 261, 0, 0, 688, 142, 0, 26, 0, 143,
144, 0, 0, 0, 145, 146, 147, 148, 149, 150,
151, 152, 153, 154, 0, 697, 0, 0, 0, 155,
156, 157, 158, 159, 160, 161, 162, 163, 164, 165,
166, 167, 168, 169, 170, 171, 172, 173, 174, 175,
176, 177, 178, 179, 180, 0, 0, 1254, 1255, 1256,
1257, 1258, 1259, 1260, 1261, 0, 261, 1262, 1263, 1264,
1265, 1266, 1267, 1268, 1269, 0, 0, 0, 261, 1270,
0, 0, 0, 0, 261, 0, 0, 0, 0, 0,
0, 1650, 0, 0, 2309, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 822, 0, 0, 0,
0, 825, 131, 132, 1113, 0, 0, 829, 0, 0,
0, 833, 0, 0, 0, 0, 0, 133, 134, 135,
0, 0, 0, 834, 0, 136, 137, 0, 11, 0,
0, 0, 835, 836, 837, 0, 0, 0, 839, 0,
840, 0, 841, 842, 138, 139, 140, 0, 0, 141,
0, 0, 0, 0, 0, 0, 855, 0, 0, 142,
859, 26, 862, 143, 144, 0, 0, 0, 145, 146,
147, 148, 149, 150, 151, 152, 153, 154, 0, 0,
0, 0, 0, 155, 156, 157, 1114, 1115, 1116, 1117,
1118, 1119, 1120, 1121, 1122, 1123, 1124, 1125, 1126, 1127,
1128, 1129, 1130, 1131, 1132, 1133, 1134, 1135, 1136, 1137,
1138, 1139, 1140, 0, 1141, 1142, 0, 915, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 2310,
0, 0, 0, 925, 0, 0, 0, 0, 931, 0,
0, 934, 935, 936, 0, 0, 0, 0, 0, 0,
0, 0, 943, 0, 595, 0, 0, 0, 0, 0,
0, 0, 0, 595, 0, 953, 954, 60, 0, 955,
0, 61, 841, 62, 63, 0, 1143, 0, 0, 0,
0, 0, 64, 65, 66, 67, 68, 1144, 1145, 1146,
0, 69, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 697, 2315, 0, 992, 70,
0, 994, 0, 0, 0, 0, 0, 0, 181, 0,
0, 0, 71, 0, 72, 182, 1007, 73, 183, 682,
131, 132, 1113, 0, 0, 0, 184, 0, 0, 0,
74, 75, 76, 77, 78, 133, 134, 135, 0, 0,
0, 0, 0, 136, 137, 0, 11, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 138, 139, 140, 0, 0, 141, 0, 0,
0, 0, 0, 0, 0, 0, 0, 142, 0, 26,
1055, 143, 144, 0, 0, 0, 145, 146, 147, 148,
149, 150, 151, 152, 153, 154, 0, 0, 0, 0,
0, 155, 156, 157, 1114, 1115, 1116, 1117, 1118, 1119,
1120, 1121, 1122, 1123, 1124, 1125, 1126, 1127, 1128, 1129,
1130, 1131, 1132, 1133, 1134, 1135, 1136, 1137, 1138, 1139,
1140, 0, 1141, 1142, 0, 0, 0, 308, 309, 310,
1085, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 0, 324, 325, 0, 0, 326,
0, 0, 0, 0, 0, 1147, 0, 0, 327, 0,
0, 1148, 1149, 1110, 0, 0, 0, 0, 0, 1150,
0, 0, 1151, 0, 0, 1465, 1152, 0, 0, 1466,
1153, 1154, 0, 0, 1143, 0, 0, 2316, 0, 0,
0, 0, 0, 0, 0, 1144, 1145, 1146, 0, 310,
0, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 0, 324, 325, 1206, 1207, 326,
0, 0, 0, 0, 0, 0, 0, 0, 327, 0,
0, 2317, 0, 0, 0, 0, 1217, 0, 0, 0,
1221, 0, 0, 0, 92, 0, 0, 98, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 2318,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 308, 309, 310, 92, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 1248, 0, 0, 0, 0,
0, 0, 0, 327, 79, 80, 81, 82, 0, 0,
0, 0, 92, 0, 2322, 0, 0, 0, 1280, 0,
92, 92, 0, 1254, 1255, 1256, 1257, 1258, 1259, 1260,
1261, 92, 0, 1262, 1263, 1264, 1265, 1266, 1267, 1268,
1269, 1385, 0, 0, 253, 1270, 2323, 253, 0, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 1147, 0, 0, 0, 0, 0, 1148,
1149, 0, 0, 0, 0, 0, 0, 1150, 0, 0,
1151, 0, 0, 0, 1152, 306, 0, 0, 1153, 1154,
0, 0, 0, 1463, 1464, 333, 333, 92, 2325, 92,
92, 92, 92, 0, 345, 0, 0, 92, 92, 92,
92, 92, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 131, 132, 6, 0, 930, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 133, 134, 135,
0, 0, 0, 0, 0, 136, 137, 0, 11, 0,
0, 253, 253, 0, 0, 0, 0, 0, 253, 253,
253, 0, 0, 0, 138, 139, 140, 0, 0, 141,
92, 92, 92, 0, 0, 467, 92, 470, 2329, 142,
92, 26, 0, 143, 144, 0, 0, 0, 145, 146,
147, 148, 149, 150, 151, 152, 153, 154, 0, 0,
0, 0, 0, 155, 156, 157, 158, 159, 160, 161,
162, 163, 164, 165, 166, 167, 168, 169, 170, 171,
172, 173, 174, 175, 176, 177, 178, 179, 180, 1630,
308, 309, 310, 0, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 0, 0, 0, 0,
0, 327, 0, 0, 0, 521, 0, 0, 0, 0,
0, 0, 92, 0, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 261, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 253, 0, 326, 0, 253, 253, 0, 0,
92, 253, 1738, 327, 0, 0, 0, 253, 253, 0,
0, 0, 253, 253, 253, 253, 0, 0, 0, 0,
253, 0, 0, 253, 0, 253, 0, 308, 309, 310,
2330, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 0, 324, 325, 0, 1783, 326,
1785, 0, 0, 1788, 1789, 0, 1791, 0, 327, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 0, 0, 0, 0, 333, 0, 0,
253, 0, 92, 0, 0, 0, 1838, 0, 0, 92,
0, 0, 0, 0, 0, 92, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 308, 309, 310, 253, 311, 312, 313, 314, 315,
316, 317, 318, 319, 320, 321, 322, 323, 0, 324,
325, 0, 0, 326, 0, 92, 0, 0, 0, 0,
795, 0, 327, 0, 0, 253, 0, 0, 0, 0,
0, 0, 181, 0, 0, 0, 0, 253, 0, 182,
0, 2334, 183, 253, 0, 0, 0, 0, 0, 0,
184, 0, 0, 0, 0, 0, 253, 253, 253, 0,
0, 0, 0, 0, 0, 0, 92, 92, 0, 0,
0, 308, 309, 310, 0, 311, 312, 313, 314, 315,
316, 317, 318, 319, 320, 321, 322, 323, 0, 324,
325, 0, 0, 326, 0, 0, 131, 132, 6, 60,
0, 0, 327, 61, 0, 62, 63, 0, 0, 0,
0, 133, 134, 135, 64, 65, 66, 67, 68, 136,
137, 244, 11, 69, 0, 0, 0, 0, 0, 0,
0, 0, 253, 253, 2335, 0, 0, 0, 138, 139,
140, 70, 877, 141, 253, 245, 246, 247, 248, 249,
0, 0, 0, 142, 71, 26, 72, 143, 144, 73,
0, 0, 145, 146, 147, 148, 149, 150, 151, 152,
153, 154, 74, 75, 76, 77, 78, 155, 156, 157,
158, 159, 160, 161, 162, 163, 164, 165, 166, 167,
168, 169, 170, 171, 172, 173, 174, 175, 176, 177,
178, 179, 180, 0, 0, 0, 0, 0, 253, 253,
0, 2083, 0, 0, 0, 0, 0, 0, 0, 1666,
0, 253, 0, 253, 2682, 0, 0, 0, 795, 2094,
2095, 0, 253, 841, 0, 0, 0, 0, 0, 0,
0, 0, 0, 333, 0, 0, 0, 0, 0, 253,
253, 0, 0, 308, 309, 310, 0, 311, 312, 313,
314, 315, 316, 317, 318, 319, 320, 321, 322, 323,
0, 324, 325, 0, 0, 326, 92, 0, 0, 0,
0, 0, 0, 0, 327, 0, 0, 0, 0, 253,
0, 0, 0, 0, 0, 253, 0, 0, 0, 0,
2132, 0, 0, 0, 0, 0, 0, 795, 0, 0,
2142, 2143, 2144, 0, 0, 0, 0, 0, 0, 0,
2151, 0, 0, 2154, 0, 2156, 2157, 0, 0, 0,
2161, 0, 0, 2164, 2165, 0, 0, 0, 2167, 0,
0, 2170, 2171, 2172, 2173, 0, 0, 2174, 2175, 2176,
2177, 2178, 0, 2180, 0, 0, 0, 0, 0, 2184,
2185, 0, 0, 0, 2189, 2190, 0, 0, 308, 309,
310, 92, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 2203, 324, 325, 0, 0,
326, 333, 0, 0, 2641, 333, 0, 0, 0, 327,
0, 0, 2642, 2218, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 1254, 1255, 1256,
1257, 1258, 1259, 1260, 1261, 327, 333, 1262, 1263, 1264,
1265, 1266, 1267, 1268, 1269, 0, 0, 0, 0, 1270,
0, 0, 0, 1880, 0, 0, 79, 80, 81, 82,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 259, 0, 0, 0,
0, 0, 0, 182, 0, 0, 183, 0, 0, 0,
0, 0, 0, 0, 184, 1667, 0, 308, 309, 310,
795, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 0, 324, 325, 0, 0, 326,
6, 0, 253, 0, 0, 0, 92, 0, 327, 7,
8, 9, 10, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 11, 0, 12, 13, 14, 15,
16, 17, 18, 19, 20, 21, 0, 0, 22, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 24, 25, 0, 0, 26, 0, 0,
0, 0, 27, 28, 1249, 0, 261, 308, 309, 310,
0, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 0, 324, 325, 0, 0, 326,
2435, 0, 0, 0, 0, 0, 0, 0, 327, 0,
2451, 0, 2452, 2453, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 795, 0, 0, 0, 0, 30,
0, 0, 0, 0, 0, 0, 2469, 0, 2471, 2472,
0, 0, 0, 795, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 2485, 2486, 0, 0, 0, 0, 0, 0, 0,
2490, 0, 0, 0, 0, 0, 0, 2683, 0, 0,
2496, 0, 0, 0, 2500, 0, 0, 0, 2504, 2505,
0, 0, 2509, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 261, 0,
261, 261, 261, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 2547,
2548, 0, 0, 2550, 0, 2551, 2552, 0, 0, 0,
2555, 2556, 0, 2559, 0, 0, 0, 0, 0, 0,
0, 0, 2565, 0, 2567, 2568, 2569, 2570, 2571, 2572,
2573, 2574, 2575, 2576, 2577, 2578, 0, 38, 0, 0,
0, 2584, 2585, 39, 2587, 0, 131, 132, 6, 0,
0, 0, 0, 623, 0, 2597, 2598, 2599, 2600, 2601,
0, 133, 134, 135, 0, 0, 0, 0, 0, 136,
137, 244, 11, 1378, 1379, 1380, 1381, 1382, 0, 0,
0, 0, 0, 2684, 0, 0, 0, 92, 138, 139,
140, 0, 0, 141, 0, 245, 246, 247, 248, 249,
0, 0, 0, 142, 0, 26, 0, 143, 144, 0,
0, 0, 145, 146, 147, 148, 149, 150, 151, 152,
153, 154, 0, 0, 0, 0, 0, 155, 156, 157,
158, 159, 160, 161, 162, 163, 164, 165, 166, 167,
168, 169, 170, 171, 172, 173, 174, 175, 176, 177,
178, 179, 180, 0, 0, 0, 0, 0, 0, 0,
253, 0, 0, 0, 0, 0, 0, 0, 0, 0,
261, 0, 0, 2672, 2673, 2674, 261, 0, 0, 0,
0, 0, 0, 0, 1254, 1255, 1256, 1257, 1258, 1259,
1260, 1261, 0, 2677, 1262, 1263, 1264, 1265, 1266, 1267,
1268, 1269, 0, 0, 253, 2680, 1270, 0, 0, 0,
2090, 92, 253, 92, 2687, 2688, 0, 2689, 0, 0,
0, 0, 0, 0, 0, 0, 0, 2698, 2699, 2700,
2701, 0, 0, 2704, 0, 2706, 0, 2708, 0, 0,
0, 2712, 0, 0, 0, 0, 92, 0, 2725, 2726,
0, 0, 0, 0, 0, 0, 92, 0, 0, 0,
0, 0, 0, 0, 253, 0, 0, 0, 92, 92,
2741, 0, 92, 92, 92, 0, 2685, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
261, 92, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 92, 92, 0, 0, 0, 795, 0,
308, 309, 310, 0, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 2783, 324, 325,
0, 0, 326, 0, 0, 0, 0, 0, 0, 0,
0, 327, 2792, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 261, 261, 261, 261, 0,
0, 0, 0, 2810, 2811, 2812, 0, 2813, 0, 0,
0, 0, 2816, 2817, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 2826, 0, 2828, 0, 0, 308,
309, 310, 2836, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 2851, 0, 2767, 0, 0, 0, 0,
327, 0, 0, 2768, 0, 0, 250, 0, 0, 0,
0, 0, 0, 182, 0, 0, 183, 0, 0, 0,
251, 0, 0, 0, 184, 0, 308, 309, 310, 0,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 2888, 2889, 2890, 0, 0, 2891, 327, 0, 2894,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 261, 0, 261, 261, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 2923, 2924, 0, 0, 0, 0, 0, 2927,
0, 0, 2930, 0, 0, 0, 0, 0, 0, 0,
0, 2934, 0, 0, 0, 0, 795, 0, 0, 0,
0, 0, 0, 0, 0, 2686, 0, 0, 0, 0,
2951, 2952, 0, 0, 0, 0, 0, 0, 261, 0,
0, 0, 0, 0, 0, 0, 0, 2965, 0, 0,
0, 0, 0, 2839, 0, 0, 0, 0, 0, 0,
0, 0, 2981, 0, 0, 0, 0, 0, 2986, 0,
2988, 0, 0, 0, 0, 0, 0, 0, 0, 2996,
0, 0, 0, 3002, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 3012, 0, 0,
0, 3016, 0, 0, 0, 0, 3020, 3021, 0, 0,
0, 3024, 0, 0, 0, 0, 0, 3029, 3030, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 1254, 1255, 1256, 1257, 1258, 1259, 1260, 1261,
327, 0, 1262, 1263, 1264, 1265, 1266, 1267, 1268, 1269,
0, 0, 0, 0, 1270, 0, 0, 0, 2690, 131,
132, 586, 60, 0, 0, 0, 61, 92, 62, 63,
0, 0, 0, 0, 133, 134, 135, 64, 65, 66,
67, 68, 136, 137, 244, 11, 69, 0, 0, 92,
0, 253, 253, 253, 0, 253, 0, 0, 0, 0,
0, 138, 139, 140, 70, 0, 141, 0, 245, 246,
247, 248, 249, 0, 0, 0, 142, 71, 26, 72,
143, 144, 73, 0, 0, 145, 146, 147, 148, 149,
150, 151, 152, 153, 154, 74, 75, 76, 77, 78,
155, 156, 157, 158, 159, 160, 161, 162, 163, 164,
165, 166, 167, 168, 169, 170, 171, 172, 173, 174,
175, 176, 177, 178, 179, 180, 0, 0, 0, 0,
131, 132, 6, 60, 0, 0, 0, 61, 710, 62,
63, 0, 588, 0, 0, 133, 134, 135, 64, 65,
66, 67, 68, 136, 137, 244, 11, 69, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 138, 139, 140, 70, 0, 141, 0, 245,
246, 247, 248, 249, 0, 0, 0, 142, 71, 26,
72, 143, 144, 73, 0, 0, 145, 146, 147, 148,
149, 150, 151, 152, 153, 154, 74, 75, 76, 77,
78, 155, 156, 157, 158, 159, 160, 161, 162, 163,
164, 165, 166, 167, 168, 169, 170, 171, 172, 173,
174, 175, 176, 177, 178, 179, 180, 0, 308, 309,
310, 0, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 253, 324, 325, 0, 0,
326, 0, 0, 0, 0, 0, 308, 309, 310, 327,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 6, 0, 0, 0, 0, 0, 327, 0, 0,
7, 8, 9, 10, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 253, 11, 253, 12, 13, 14,
15, 16, 17, 18, 19, 20, 21, 0, 0, 22,
0, 0, 0, 0, 676, 0, 0, 0, 0, 0,
0, 0, 0, 0, 24, 25, 0, 0, 26, 0,
0, 0, 0, 27, 28, 0, 0, 0, 0, 0,
0, 0, 0, 0, 92, 92, 0, 0, 988, 92,
0, 0, 0, 253, 6, 0, 0, 0, 0, 79,
80, 81, 82, 0, 0, 0, 0, 253, 0, 253,
253, 253, 0, 0, 0, 92, 0, 0, 11, 250,
92, 253, 92, 253, 0, 0, 182, 92, 0, 183,
30, 253, 0, 251, 0, 0, 92, 711, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 1517, 0,
0, 0, 0, 0, 0, 0, 0, 0, 1518, 0,
0, 0, 0, 0, 0, 253, 253, 0, 0, 92,
0, 0, 92, 0, 92, 0, 1114, 1115, 1116, 1117,
1118, 1119, 1120, 1121, 1122, 1123, 1124, 1125, 1126, 1127,
1128, 1129, 1130, 1131, 1132, 1133, 1134, 1135, 1136, 0,
0, 0, 1519, 1520, 1521, 1522, 1523, 1524, 0, 0,
79, 80, 81, 82, 0, 0, 0, 0, 0, 0,
435, 0, 0, 0, 0, 0, 0, 0, 0, 0,
250, 0, 0, 0, 0, 0, 0, 182, 0, 0,
183, 0, 0, 0, 251, 0, 0, 0, 184, 92,
0, 0, 92, 253, 92, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 307, 0, 38, 0,
0, 0, 0, 0, 39, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 92, 92, 0, 0, 0,
0, 131, 132, 6, 60, 0, 0, 0, 863, 253,
62, 63, 0, 0, 0, 253, 133, 134, 135, 64,
65, 66, 67, 68, 136, 137, 244, 11, 69, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 138, 139, 140, 70, 0, 141, 0,
245, 246, 247, 248, 249, 0, 0, 0, 142, 71,
26, 72, 143, 144, 73, 0, 0, 145, 146, 147,
148, 149, 150, 151, 152, 153, 154, 74, 75, 76,
77, 78, 155, 156, 157, 158, 159, 160, 161, 162,
163, 164, 165, 166, 167, 168, 169, 170, 171, 172,
173, 174, 175, 176, 177, 178, 179, 180, 0, 0,
0, 0, 0, 0, 1525, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 308, 309, 310, 253,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 435, 0, 326, 0,
677, 0, 0, 0, 0, 0, 0, 327, 0, 0,
308, 309, 310, 0, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 131, 132, 6, 60, 0, 989, 0,
61, 327, 62, 63, 253, 253, 253, 253, 133, 134,
135, 64, 65, 66, 67, 68, 136, 137, 0, 11,
69, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 253, 0, 0, 253, 138, 139, 140, 70, 0,
141, 0, 0, 0, 0, 0, 0, 0, 0, 0,
142, 71, 26, 72, 143, 144, 73, 0, 0, 145,
146, 147, 148, 149, 150, 151, 152, 153, 154, 74,
75, 76, 77, 78, 155, 156, 157, 158, 159, 160,
161, 162, 163, 164, 165, 166, 167, 168, 169, 170,
171, 172, 173, 174, 175, 176, 177, 178, 179, 180,
0, 0, 308, 309, 310, 0, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 452, 437, 323, 0,
324, 325, 0, 0, 326, 0, 1066, 0, 0, 0,
0, 253, 92, 327, 0, 0, 253, 0, 0, 0,
0, 0, 0, 253, 253, 0, 253, 253, 308, 309,
310, 0, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 79, 80, 81, 82, 0, 0, 0, 0, 327,
0, 0, 253, 253, 0, 0, 253, 0, 0, 253,
0, 250, 0, 0, 0, 0, 0, 0, 182, 0,
0, 183, 0, 0, 0, 864, 0, 253, 0, 184,
131, 132, 6, 60, 253, 253, 0, 863, 0, 62,
63, 0, 0, 0, 0, 133, 134, 135, 64, 65,
66, 67, 68, 136, 137, 0, 11, 69, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 138, 139, 140, 70, 0, 141, 0, 0,
0, 0, 0, 0, 0, 0, 0, 142, 71, 26,
72, 143, 144, 73, 0, 0, 145, 146, 147, 148,
149, 150, 151, 152, 153, 154, 74, 75, 76, 77,
78, 155, 156, 157, 158, 159, 160, 161, 162, 163,
164, 165, 166, 167, 168, 169, 170, 171, 172, 173,
174, 175, 176, 177, 178, 179, 180, 1095, 308, 309,
310, 0, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 452, 437, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 0, 0, 131, 132, 6, 327,
0, 0, 0, 79, 80, 81, 82, 0, 0, 0,
0, 133, 134, 135, 0, 0, 0, 0, 0, 136,
137, 244, 11, 181, 0, 0, 0, 0, 0, 0,
182, 0, 0, 183, 0, 0, 0, 858, 138, 139,
140, 184, 0, 141, 0, 245, 246, 247, 248, 249,
0, 0, 0, 142, 0, 26, 0, 143, 144, 0,
0, 0, 145, 146, 147, 148, 149, 150, 151, 152,
153, 154, 0, 0, 0, 0, 0, 155, 156, 157,
158, 159, 160, 161, 162, 163, 164, 165, 166, 167,
168, 169, 170, 171, 172, 173, 174, 175, 176, 177,
178, 179, 180, 131, 132, 6, 0, 0, 0, 0,
814, 0, 0, 0, 0, 0, 0, 0, 133, 134,
135, 0, 0, 0, 0, 0, 136, 137, 244, 11,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 138, 139, 140, 0, 0,
141, 0, 245, 246, 247, 248, 249, 0, 0, 0,
142, 0, 26, 0, 143, 144, 0, 0, 0, 145,
146, 147, 148, 149, 150, 151, 152, 153, 154, 0,
0, 0, 0, 0, 155, 156, 157, 158, 159, 160,
161, 162, 163, 164, 165, 166, 167, 168, 169, 170,
171, 172, 173, 174, 175, 176, 177, 178, 179, 180,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
79, 80, 81, 82, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
181, 0, 0, 0, 0, 0, 0, 182, 0, 0,
183, 0, 6, 0, 960, 0, 0, 0, 184, 0,
0, 7, 8, 9, 10, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 0, 0,
22, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 24, 25, 0, 2511, 26,
0, 0, 2512, 435, 27, 28, 0, 0, 2513, 0,
0, 308, 309, 310, 0, 311, 312, 313, 314, 315,
316, 317, 318, 319, 320, 321, 322, 323, 0, 324,
325, 0, 0, 326, 0, 0, 0, 2847, 0, 131,
132, 586, 327, 0, 0, 2848, 0, 0, 0, 0,
0, 0, 0, 0, 133, 134, 135, 0, 0, 0,
0, 30, 136, 137, 244, 11, 250, 0, 0, 0,
0, 0, 0, 182, 0, 0, 183, 0, 0, 1725,
251, 138, 139, 140, 184, 0, 141, 0, 245, 246,
247, 248, 249, 0, 0, 0, 142, 0, 26, 0,
143, 144, 0, 0, 1726, 145, 146, 147, 148, 149,
150, 151, 152, 153, 154, 0, 0, 0, 0, 0,
155, 156, 157, 158, 159, 160, 161, 162, 163, 164,
165, 166, 167, 168, 169, 170, 171, 172, 173, 174,
175, 176, 177, 178, 179, 180, 0, 0, 0, 0,
0, 131, 132, 6, 0, 0, 0, 0, 0, 0,
0, 0, 588, 0, 0, 0, 133, 134, 135, 0,
0, 0, 0, 250, 136, 137, 244, 11, 0, 0,
182, 0, 0, 183, 0, 0, 0, 251, 0, 0,
0, 184, 0, 138, 139, 140, 0, 0, 141, 38,
245, 246, 247, 248, 249, 39, 0, 0, 142, 0,
26, 0, 143, 144, 0, 0, 0, 145, 146, 147,
148, 149, 150, 151, 152, 153, 154, 0, 0, 0,
0, 0, 155, 156, 157, 158, 159, 160, 161, 162,
163, 164, 165, 166, 167, 168, 169, 170, 171, 172,
173, 174, 175, 176, 177, 178, 179, 180, 131, 132,
6, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 133, 134, 135, 0, 0, 0, 0,
0, 136, 137, 244, 11, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
138, 139, 140, 0, 0, 141, 0, 245, 246, 247,
248, 249, 0, 0, 0, 142, 0, 26, 0, 143,
144, 0, 0, 0, 145, 146, 147, 148, 149, 150,
151, 152, 153, 154, 1727, 1728, 0, 0, 0, 155,
156, 157, 158, 159, 160, 161, 162, 163, 164, 165,
166, 167, 168, 169, 170, 171, 172, 173, 174, 175,
176, 177, 178, 179, 180, 308, 309, 310, 0, 311,
312, 313, 314, 315, 316, 317, 318, 319, 320, 436,
437, 323, 0, 324, 325, 0, 0, 326, 0, 0,
0, 0, 131, 132, 6, 0, 327, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 133, 134, 135,
0, 0, 0, 0, 0, 136, 137, 244, 11, 250,
0, 0, 0, 0, 0, 0, 182, 0, 0, 183,
0, 0, 0, 251, 138, 139, 140, 711, 0, 141,
0, 245, 246, 247, 248, 249, 0, 0, 0, 142,
0, 26, 0, 143, 144, 0, 0, 0, 145, 146,
147, 148, 149, 150, 151, 152, 153, 154, 0, 0,
0, 0, 0, 155, 156, 157, 158, 159, 160, 161,
162, 163, 164, 165, 166, 167, 168, 169, 170, 171,
172, 173, 174, 175, 176, 177, 178, 179, 180, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 131,
132, 6, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 133, 134, 135, 0, 0, 0,
0, 250, 136, 137, 244, 11, 0, 0, 182, 0,
0, 183, 0, 0, 0, 251, 1214, 0, 0, 184,
0, 138, 139, 140, 0, 0, 141, 0, 245, 246,
247, 248, 249, 0, 0, 0, 142, 0, 26, 0,
143, 144, 0, 0, 0, 145, 146, 147, 148, 149,
150, 151, 152, 153, 154, 0, 0, 0, 0, 0,
155, 156, 157, 158, 159, 160, 161, 162, 163, 164,
165, 166, 167, 168, 169, 170, 171, 172, 173, 174,
175, 176, 177, 178, 179, 180, 131, 132, 6, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 133, 134, 135, 0, 0, 0, 0, 259, 136,
137, 244, 11, 0, 0, 182, 0, 0, 183, 260,
0, 0, 0, 0, 0, 0, 184, 0, 138, 139,
140, 0, 0, 141, 0, 245, 246, 247, 248, 249,
0, 0, 0, 142, 0, 26, 0, 143, 144, 0,
0, 0, 145, 146, 147, 148, 149, 150, 151, 152,
153, 154, 0, 0, 0, 0, 0, 155, 156, 157,
158, 159, 160, 161, 162, 163, 164, 165, 166, 167,
168, 169, 170, 171, 172, 173, 174, 175, 176, 177,
178, 179, 180, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 131, 132, 6, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
133, 134, 135, 0, 0, 0, 0, 0, 136, 137,
244, 11, 259, 0, 0, 0, 0, 0, 0, 182,
0, 0, 183, 0, 0, 0, 430, 138, 139, 140,
184, 0, 141, 0, 245, 246, 247, 248, 249, 0,
0, 0, 142, 0, 26, 0, 143, 144, 0, 0,
0, 145, 146, 147, 148, 149, 150, 151, 152, 153,
154, 0, 0, 0, 0, 0, 155, 156, 157, 158,
159, 160, 161, 162, 163, 164, 165, 166, 167, 168,
169, 170, 171, 172, 173, 174, 175, 176, 177, 178,
179, 180, 0, 0, 0, 0, 0, 0, 0, 131,
132, 6, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 133, 134, 135, 0, 0, 0,
0, 0, 136, 137, 244, 11, 0, 0, 0, 259,
0, 0, 0, 0, 0, 0, 182, 0, 0, 183,
0, 138, 139, 140, 433, 0, 141, 184, 245, 246,
247, 248, 249, 0, 0, 0, 142, 0, 26, 0,
143, 144, 0, 0, 0, 145, 146, 147, 148, 149,
150, 151, 152, 153, 154, 0, 0, 0, 0, 0,
155, 156, 157, 158, 159, 160, 161, 162, 163, 164,
165, 166, 167, 168, 169, 170, 171, 172, 173, 174,
175, 176, 177, 178, 179, 180, 0, 0, 0, 131,
132, 6, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 133, 134, 135, 0, 0, 0,
0, 0, 136, 137, 244, 11, 250, 0, 0, 0,
0, 0, 0, 182, 0, 0, 183, 0, 0, 0,
251, 138, 139, 140, 184, 0, 141, 0, 245, 246,
247, 248, 249, 0, 0, 0, 142, 0, 26, 0,
143, 144, 0, 0, 0, 145, 146, 147, 148, 149,
150, 151, 152, 153, 154, 0, 0, 0, 0, 0,
155, 156, 157, 158, 159, 160, 161, 162, 163, 164,
165, 166, 167, 168, 169, 170, 171, 172, 173, 174,
175, 176, 177, 178, 179, 180, 0, 0, 0, 131,
132, 6, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 133, 134, 135, 0, 0, 0,
0, 0, 136, 137, 0, 11, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 138, 139, 140, 0, 259, 141, 0, 0, 0,
0, 0, 182, 0, 0, 183, 142, 0, 26, 594,
143, 144, 0, 184, 0, 145, 146, 147, 148, 149,
150, 151, 152, 153, 154, 0, 0, 0, 0, 0,
155, 156, 157, 158, 159, 160, 161, 162, 163, 164,
165, 166, 167, 168, 169, 170, 171, 172, 173, 174,
175, 176, 177, 178, 179, 180, 0, 0, 0, 0,
0, 0, 0, 131, 132, 6, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 133, 134,
135, 0, 0, 0, 0, 0, 136, 137, 0, 11,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 138, 139, 140, 0, 259,
141, 0, 0, 0, 0, 0, 182, 0, 0, 183,
142, 0, 26, 606, 143, 144, 0, 184, 0, 145,
146, 147, 148, 149, 150, 151, 152, 153, 154, 0,
0, 0, 0, 0, 155, 156, 157, 158, 159, 160,
161, 162, 163, 164, 165, 166, 167, 168, 169, 170,
171, 172, 173, 174, 175, 176, 177, 178, 179, 180,
0, 0, 0, 131, 132, 6, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 133, 134,
135, 0, 0, 0, 0, 0, 136, 137, 0, 11,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 138, 139, 140, 0, 259,
141, 0, 0, 0, 0, 0, 182, 0, 0, 183,
142, 0, 26, 0, 143, 144, 0, 184, 0, 145,
146, 147, 148, 149, 150, 151, 152, 153, 154, 0,
0, 0, 0, 0, 155, 156, 157, 158, 159, 160,
161, 162, 163, 164, 165, 166, 167, 168, 169, 170,
171, 172, 173, 174, 175, 176, 177, 178, 179, 180,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 131, 132, 6, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 133, 134, 135, 0,
0, 0, 0, 0, 136, 137, 0, 11, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 181,
0, 0, 0, 138, 139, 140, 182, 0, 141, 183,
611, 0, 0, 612, 0, 0, 0, 184, 142, 0,
26, 0, 143, 144, 0, 0, 0, 145, 146, 147,
148, 149, 150, 151, 152, 153, 154, 0, 0, 0,
0, 0, 155, 156, 157, 158, 159, 160, 161, 162,
163, 164, 165, 166, 167, 168, 169, 170, 171, 172,
173, 174, 175, 176, 177, 178, 179, 180, 131, 132,
6, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 133, 134, 135, 0, 0, 0, 0,
0, 136, 137, 0, 11, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
138, 139, 140, 181, 0, 141, 0, 0, 0, 0,
182, 0, 0, 183, 958, 142, 0, 26, 0, 143,
144, 184, 0, 0, 145, 146, 147, 148, 149, 150,
151, 152, 153, 154, 0, 0, 0, 0, 0, 155,
156, 157, 158, 159, 160, 161, 162, 163, 164, 165,
166, 167, 168, 169, 170, 171, 172, 173, 174, 175,
176, 177, 178, 179, 180, 0, 0, 0, 131, 132,
6, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 133, 134, 135, 0, 0, 0, 0,
0, 136, 137, 0, 11, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
138, 139, 140, 181, 0, 141, 0, 0, 0, 0,
182, 0, 0, 183, 990, 142, 0, 26, 0, 143,
144, 184, 0, 0, 145, 146, 147, 148, 149, 150,
151, 152, 153, 154, 0, 0, 0, 0, 0, 155,
156, 157, 158, 159, 160, 161, 162, 163, 164, 165,
166, 167, 168, 169, 170, 171, 172, 173, 174, 175,
176, 177, 178, 179, 180, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 131, 132, 6, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 133, 134, 135, 0, 0, 0, 0, 0, 136,
137, 0, 11, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 138, 139,
140, 181, 0, 141, 0, 0, 0, 0, 182, 0,
0, 183, 674, 142, 0, 26, 0, 143, 144, 184,
435, 0, 145, 146, 147, 148, 149, 150, 151, 152,
153, 154, 2508, 0, 0, 0, 0, 155, 156, 157,
158, 159, 160, 161, 162, 163, 164, 165, 166, 167,
168, 169, 170, 171, 172, 173, 174, 175, 176, 177,
178, 179, 180, 131, 132, 6, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 133, 134,
135, 0, 0, 0, 0, 0, 136, 137, 0, 11,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 138, 139, 140, 181, 0,
141, 0, 0, 0, 0, 182, 0, 0, 183, 985,
142, 0, 26, 0, 143, 144, 184, 0, 0, 145,
146, 147, 148, 149, 150, 151, 152, 153, 154, 0,
0, 0, 0, 0, 155, 156, 157, 158, 159, 160,
161, 162, 163, 164, 165, 166, 167, 168, 169, 170,
171, 172, 173, 174, 175, 176, 177, 178, 179, 180,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 2225, 0, 0, 0, 0, 0, 0, 0, 0,
7, 8, 9, 10, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 11, 0, 12, 13, 14,
15, 16, 17, 18, 19, 20, 21, 0, 181, 22,
0, 0, 0, 0, 0, 182, 0, 0, 183, 0,
0, 0, 0, 0, 24, 25, 184, 0, 26, 0,
0, 0, 0, 27, 28, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 1289,
0, 0, 0, 0, 0, 0, 0, 0, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 6,
30, 0, 0, 0, 0, 0, 0, 0, 7, 8,
9, 10, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 678, 181, 22, 0, 0,
0, 0, 0, 182, 0, 0, 183, 0, 0, 2226,
2558, 0, 24, 25, 184, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 30, 0,
0, 0, 308, 309, 310, 0, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 452, 437, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 0, 0,
0, 236, 0, 327, 0, 0, 0, 0, 30, 733,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 734, 0, 38, 0,
0, 0, 0, 181, 39, 0, 735, 736, 0, 0,
182, 0, 0, 183, 0, 737, 0, 738, 1292, 1293,
1294, 184, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 38, 1369, 7, 8,
9, 10, 39, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 2227, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 6, 0, 0,
0, 0, 0, 0, 0, 0, 7, 8, 9, 10,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 11, 1370, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 0, 30, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24, 25, 0, 0, 26, 0, 0, 0, 0, 27,
28, 0, 739, 0, 0, 0, 0, 308, 309, 310,
0, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 0, 324, 325, 0, 0, 326,
0, 0, 0, 0, 0, 0, 0, 0, 327, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 372, 0, 0, 0, 0, 30, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 38, 0, 0, 0, 0, 0,
39, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 681, 0, 0, 6, 0, 0,
0, 0, 0, 0, 0, 0, 7, 8, 9, 10,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 11, 2465, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 0, 30, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24, 25, 6, 0, 26, 0, 0, 0, 0, 27,
28, 7, 8, 9, 10, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 0, 0,
22, 0, 0, 0, 0, 0, 0, 0, 0, 0,
373, 0, 0, 0, 0, 24, 25, 0, 0, 26,
0, 0, 0, 0, 27, 28, 30, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 30, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 38, 0, 0, 0, 0, 0,
39, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 807,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 6, 0, 0, 0, 0, 0, 0, 0,
0, 7, 8, 9, 10, 0, 0, 0, 0, 38,
0, 0, 2466, 0, 0, 39, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 30, 0,
22, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 24, 25, 0, 0, 26,
0, 0, 0, 0, 27, 28, 308, 309, 310, 0,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 0, 0, 0, 0, 0, 327, 0, 379,
380, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 1292, 1293,
1294, 30, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 383, 384, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 38,
0, 0, 24, 25, 0, 39, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 6, 0, 0,
0, 0, 0, 0, 0, 0, 7, 8, 9, 10,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 11, 2482, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 0, 30, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24, 25, 0, 0, 26, 0, 0, 0, 0, 27,
28, 308, 309, 310, 0, 311, 312, 313, 314, 315,
316, 317, 318, 319, 320, 321, 322, 323, 0, 324,
325, 0, 0, 326, 0, 0, 0, 0, 0, 0,
0, 0, 327, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 387, 388, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 30, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 38, 0, 0, 0, 0, 0,
39, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 6, 0, 0,
0, 0, 0, 0, 0, 0, 7, 8, 9, 10,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 11, 2484, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 0, 30, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24, 25, 0, 0, 26, 0, 0, 0, 0, 27,
28, 308, 309, 310, 0, 311, 312, 313, 314, 315,
316, 317, 318, 319, 320, 321, 322, 323, 0, 324,
325, 0, 0, 326, 0, 0, 0, 0, 0, 0,
0, 0, 327, 0, 0, 531, 0, 0, 0, 391,
392, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 395, 30, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 38, 0, 0, 0, 0, 0,
39, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 6, 0, 0,
0, 0, 0, 0, 0, 0, 7, 8, 9, 10,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 11, 2488, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 0, 30, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24, 25, 6, 0, 26, 0, 0, 0, 0, 27,
28, 7, 8, 9, 10, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 0, 0,
22, 0, 0, 0, 0, 0, 0, 0, 0, 0,
396, 0, 0, 0, 0, 24, 25, 0, 0, 26,
0, 0, 0, 0, 27, 28, 30, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 30, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 38, 0, 0, 0, 0, 0,
39, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 1396, 308, 309, 310, 0, 311,
312, 313, 314, 315, 316, 317, 318, 319, 320, 321,
322, 323, 6, 324, 325, 0, 0, 326, 0, 0,
0, 7, 8, 9, 10, 0, 327, 0, 0, 38,
0, 0, 2491, 0, 0, 39, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 30, 0,
22, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 24, 25, 0, 0, 26,
0, 0, 0, 0, 27, 28, 0, 308, 309, 310,
0, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 0, 324, 325, 0, 0, 326,
0, 0, 0, 0, 0, 0, 0, 0, 327, 400,
401, 661, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 1292, 1293,
1294, 30, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 404, 405, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 38,
0, 0, 24, 25, 0, 39, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 6, 0, 0,
0, 0, 0, 0, 0, 0, 7, 8, 9, 10,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 11, 2492, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 6, 30, 0,
0, 0, 0, 0, 0, 0, 7, 8, 9, 10,
24, 25, 0, 0, 26, 0, 0, 0, 0, 27,
28, 11, 0, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24, 25, 0, 0, 26, 0, 0, 0, 0, 27,
28, 0, 0, 0, 410, 411, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 30, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 30, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 38, 0, 0, 0, 0, 0,
39, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 6, 0, 0,
0, 0, 0, 0, 38, 0, 7, 8, 9, 10,
39, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 11, 2765, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 0, 30, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24, 25, 6, 0, 26, 0, 0, 0, 0, 27,
28, 7, 8, 9, 10, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 0, 0,
22, 0, 0, 0, 0, 0, 0, 0, 0, 416,
417, 0, 0, 0, 0, 24, 25, 0, 0, 26,
0, 0, 0, 0, 27, 28, 30, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 30, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 38, 0, 0, 0, 0, 0,
39, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 308, 309, 310, 0, 311,
312, 313, 314, 315, 316, 317, 318, 319, 320, 321,
322, 323, 6, 324, 325, 0, 0, 326, 0, 331,
0, 7, 8, 9, 10, 0, 327, 0, 0, 38,
0, 0, 2829, 0, 0, 39, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 30, 0,
22, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 24, 25, 0, 0, 26,
0, 0, 0, 0, 27, 28, 0, 308, 309, 310,
0, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 0, 324, 325, 0, 0, 326,
0, 0, 0, 0, 0, 0, 0, 0, 327, 1101,
1102, 670, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 1292, 1293,
1294, 30, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 1104, 1105, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 38,
0, 0, 24, 25, 0, 39, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 6, 0, 0,
0, 0, 0, 0, 0, 0, 7, 8, 9, 10,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 11, 2835, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 0, 30, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24, 25, 0, 0, 26, 0, 0, 0, 0, 27,
28, 308, 309, 310, 0, 311, 312, 313, 314, 315,
316, 317, 318, 319, 320, 321, 322, 323, 0, 324,
325, 0, 0, 326, 0, 0, 0, 0, 0, 0,
0, 0, 327, 0, 0, 671, 0, 0, 0, 0,
0, 0, 0, 0, 1107, 1108, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 30, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 38, 0, 0, 0, 0, 0,
39, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 6, 0, 0,
0, 0, 0, 0, 0, 0, 7, 8, 9, 10,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 11, 2895, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 0, 30, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24, 25, 6, 0, 26, 0, 0, 0, 0, 27,
28, 7, 8, 9, 10, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 0, 0,
22, 0, 0, 0, 0, 0, 0, 0, 0, 1164,
1165, 0, 0, 0, 0, 24, 25, 0, 0, 26,
0, 0, 0, 0, 27, 28, 30, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 30, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 38, 0, 0, 0, 0, 0,
39, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 308, 309, 310, 0, 311,
312, 313, 314, 315, 316, 317, 318, 319, 320, 321,
322, 323, 6, 324, 325, 0, 0, 326, 0, 332,
0, 7, 8, 9, 10, 0, 327, 0, 0, 38,
0, 0, 2899, 0, 0, 39, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 30, 0,
22, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 24, 25, 0, 0, 26,
0, 0, 0, 0, 27, 28, 0, 308, 309, 310,
0, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 0, 324, 325, 0, 0, 326,
0, 0, 0, 0, 0, 0, 0, 0, 327, 1167,
1168, 672, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 1292, 1293,
1294, 30, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 1170, 1171, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 38,
0, 0, 24, 25, 0, 39, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 6, 0, 0,
0, 0, 0, 0, 0, 0, 7, 8, 9, 10,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 11, 2903, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 0, 30, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24, 25, 0, 0, 26, 0, 0, 0, 0, 27,
28, 308, 309, 310, 0, 311, 312, 313, 314, 315,
316, 317, 318, 319, 320, 321, 322, 323, 0, 324,
325, 0, 0, 326, 0, 0, 0, 0, 0, 0,
0, 0, 327, 0, 0, 803, 0, 0, 0, 0,
0, 0, 0, 0, 1173, 1174, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 30, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 38, 0, 0, 0, 0, 0,
39, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 6, 0, 0,
0, 0, 0, 0, 0, 0, 7, 8, 9, 10,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 11, 2904, 12, 13, 14, 15, 16, 17, 18,
19, 20, 21, 0, 0, 22, 0, 0, 30, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
24, 25, 6, 0, 26, 0, 0, 0, 0, 27,
28, 7, 8, 9, 10, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 0, 0,
22, 0, 0, 0, 0, 0, 0, 0, 0, 1187,
1188, 0, 0, 0, 0, 24, 25, 0, 0, 26,
0, 0, 0, 0, 27, 28, 30, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 30, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 38, 0, 0, 0, 0, 0,
39, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 0, 0, 308, 309, 310, 0, 311,
312, 313, 314, 315, 316, 317, 318, 319, 320, 321,
322, 323, 6, 324, 325, 0, 0, 326, 0, 355,
0, 7, 8, 9, 10, 0, 327, 0, 0, 38,
0, 0, 2935, 0, 0, 39, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 30, 0,
22, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 24, 25, 0, 0, 26,
0, 0, 0, 0, 27, 28, 0, 308, 309, 310,
0, 311, 312, 313, 314, 315, 316, 317, 318, 319,
320, 321, 322, 323, 0, 324, 325, 0, 0, 326,
0, 0, 0, 0, 0, 0, 0, 0, 327, 1190,
1191, 804, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 1292, 1293,
1294, 30, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 1194, 1195, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 38,
0, 0, 24, 25, 0, 39, 26, 0, 6, 60,
0, 27, 28, 61, 0, 62, 63, 0, 0, 0,
0, 0, 0, 0, 64, 65, 66, 67, 68, 0,
0, 0, 11, 69, 0, 0, 0, 6, 60, 0,
0, 0, 61, 0, 62, 63, 0, 0, 0, 0,
0, 70, 3004, 64, 65, 66, 67, 68, 0, 0,
0, 11, 69, 0, 71, 0, 72, 0, 30, 73,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
70, 0, 74, 75, 76, 77, 78, 0, 0, 0,
0, 0, 0, 71, 0, 72, 0, 0, 73, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 74, 75, 76, 77, 78, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 1101, 1223, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 24, 25, 0, 0, 26, 0, 59, 60,
0, 27, 28, 61, 0, 62, 63, 0, 0, 0,
0, 0, 0, 0, 64, 65, 66, 67, 68, 0,
0, 0, 0, 69, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 70, 3010, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 71, 0, 72, 0, 30, 73,
0, 0, 0, 0, 0, 0, 79, 80, 81, 82,
0, 0, 74, 75, 76, 77, 78, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 79, 80, 81, 82, 0,
960, 308, 309, 310, 0, 311, 312, 313, 314, 315,
316, 317, 318, 319, 320, 321, 322, 323, 0, 324,
325, 0, 0, 326, 0, 0, 0, 0, 0, 0,
0, 0, 327, 0, 0, 1075, 0, 0, 1292, 1293,
1294, 0, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 0, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 0, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 1289,
0, 0, 0, 1368, 0, 0, 0, 1369, 7, 8,
9, 10, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 1290, 1291, 22, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 24, 25, 6, 0, 26, 0, 0, 0,
0, 27, 28, 7, 8, 9, 10, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 11, 0,
12, 13, 14, 15, 16, 17, 18, 19, 20, 21,
0, 0, 22, 0, 0, 0, 0, 0, 0, 0,
0, 0, 3023, 0, 0, 0, 0, 24, 25, 0,
0, 26, 0, 0, 0, 0, 27, 28, 30, 0,
0, 0, 0, 0, 0, 0, 79, 80, 81, 82,
308, 309, 310, 0, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 0, 0, 0, 0,
0, 327, 0, 0, 1076, 0, 236, 0, 0, 0,
0, 0, 0, 30, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 1292, 1293,
1294, 770, 1295, 1296, 1297, 1298, 1299, 1300, 1301, 1302,
1303, 1304, 1305, 1306, 1307, 1308, 1309, 1310, 1311, 1312,
1313, 1314, 1315, 1316, 1317, 1318, 1319, 1320, 1321, 1322,
1323, 1324, 1325, 1326, 0, 0, 0, 0, 0, 1327,
1328, 1329, 0, 771, 1330, 1331, 1332, 1333, 1334, 1335,
1336, 772, 0, 1337, 0, 1338, 1339, 1340, 1341, 1342,
1343, 1344, 39, 1345, 1346, 1347, 1348, 1349, 1350, 1351,
1352, 1353, 1354, 1355, 1356, 1357, 1358, 1359, 1360, 1361,
1362, 1363, 1364, 1365, 1366, 0, 0, 0, 1367, 0,
0, 0, 0, 1368, 6, 0, 0, 1369, 0, 0,
0, 0, 0, 7, 8, 9, 10, 0, 0, 0,
0, 38, 0, 0, 0, 0, 0, 39, 11, 0,
12, 13, 14, 15, 16, 17, 18, 19, 20, 21,
0, 0, 22, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 773, 0, 774, 24, 25, 0,
0, 26, 0, 0, 0, 0, 27, 28, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 775, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 3027, 0, 0, 0, 0, 0, 0, 0,
0, 0, 776, 0, 777, 778, 236, 0, 0, 779,
780, 0, 0, 30, 0, 0, 781, 0, 0, 0,
0, 0, 0, 0, 0, 6, 0, 0, 0, 0,
0, 0, 0, 0, 7, 8, 9, 10, 0, 0,
0, 754, 0, 0, 0, 0, 0, 782, 0, 11,
0, 12, 13, 14, 15, 16, 17, 18, 19, 20,
21, 0, 0, 22, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 24, 25,
0, 0, 26, 755, 756, 6, 0, 27, 28, 0,
0, 757, 0, 0, 7, 8, 9, 10, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 11,
0, 12, 13, 14, 15, 16, 17, 18, 19, 20,
21, 0, 0, 22, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 236, 24, 25,
0, 0, 26, 0, 30, 0, 0, 27, 28, 0,
0, 38, 746, 0, 0, 0, 0, 39, 0, 0,
0, 7, 8, 9, 10, 0, 0, 0, 0, 0,
0, 0, 762, 0, 0, 0, 11, 0, 12, 13,
14, 15, 16, 17, 18, 19, 20, 21, 0, 763,
22, 0, 0, 0, 0, 0, 0, 236, 0, 0,
0, 0, 0, 0, 30, 24, 25, 0, 0, 26,
0, 0, 0, 0, 27, 28, 764, 0, 0, 726,
0, 0, 0, 0, 727, 0, 0, 0, 0, 308,
309, 310, 728, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 1199, 236, 0, 0, 0, 0, 0,
0, 30, 0, 0, 6, 0, 0, 0, 0, 0,
0, 0, 38, 7, 8, 9, 10, 758, 39, 747,
2379, 0, 0, 0, 0, 0, 0, 0, 11, 748,
12, 13, 14, 15, 16, 17, 18, 19, 20, 21,
0, 0, 22, 765, 0, 0, 749, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 24, 25, 6,
0, 26, 0, 0, 0, 0, 27, 28, 7, 8,
9, 10, 38, 0, 0, 0, 0, 0, 39, 0,
0, 0, 0, 11, 0, 12, 13, 14, 15, 16,
17, 18, 19, 20, 21, 0, 0, 22, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 24, 25, 0, 0, 26, 0, 0, 0,
0, 27, 28, 30, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 38,
0, 0, 0, 0, 0, 39, 0, 0, 766, 2380,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 2381, 0, 0,
0, 236, 1180, 1181, 1182, 1183, 0, 0, 30, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 720, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 721, 0, 729, 0,
0, 0, 0, 2382, 0, 0, 0, 0, 0, 0,
0, 308, 309, 310, 2383, 311, 312, 313, 314, 315,
316, 317, 318, 319, 320, 321, 322, 323, 0, 324,
325, 0, 0, 326, 0, 0, 0, 0, 0, 0,
0, 0, 327, 0, 0, 1614, 0, 0, 0, 0,
0, 38, 0, 0, 0, 0, 0, 39, 0, 0,
0, 0, 0, 0, 2384, 750, 308, 309, 310, 0,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 0, 0, 0, 0, 0, 327, 0, 0,
1978, 0, 0, 0, 0, 0, 38, 0, 0, 2385,
0, 0, 39, 0, 0, 0, 0, 0, 0, 0,
2386, 2387, 2388, 2389, 2390, 2391, 2392, 2393, 2394, 2395,
2396, 0, 0, 2397, 2398, 2399, 2400, 2401, 2402, 2403,
2404, 2405, 2406, 2407, 2408, 2409, 2410, 2411, 2412, 2413,
2414, 2415, 2416, 2417, 2418, 2419, 2420, 2421, 2422, 2423,
2424, 2425, 2426, 2427, 2428, 2429, 2430, 2431, 6, 0,
0, 0, 2432, 2433, 0, 0, 0, 7, 8, 9,
10, 0, 0, 0, 0, 0, 0, 1184, 0, 0,
0, 0, 11, 0, 12, 13, 14, 15, 16, 17,
18, 19, 20, 21, 0, 0, 22, 0, 0, 0,
0, 0, 23, 0, 0, 0, 0, 0, 0, 0,
0, 24, 25, 0, 0, 26, 0, 0, 0, 0,
27, 28, 0, 0, 0, 0, 0, 0, 0, 308,
309, 310, 722, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 1986, 0, 0, 0, 0, 0, 0,
0, 29, 0, 0, 0, 0, 0, 30, 31, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 32, 0, 0, 33, 0, 0, 0, 0, 0,
0, 0, 0, 0, 34, 0, 0, 0, 35, 0,
0, 0, 0, 0, 0, 0, 0, 0, 308, 309,
310, 36, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 0, 0, 37, 0, 0, 327,
0, 0, 1996, 308, 309, 310, 0, 311, 312, 313,
314, 315, 316, 317, 318, 319, 320, 321, 322, 323,
0, 324, 325, 0, 0, 326, 0, 0, 0, 0,
0, 0, 0, 0, 327, 0, 0, 1997, 308, 309,
310, 0, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 0, 38, 0, 0, 0, 327,
0, 39, 2005, 0, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 40, 326, 41, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2270, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2271, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2295, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2296, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2297, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2306, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2312, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2319, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2320, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2321, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2343, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2603, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2605, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2616, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2617, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2622, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2623, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2629, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2631, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2636, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2637, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2751, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2752, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2753, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2755, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2760, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2770, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2772, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2774, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2780, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2859, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2860, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2861, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2864, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2871, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2875, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2919, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2938, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2939, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2961, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2962, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 2976, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 2991, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 3005, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 3009, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 3019, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 3025, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 3026, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 0, 0, 0, 327, 0, 0, 3031, 308,
309, 310, 0, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 0, 324, 325, 0,
0, 326, 0, 0, 0, 0, 0, 0, 0, 0,
327, 0, 0, 3032, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 356, 0,
357, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 0, 0,
455, 0, 0, 327, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 498, 0,
0, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 552, 0, 0, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 0, 0, 585, 0,
0, 327, 308, 309, 310, 0, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 0, 0,
633, 0, 0, 327, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
651, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 652, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 653, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 654, 0, 308, 309, 310, 327,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 655, 0, 308, 309, 310, 327, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
656, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 657, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 658, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 659, 0, 308, 309, 310, 327,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 660, 0, 308, 309, 310, 327, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
662, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 663, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 664, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 665, 0, 308, 309, 310, 327,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 666, 0, 308, 309, 310, 327, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
667, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 668, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 669, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 673, 0, 308, 309, 310, 327,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
679, 0, 0, 0, 308, 309, 310, 327, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
820, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 857, 0, 0, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 0, 0, 971, 0,
0, 327, 308, 309, 310, 0, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 974, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 981, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 982, 0, 308, 309, 310, 327,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 983, 0, 308, 309, 310, 327, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
984, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 986, 0, 0, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 987, 0, 0, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 0, 0, 1004, 0, 0, 327,
308, 309, 310, 0, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 0, 0, 1211, 0,
0, 327, 308, 309, 310, 0, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 1227, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 1390, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 1391, 0, 308, 309, 310, 327,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 0, 0, 1399, 0, 0, 327, 308, 309,
310, 0, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 0, 0, 1499, 0, 0, 327,
308, 309, 310, 0, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 2076, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 2262, 0, 0, 0, 308, 309, 310, 327,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 2301, 0, 308, 309, 310, 327, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
2302, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 2303, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 2304, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 2355, 0, 308, 309, 310, 327,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 2589, 0, 308, 309, 310, 327, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
2604, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 2614, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 2632, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 2757, 0, 0, 0, 308, 309, 310, 327,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 0, 0, 2758, 0, 0, 327, 308, 309,
310, 0, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 0, 0, 2759, 0, 0, 327,
308, 309, 310, 0, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 2766, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 2769, 0, 308, 309, 310, 327,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 2776, 0, 308, 309, 310, 327, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
2788, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 2789, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 0, 0, 2862, 0,
0, 327, 308, 309, 310, 0, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 0, 0,
2865, 0, 0, 327, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
2869, 0, 308, 309, 310, 327, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 0, 0,
2881, 0, 0, 327, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 2914, 0, 0, 327, 308, 309, 310, 0,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 0, 0, 2915, 0, 0, 327, 308, 309,
310, 0, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 0, 0, 2916, 0, 0, 327,
308, 309, 310, 0, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 2917, 0, 308, 309,
310, 327, 311, 312, 313, 314, 315, 316, 317, 318,
319, 320, 321, 322, 323, 0, 324, 325, 0, 0,
326, 0, 0, 0, 0, 0, 2941, 0, 0, 327,
308, 309, 310, 0, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 0, 0, 2944, 0,
0, 327, 308, 309, 310, 0, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 2948, 0,
308, 309, 310, 327, 311, 312, 313, 314, 315, 316,
317, 318, 319, 320, 321, 322, 323, 0, 324, 325,
0, 0, 326, 0, 0, 0, 0, 0, 2995, 0,
0, 327, 308, 309, 310, 0, 311, 312, 313, 314,
315, 316, 317, 318, 319, 320, 321, 322, 323, 0,
324, 325, 0, 0, 326, 0, 0, 0, 0, 0,
2997, 0, 0, 327, 308, 309, 310, 0, 311, 312,
313, 314, 315, 316, 317, 318, 319, 320, 321, 322,
323, 0, 324, 325, 0, 0, 326, 0, 0, 0,
0, 0, 3028, 0, 0, 327, 308, 309, 310, 0,
311, 312, 313, 314, 315, 316, 317, 318, 319, 320,
321, 322, 323, 0, 324, 325, 0, 0, 326, 0,
0, 0, 0, 0, 0, 0, 0, 327
};
static const yytype_int16 yycheck[] =
{
5, 797, 126, 1113, 1481, 1482, 5, 12, 9, 18,
2068, 20, 1428, 1090, 2072, 20, 5, 218, 1434, 1435,
1436, 1437, 223, 5, 195, 1503, 5, 5, 5, 5,
29, 5, 126, 1089, 39, 3, 329, 5, 876, 195,
45, 7, 5, 7, 27, 28, 51, 52, 5, 195,
727, 29, 29, 5, 849, 29, 7, 1148, 1149, 1150,
1151, 29, 45, 567, 568, 569, 570, 5, 7, 573,
574, 7, 29, 577, 578, 3, 7, 5, 61, 62,
63, 64, 65, 7, 5, 257, 258, 9, 1159, 72,
73, 29, 75, 76, 399, 3, 79, 5, 7, 82,
5, 29, 3, 9, 5, 5, 5, 112, 29, 0,
51, 120, 117, 5, 123, 563, 369, 5, 6, 117,
1230, 29, 1232, 5, 29, 5, 250, 251, 29, 29,
29, 0, 5, 9, 5, 259, 134, 29, 294, 51,
5, 29, 1233, 120, 397, 396, 439, 10, 294, 126,
133, 134, 135, 404, 152, 138, 139, 140, 29, 5,
143, 144, 62, 5, 1255, 1256, 1257, 1258, 1259, 1260,
1261, 1262, 1263, 1264, 1265, 1266, 1267, 1268, 1269, 1270,
5, 6, 1273, 29, 57, 7, 126, 51, 51, 2247,
142, 51, 120, 133, 44, 204, 142, 202, 138, 120,
205, 395, 5, 51, 29, 126, 152, 500, 154, 191,
1005, 216, 51, 393, 155, 393, 393, 222, 51, 224,
225, 226, 227, 228, 229, 230, 404, 397, 398, 906,
235, 1069, 525, 238, 145, 146, 147, 148, 149, 150,
396, 1657, 5, 155, 537, 3, 222, 5, 224, 225,
226, 227, 228, 229, 230, 23, 396, 5, 404, 235,
142, 126, 238, 117, 404, 713, 29, 272, 273, 274,
152, 29, 393, 278, 120, 5, 396, 449, 139, 121,
126, 142, 143, 163, 404, 139, 54, 369, 142, 37,
369, 155, 155, 173, 144, 155, 572, 421, 152, 29,
165, 425, 426, 382, 383, 393, 430, 155, 117, 397,
395, 393, 436, 437, 393, 397, 155, 441, 442, 443,
444, 395, 155, 91, 127, 392, 1742, 421, 452, 117,
454, 99, 100, 396, 401, 138, 430, 140, 141, 1395,
1643, 404, 110, 152, 369, 154, 355, 640, 1439, 1652,
355, 644, 202, 162, 1445, 1446, 397, 382, 383, 368,
1037, 366, 1433, 368, 152, 1203, 154, 155, 156, 157,
158, 159, 160, 378, 177, 178, 179, 180, 181, 182,
183, 184, 185, 186, 187, 395, 400, 394, 191, 192,
404, 394, 1026, 396, 393, 397, 395, 404, 248, 249,
398, 404, 401, 404, 152, 529, 400, 394, 397, 396,
404, 377, 378, 377, 378, 420, 398, 404, 397, 424,
425, 426, 396, 401, 401, 393, 1222, 397, 196, 397,
198, 199, 200, 201, 397, 529, 393, 405, 206, 207,
208, 209, 210, 384, 395, 382, 383, 384, 385, 207,
397, 398, 398, 625, 626, 627, 395, 1873, 398, 395,
394, 399, 396, 393, 395, 393, 400, 404, 397, 397,
594, 395, 384, 396, 396, 383, 397, 405, 5, 2537,
401, 404, 606, 395, 397, 393, 395, 398, 612, 395,
395, 393, 393, 395, 399, 395, 7, 405, 397, 393,
594, 269, 270, 271, 405, 397, 400, 275, 709, 397,
397, 279, 606, 369, 1148, 1149, 1150, 1151, 612, 395,
384, 384, 397, 394, 384, 396, 382, 383, 398, 701,
702, 395, 384, 385, 404, 395, 384, 398, 396, 7,
392, 713, 743, 7, 398, 384, 404, 395, 398, 396,
396, 384, 396, 191, 563, 401, 395, 404, 396, 1650,
404, 319, 395, 568, 569, 570, 404, 572, 573, 574,
397, 44, 577, 578, 1665, 126, 127, 128, 129, 130,
131, 132, 133, 134, 135, 136, 137, 44, 396, 398,
397, 142, 568, 569, 570, 398, 404, 573, 574, 1233,
127, 577, 578, 371, 155, 777, 778, 2665, 378, 379,
398, 138, 396, 140, 141, 1292, 1293, 399, 388, 389,
404, 1255, 1256, 1257, 1258, 1259, 1260, 1261, 1262, 1263,
1264, 1265, 1266, 1267, 1268, 1269, 1270, 396, 398, 1273,
623, 812, 393, 397, 404, 404, 818, 819, 395, 400,
177, 178, 179, 180, 181, 182, 183, 184, 185, 186,
187, 429, 202, 395, 191, 192, 790, 207, 792, 142,
202, 144, 388, 389, 393, 207, 392, 801, 154, 393,
395, 400, 155, 395, 399, 401, 858, 144, 164, 698,
166, 167, 701, 369, 703, 394, 169, 396, 395, 2115,
240, 241, 2118, 243, 244, 404, 382, 383, 240, 241,
242, 716, 369, 718, 396, 395, 721, 393, 191, 395,
9, 393, 404, 728, 117, 382, 383, 396, 400, 1406,
735, 1408, 1409, 1410, 393, 404, 393, 1414, 195, 7,
864, 1418, 718, 748, 945, 202, 203, 396, 396, 754,
394, 394, 396, 396, 1026, 404, 404, 762, 526, 764,
765, 404, 1038, 531, 369, 770, 398, 396, 773, 393,
538, 395, 404, 1277, 1278, 404, 544, 382, 383, 384,
385, 138, 396, 369, 141, 142, 394, 392, 396, 960,
404, 248, 394, 964, 396, 152, 404, 802, 396, 369,
257, 258, 404, 397, 398, 1439, 404, 382, 383, 384,
385, 1445, 1446, 170, 171, 172, 584, 392, 397, 398,
393, 1617, 395, 1500, 396, 396, 382, 383, 384, 385,
405, 814, 404, 404, 191, 7, 392, 8, 397, 398,
849, 850, 851, 384, 385, 386, 387, 398, 404, 858,
398, 392, 396, 1530, 1531, 1532, 404, 1534, 398, 1536,
404, 396, 382, 383, 384, 385, 398, 635, 636, 404,
875, 398, 392, 1377, 394, 7, 1148, 1149, 1150, 1151,
863, 382, 383, 384, 385, 7, 5, 393, 384, 385,
386, 392, 388, 389, 400, 396, 392, 397, 1575, 399,
905, 394, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, 1091,
388, 389, 398, 393, 392, 398, 398, 396, 2405, 143,
400, 397, 404, 401, 291, 372, 373, 374, 375, 376,
377, 398, 395, 380, 381, 382, 383, 384, 385, 386,
387, 1628, 396, 398, 1631, 392, 1633, 397, 398, 404,
404, 1233, 1639, 177, 178, 179, 180, 181, 182, 183,
184, 185, 186, 187, 396, 398, 397, 191, 399, 1234,
1235, 404, 404, 1255, 1256, 1257, 1258, 1259, 1260, 1261,
1262, 1263, 1264, 1265, 1266, 1267, 1268, 1269, 1270, 398,
2077, 1273, 398, 395, 1205, 404, 396, 2098, 404, 396,
1015, 2121, 396, 1018, 404, 1020, 1650, 404, 395, 398,
404, 1026, 395, 1028, 1701, 404, 1031, 1032, 1033, 398,
398, 1665, 395, 1038, 1039, 404, 404, 1042, 395, 1015,
1045, 398, 1018, 1048, 1020, 2523, 2524, 398, 398, 1845,
395, 395, 1028, 404, 404, 1031, 1032, 1033, 382, 383,
384, 385, 397, 1039, 398, 398, 1042, 395, 392, 1045,
404, 404, 1048, 382, 383, 384, 385, 845, 382, 383,
384, 385, 386, 392, 388, 389, 398, 396, 392, 395,
398, 1096, 404, 398, 404, 1100, 404, 401, 398, 404,
401, 395, 403, 222, 404, 224, 225, 226, 227, 228,
229, 230, 398, 395, 398, 398, 235, 398, 404, 238,
404, 404, 395, 404, 1100, 1401, 1402, 1403, 1404, 1405,
382, 383, 384, 385, 386, 387, 398, 395, 395, 397,
392, 1417, 404, 1148, 1149, 1150, 1151, 1152, 395, 1154,
397, 1444, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, 398, 388, 389, 395, 1439, 392, 404,
398, 404, 940, 1445, 1446, 398, 404, 401, 395, 398,
398, 404, 395, 398, 398, 404, 404, 394, 1193, 404,
398, 395, 395, 1198, 2610, 395, 404, 397, 395, 370,
371, 372, 373, 374, 375, 376, 377, 1483, 1484, 380,
381, 382, 383, 384, 385, 386, 387, 1193, 393, 395,
395, 392, 1198, 3, 3, 5, 5, 395, 1233, 1234,
1235, 397, 395, 399, 395, 395, 1512, 395, 395, 394,
396, 1246, 296, 395, 395, 395, 395, 395, 395, 7,
1255, 1256, 1257, 1258, 1259, 1260, 1261, 1262, 1263, 1264,
1265, 1266, 1267, 1268, 1269, 1270, 7, 7, 1273, 399,
8, 404, 396, 396, 9, 396, 396, 7, 1955, 393,
7, 7, 395, 1288, 1289, 395, 1963, 7, 395, 7,
7, 392, 7, 1970, 7, 369, 369, 397, 404, 404,
1576, 396, 404, 1980, 394, 7, 1983, 393, 404, 394,
401, 1988, 1288, 7, 369, 396, 2134, 2135, 395, 7,
396, 393, 369, 369, 7, 2002, 396, 1095, 2005, 404,
393, 393, 396, 404, 394, 1611, 404, 396, 404, 7,
7, 1513, 395, 7, 2162, 1469, 2023, 5, 7, 1521,
2168, 7, 397, 397, 7, 7, 397, 5, 397, 397,
397, 2179, 7, 2454, 1636, 369, 396, 5, 397, 2187,
2188, 7, 397, 7, 397, 1469, 7, 397, 1650, 395,
5, 7, 397, 2799, 305, 306, 307, 308, 309, 310,
311, 312, 313, 1665, 2071, 7, 1401, 1402, 1403, 1404,
1405, 1573, 8, 2080, 2081, 2082, 396, 1412, 2085, 7,
7, 7, 1417, 7, 1419, 370, 371, 372, 373, 374,
375, 376, 377, 1699, 404, 380, 381, 382, 383, 384,
385, 386, 387, 396, 1439, 394, 394, 392, 1714, 394,
1445, 1446, 404, 369, 7, 1721, 7, 397, 7, 568,
569, 570, 7, 7, 573, 574, 395, 395, 577, 578,
1469, 384, 7, 7, 2098, 7, 1471, 7, 7, 1474,
369, 404, 1477, 1478, 7, 7, 376, 377, 1483, 1484,
380, 381, 382, 383, 384, 385, 386, 387, 7, 397,
1495, 1496, 392, 7, 7, 7, 7, 7, 7, 1504,
1505, 2611, 7, 1508, 1509, 7, 127, 1512, 3, 396,
396, 394, 404, 1518, 1519, 7, 7, 138, 1523, 1524,
141, 142, 7, 1528, 397, 5, 384, 397, 1504, 7,
398, 398, 1537, 1538, 1539, 1540, 1541, 1542, 1543, 1544,
1545, 7, 7, 1548, 8, 1550, 1551, 1552, 1553, 1554,
397, 404, 396, 395, 2231, 1560, 177, 178, 179, 180,
181, 182, 183, 184, 185, 186, 187, 395, 395, 395,
191, 1576, 395, 395, 7, 396, 3, 397, 397, 1584,
1585, 1586, 1587, 1588, 1589, 1590, 1591, 1592, 1593, 1594,
1595, 1596, 1597, 1602, 397, 1871, 1601, 1602, 1603, 718,
1605, 397, 7, 398, 1609, 1610, 1611, 398, 1884, 393,
397, 1616, 373, 374, 375, 376, 377, 395, 395, 380,
381, 382, 383, 384, 385, 386, 387, 395, 1396, 2306,
395, 392, 370, 371, 372, 2312, 374, 375, 376, 377,
378, 379, 380, 381, 2321, 1650, 395, 395, 386, 377,
388, 389, 398, 392, 392, 369, 5, 369, 395, 1860,
1665, 397, 1667, 401, 395, 397, 395, 5, 370, 371,
372, 395, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, 395, 388, 389, 395, 1965,
392, 395, 395, 394, 1699, 1700, 1897, 1702, 395, 401,
395, 397, 395, 1904, 395, 1906, 395, 397, 395, 1714,
395, 395, 5, 395, 395, 395, 1721, 395, 370, 371,
372, 1726, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, 395, 388, 389, 395, 1940,
392, 395, 397, 5, 1945, 395, 395, 398, 395, 401,
2427, 395, 1520, 395, 1522, 395, 395, 5, 395, 1026,
2036, 396, 395, 395, 7, 395, 2042, 395, 395, 5,
7, 395, 395, 395, 7, 395, 2052, 398, 395, 395,
395, 395, 395, 5, 2060, 2061, 2062, 1555, 395, 397,
395, 395, 395, 2069, 2612, 395, 395, 1565, 5, 3,
395, 7, 395, 395, 395, 5, 396, 395, 397, 1577,
1578, 396, 2084, 1581, 1582, 1583, 1821, 1822, 7, 7,
2454, 396, 396, 396, 396, 396, 2098, 396, 395, 395,
7, 7, 1600, 397, 404, 7, 398, 7, 7, 7,
7, 7, 7, 7, 1612, 1613, 2122, 7, 7, 2526,
7, 7, 7, 7, 7, 404, 404, 395, 2030, 2031,
2032, 396, 2034, 404, 393, 2542, 1871, 404, 395, 7,
398, 7, 7, 7, 7, 7, 7, 397, 5, 1884,
395, 1148, 1149, 1150, 1151, 7, 7, 7, 7, 2707,
7, 7, 7, 2711, 7, 7, 1015, 7, 7, 1018,
7, 1020, 395, 5, 5, 395, 404, 7, 7, 1028,
7, 7, 1031, 1032, 1033, 7, 7, 7, 7, 7,
1039, 7, 7, 1042, 7, 7, 1045, 7, 7, 1048,
7, 7, 404, 396, 396, 396, 396, 396, 7, 7,
7, 7, 7, 2620, 396, 2622, 404, 404, 404, 404,
404, 1956, 1957, 404, 2631, 404, 1961, 404, 404, 396,
1965, 404, 2639, 404, 127, 396, 1233, 396, 404, 7,
396, 1976, 396, 396, 404, 138, 396, 7, 141, 142,
396, 1100, 404, 404, 396, 404, 404, 404, 1255, 1256,
1257, 1258, 1259, 1260, 1261, 1262, 1263, 1264, 1265, 1266,
1267, 1268, 1269, 1270, 2009, 404, 1273, 2825, 404, 396,
404, 404, 2830, 396, 177, 178, 179, 180, 181, 182,
183, 184, 185, 186, 187, 404, 2844, 2845, 191, 404,
404, 2036, 395, 404, 2039, 2040, 396, 2042, 2043, 2716,
404, 7, 404, 404, 396, 2054, 404, 2052, 404, 2054,
2055, 3, 2057, 396, 377, 2060, 2061, 2062, 398, 7,
3, 2262, 7, 169, 2069, 2742, 7, 7, 7, 7,
7, 7, 2749, 7, 7, 2276, 395, 397, 2896, 1198,
396, 2057, 396, 7, 397, 7, 7, 7, 7, 7,
7, 2768, 7, 2098, 7, 7, 397, 397, 397, 397,
397, 2377, 397, 7, 7, 7, 7, 7, 7, 7,
2234, 7, 7, 7, 7, 7, 394, 2122, 402, 404,
2125, 2293, 397, 2295, 2129, 397, 2131, 397, 397, 397,
7, 7, 396, 404, 397, 396, 396, 370, 371, 372,
2234, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, 7, 388, 389, 396, 5, 392,
5, 5, 5, 404, 396, 7, 7, 2985, 401, 1288,
7, 396, 1439, 404, 2992, 404, 396, 404, 1445, 1446,
2352, 2858, 2454, 396, 7, 7, 7, 7, 404, 404,
7, 396, 404, 3011, 396, 396, 404, 393, 396, 3017,
397, 404, 396, 396, 5, 404, 5, 6, 2380, 404,
2382, 10, 404, 12, 13, 397, 314, 397, 2390, 2224,
191, 396, 21, 22, 23, 24, 25, 7, 7, 7,
29, 30, 7, 395, 7, 398, 397, 7, 2006, 397,
7, 7, 2366, 395, 2368, 2369, 2370, 398, 396, 48,
396, 396, 2424, 2425, 398, 396, 396, 7, 7, 398,
2028, 7, 61, 7, 63, 7, 396, 66, 7, 7,
7, 396, 2366, 7, 2368, 2369, 2370, 7, 7, 7,
79, 80, 81, 82, 83, 2290, 2291, 7, 7, 394,
7, 5, 396, 2298, 7, 2300, 404, 7, 5, 5,
5, 168, 2307, 7, 397, 7, 7, 402, 2313, 7,
397, 7, 7, 397, 2290, 2291, 397, 5, 7, 2324,
393, 5, 397, 397, 7, 397, 404, 2332, 2333, 7,
7, 2307, 396, 404, 397, 7, 396, 2313, 7, 396,
2512, 396, 404, 404, 396, 404, 404, 396, 2324, 3,
4, 5, 2357, 397, 404, 396, 2332, 2333, 397, 7,
7, 398, 7, 397, 397, 397, 2642, 7, 397, 7,
7, 7, 2377, 2649, 7, 29, 7, 2653, 7, 5,
395, 404, 404, 1650, 397, 1504, 397, 397, 397, 397,
7, 45, 46, 47, 396, 396, 50, 396, 1665, 404,
5, 5, 5, 242, 396, 396, 60, 7, 62, 396,
64, 65, 3, 4, 5, 69, 70, 71, 72, 73,
74, 75, 76, 77, 78, 7, 7, 7, 7, 7,
84, 85, 86, 7, 2558, 398, 7, 7, 29, 278,
2564, 7, 2718, 7, 7, 7, 397, 397, 7, 2454,
7, 7, 7, 7, 45, 46, 47, 7, 7, 50,
7, 7, 397, 7, 2558, 397, 396, 398, 7, 60,
2564, 62, 397, 64, 65, 404, 404, 404, 69, 70,
71, 72, 73, 74, 75, 76, 77, 78, 396, 398,
397, 397, 397, 84, 85, 86, 7, 336, 337, 338,
397, 7, 118, 7, 7, 396, 193, 397, 397, 396,
349, 350, 351, 352, 353, 354, 404, 370, 371, 372,
404, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, 398, 388, 389, 397, 404, 392,
398, 404, 404, 404, 398, 404, 397, 404, 401, 404,
7, 7, 5, 7, 2678, 7, 5, 397, 396, 5,
5, 2566, 398, 398, 363, 364, 365, 366, 397, 397,
396, 398, 2848, 397, 404, 2343, 2344, 5, 377, 378,
2348, 370, 371, 372, 2678, 374, 375, 376, 377, 378,
379, 380, 381, 382, 383, 384, 385, 386, 2770, 388,
389, 2773, 2607, 392, 397, 394, 2374, 396, 398, 397,
397, 2379, 401, 2381, 398, 404, 398, 1472, 2386, 2743,
2744, 2745, 2746, 404, 463, 397, 1014, 2395, 467, 398,
469, 1680, 1473, 472, 1822, 474, 2049, 2642, 1284, 2206,
2363, 1610, 2918, 1834, 2649, 2650, 2651, 938, 2653, 2743,
2744, 2745, 2746, 2373, 871, 355, 1000, 831, 787, 849,
2428, 689, 964, 2431, 98, 2433, 370, 371, 372, -1,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, 828, -1, 392, -1,
2695, -1, 526, -1, -1, -1, -1, 401, 2870, -1,
-1, -1, -1, 2875, -1, -1, -1, -1, -1, -1,
2882, -1, -1, 2718, -1, -1, -1, -1, -1, 2695,
-1, 560, 561, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 393,
2508, 580, -1, 2511, -1, 2513, -1, 401, -1, 2921,
2922, -1, -1, 2925, -1, -1, 2928, -1, -1, 2883,
-1, 2885, 2886, -1, -1, -1, -1, -1, -1, -1,
2775, -1, -1, -1, 2779, -1, 2544, 2545, -1, -1,
-1, 2953, 2954, -1, -1, -1, -1, -1, -1, 2883,
-1, 2885, 2886, -1, 7, -1, -1, -1, -1, 2775,
-1, -1, -1, 2779, -1, -1, -1, 646, -1, -1,
401, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 2946, -1, -1, -1, 2831, 55, 2833, 57,
58, 2098, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 2848, -1, -1, -1, 686, -1, 688,
-1, -1, 2946, -1, -1, -1, 695, -1, -1, -1,
88, -1, -1, 2868, -1, -1, -1, 2872, -1, -1,
-1, 2876, 2877, -1, -1, 370, 371, 372, -1, 374,
375, 376, 377, 378, 379, 380, 381, 382, 383, 384,
385, 386, 2868, 388, 389, -1, 2872, 392, 126, 127,
2876, 2877, -1, 398, -1, -1, 401, -1, -1, 404,
-1, -1, -1, 2918, -1, 2920, -1, -1, 370, 371,
372, -1, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, 2057, -1,
392, -1, -1, -1, 2920, -1, -1, -1, -1, 401,
-1, -1, 2957, 181, 182, 183, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, 197,
388, 389, -1, -1, 392, -1, -1, -1, -1, -1,
-1, -1, -1, 401, 823, 824, 214, 826, 827, 2994,
-1, -1, -1, 2998, 833, 3000, -1, -1, 3003, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 236, -1,
-1, -1, -1, 3018, -1, 243, -1, 3022, 2994, -1,
-1, -1, 250, 251, -1, -1, -1, 3003, -1, -1,
-1, 259, -1, -1, -1, -1, -1, -1, -1, 267,
-1, -1, 3018, -1, -1, -1, 3022, -1, -1, 277,
-1, -1, 280, 281, 282, 283, 284, 285, 286, 287,
288, 289, 290, 291, 292, 293, 294, 295, 296, 297,
298, 299, 300, 301, 302, -1, -1, -1, -1, 307,
308, 309, 310, 311, 312, 313, 314, 315, 316, 317,
318, 319, 320, 321, 322, 323, 324, 325, 326, -1,
328, -1, 330, 2871, -1, 370, 371, 372, -1, 374,
375, 376, 377, 378, 379, 380, 381, -1, -1, 347,
-1, 386, 961, 388, 389, -1, -1, 392, -1, -1,
-1, -1, -1, -1, -1, -1, 401, -1, 977, -1,
-1, -1, 370, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 991, 992, -1, -1, -1, 370, 371, 372,
-1, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, -1, 388, 389, -1, -1, 392,
-1, -1, -1, -1, -1, -1, -1, 2454, 401, -1,
-1, -1, -1, 421, -1, -1, -1, 425, 426, 427,
428, -1, 430, -1, -1, -1, -1, 435, 436, 437,
438, -1, -1, 441, 442, 443, 444, 445, -1, -1,
-1, -1, -1, -1, 452, -1, 454, -1, -1, 457,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 1081, -1, -1, -1, -1, -1, 3, 4,
5, -1, -1, 1092, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 18, 19, 20, -1, -1, -1, -1,
-1, 26, 27, -1, 29, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
45, 46, 47, -1, -1, 50, 524, -1, -1, -1,
-1, 529, -1, -1, 532, 60, -1, 62, -1, 64,
65, -1, -1, -1, 69, 70, 71, 72, 73, 74,
75, 76, 77, 78, -1, 553, -1, -1, -1, 84,
85, 86, 87, 88, 89, 90, 91, 92, 93, 94,
95, 96, 97, 98, 99, 100, 101, 102, 103, 104,
105, 106, 107, 108, 109, -1, -1, 370, 371, 372,
373, 374, 375, 376, 377, -1, 594, 380, 381, 382,
383, 384, 385, 386, 387, -1, -1, -1, 606, 392,
-1, -1, -1, -1, 612, -1, -1, -1, -1, -1,
-1, 404, -1, -1, 7, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 634, -1, -1, -1,
-1, 639, 3, 4, 5, -1, -1, 645, -1, -1,
-1, 649, -1, -1, -1, -1, -1, 18, 19, 20,
-1, -1, -1, 661, -1, 26, 27, -1, 29, -1,
-1, -1, 670, 671, 672, -1, -1, -1, 676, -1,
678, -1, 680, 681, 45, 46, 47, -1, -1, 50,
-1, -1, -1, -1, -1, -1, 694, -1, -1, 60,
698, 62, 700, 64, 65, -1, -1, -1, 69, 70,
71, 72, 73, 74, 75, 76, 77, 78, -1, -1,
-1, -1, -1, 84, 85, 86, 87, 88, 89, 90,
91, 92, 93, 94, 95, 96, 97, 98, 99, 100,
101, 102, 103, 104, 105, 106, 107, 108, 109, 110,
111, 112, 113, -1, 115, 116, -1, 755, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 7,
-1, -1, -1, 771, -1, -1, -1, -1, 776, -1,
-1, 779, 780, 781, -1, -1, -1, -1, -1, -1,
-1, -1, 790, -1, 792, -1, -1, -1, -1, -1,
-1, -1, -1, 801, -1, 803, 804, 6, -1, 807,
-1, 10, 810, 12, 13, -1, 177, -1, -1, -1,
-1, -1, 21, 22, 23, 24, 25, 188, 189, 190,
-1, 30, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 843, 7, -1, 846, 48,
-1, 849, -1, -1, -1, -1, -1, -1, 383, -1,
-1, -1, 61, -1, 63, 390, 864, 66, 393, 394,
3, 4, 5, -1, -1, -1, 401, -1, -1, -1,
79, 80, 81, 82, 83, 18, 19, 20, -1, -1,
-1, -1, -1, 26, 27, -1, 29, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 45, 46, 47, -1, -1, 50, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 60, -1, 62,
928, 64, 65, -1, -1, -1, 69, 70, 71, 72,
73, 74, 75, 76, 77, 78, -1, -1, -1, -1,
-1, 84, 85, 86, 87, 88, 89, 90, 91, 92,
93, 94, 95, 96, 97, 98, 99, 100, 101, 102,
103, 104, 105, 106, 107, 108, 109, 110, 111, 112,
113, -1, 115, 116, -1, -1, -1, 370, 371, 372,
988, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, -1, 388, 389, -1, -1, 392,
-1, -1, -1, -1, -1, 376, -1, -1, 401, -1,
-1, 382, 383, 1021, -1, -1, -1, -1, -1, 390,
-1, -1, 393, -1, -1, 396, 397, -1, -1, 400,
401, 402, -1, -1, 177, -1, -1, 7, -1, -1,
-1, -1, -1, -1, -1, 188, 189, 190, -1, 372,
-1, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, -1, 388, 389, 1075, 1076, 392,
-1, -1, -1, -1, -1, -1, -1, -1, 401, -1,
-1, 7, -1, -1, -1, -1, 1094, -1, -1, -1,
1098, -1, -1, -1, 23, -1, -1, 26, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 7,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 370, 371, 372, 54, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, 1153, -1, -1, -1, -1,
-1, -1, -1, 401, 363, 364, 365, 366, -1, -1,
-1, -1, 91, -1, 7, -1, -1, -1, 1176, -1,
99, 100, -1, 370, 371, 372, 373, 374, 375, 376,
377, 110, -1, 380, 381, 382, 383, 384, 385, 386,
387, 1199, -1, -1, 123, 392, 7, 126, -1, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 376, -1, -1, -1, -1, -1, 382,
383, -1, -1, -1, -1, -1, -1, 390, -1, -1,
393, -1, -1, -1, 397, 184, -1, -1, 401, 402,
-1, -1, -1, 1271, 1272, 194, 195, 196, 7, 198,
199, 200, 201, -1, 203, -1, -1, 206, 207, 208,
209, 210, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 3, 4, 5, -1, 7, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 18, 19, 20,
-1, -1, -1, -1, -1, 26, 27, -1, 29, -1,
-1, 250, 251, -1, -1, -1, -1, -1, 257, 258,
259, -1, -1, -1, 45, 46, 47, -1, -1, 50,
269, 270, 271, -1, -1, 274, 275, 276, 7, 60,
279, 62, -1, 64, 65, -1, -1, -1, 69, 70,
71, 72, 73, 74, 75, 76, 77, 78, -1, -1,
-1, -1, -1, 84, 85, 86, 87, 88, 89, 90,
91, 92, 93, 94, 95, 96, 97, 98, 99, 100,
101, 102, 103, 104, 105, 106, 107, 108, 109, 1407,
370, 371, 372, -1, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, -1, -1, -1, -1,
-1, 401, -1, -1, -1, 1443, -1, -1, -1, -1,
-1, -1, 371, -1, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, 1469, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, 421, -1, 392, -1, 425, 426, -1, -1,
429, 430, 1510, 401, -1, -1, -1, 436, 437, -1,
-1, -1, 441, 442, 443, 444, -1, -1, -1, -1,
449, -1, -1, 452, -1, 454, -1, 370, 371, 372,
7, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, -1, 388, 389, -1, 1556, 392,
1558, -1, -1, 1561, 1562, -1, 1564, -1, 401, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, -1, -1, -1, -1, 526, -1, -1,
529, -1, 531, -1, -1, -1, 1614, -1, -1, 538,
-1, -1, -1, -1, -1, 544, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 370, 371, 372, 563, 374, 375, 376, 377, 378,
379, 380, 381, 382, 383, 384, 385, 386, -1, 388,
389, -1, -1, 392, -1, 584, -1, -1, -1, -1,
589, -1, 401, -1, -1, 594, -1, -1, -1, -1,
-1, -1, 383, -1, -1, -1, -1, 606, -1, 390,
-1, 7, 393, 612, -1, -1, -1, -1, -1, -1,
401, -1, -1, -1, -1, -1, 625, 626, 627, -1,
-1, -1, -1, -1, -1, -1, 635, 636, -1, -1,
-1, 370, 371, 372, -1, 374, 375, 376, 377, 378,
379, 380, 381, 382, 383, 384, 385, 386, -1, 388,
389, -1, -1, 392, -1, -1, 3, 4, 5, 6,
-1, -1, 401, 10, -1, 12, 13, -1, -1, -1,
-1, 18, 19, 20, 21, 22, 23, 24, 25, 26,
27, 28, 29, 30, -1, -1, -1, -1, -1, -1,
-1, -1, 701, 702, 7, -1, -1, -1, 45, 46,
47, 48, 711, 50, 713, 52, 53, 54, 55, 56,
-1, -1, -1, 60, 61, 62, 63, 64, 65, 66,
-1, -1, 69, 70, 71, 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, 98, 99, 100, 101, 102, 103, 104, 105, 106,
107, 108, 109, -1, -1, -1, -1, -1, 777, 778,
-1, 1859, -1, -1, -1, -1, -1, -1, -1, 126,
-1, 790, -1, 792, 7, -1, -1, -1, 797, 1877,
1878, -1, 801, 1881, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 812, -1, -1, -1, -1, -1, 818,
819, -1, -1, 370, 371, 372, -1, 374, 375, 376,
377, 378, 379, 380, 381, 382, 383, 384, 385, 386,
-1, 388, 389, -1, -1, 392, 845, -1, -1, -1,
-1, -1, -1, -1, 401, -1, -1, -1, -1, 858,
-1, -1, -1, -1, -1, 864, -1, -1, -1, -1,
1948, -1, -1, -1, -1, -1, -1, 876, -1, -1,
1958, 1959, 1960, -1, -1, -1, -1, -1, -1, -1,
1968, -1, -1, 1971, -1, 1973, 1974, -1, -1, -1,
1978, -1, -1, 1981, 1982, -1, -1, -1, 1986, -1,
-1, 1989, 1990, 1991, 1992, -1, -1, 1995, 1996, 1997,
1998, 1999, -1, 2001, -1, -1, -1, -1, -1, 2007,
2008, -1, -1, -1, 2012, 2013, -1, -1, 370, 371,
372, 940, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, 2033, 388, 389, -1, -1,
392, 960, -1, -1, 396, 964, -1, -1, -1, 401,
-1, -1, 404, 2051, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, 370, 371, 372,
373, 374, 375, 376, 377, 401, 1005, 380, 381, 382,
383, 384, 385, 386, 387, -1, -1, -1, -1, 392,
-1, -1, -1, 396, -1, -1, 363, 364, 365, 366,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 383, -1, -1, -1,
-1, -1, -1, 390, -1, -1, 393, -1, -1, -1,
-1, -1, -1, -1, 401, 402, -1, 370, 371, 372,
1069, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, -1, 388, 389, -1, -1, 392,
5, -1, 1091, -1, -1, -1, 1095, -1, 401, 14,
15, 16, 17, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 29, -1, 31, 32, 33, 34,
35, 36, 37, 38, 39, 40, -1, -1, 43, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 58, 59, -1, -1, 62, -1, -1,
-1, -1, 67, 68, 1153, -1, 2234, 370, 371, 372,
-1, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, -1, 388, 389, -1, -1, 392,
2258, -1, -1, -1, -1, -1, -1, -1, 401, -1,
2268, -1, 2270, 2271, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 1203, -1, -1, -1, -1, 124,
-1, -1, -1, -1, -1, -1, 2294, -1, 2296, 2297,
-1, -1, -1, 1222, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 2319, 2320, -1, -1, -1, -1, -1, -1, -1,
2328, -1, -1, -1, -1, -1, -1, 7, -1, -1,
2338, -1, -1, -1, 2342, -1, -1, -1, 2346, 2347,
-1, -1, 2350, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 2366, -1,
2368, 2369, 2370, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 2387,
2388, -1, -1, 2391, -1, 2393, 2394, -1, -1, -1,
2398, 2399, -1, 2401, -1, -1, -1, -1, -1, -1,
-1, -1, 2410, -1, 2412, 2413, 2414, 2415, 2416, 2417,
2418, 2419, 2420, 2421, 2422, 2423, -1, 262, -1, -1,
-1, 2429, 2430, 268, 2432, -1, 3, 4, 5, -1,
-1, -1, -1, 10, -1, 2443, 2444, 2445, 2446, 2447,
-1, 18, 19, 20, -1, -1, -1, -1, -1, 26,
27, 28, 29, 298, 299, 300, 301, 302, -1, -1,
-1, -1, -1, 7, -1, -1, -1, 1396, 45, 46,
47, -1, -1, 50, -1, 52, 53, 54, 55, 56,
-1, -1, -1, 60, -1, 62, -1, 64, 65, -1,
-1, -1, 69, 70, 71, 72, 73, 74, 75, 76,
77, 78, -1, -1, -1, -1, -1, 84, 85, 86,
87, 88, 89, 90, 91, 92, 93, 94, 95, 96,
97, 98, 99, 100, 101, 102, 103, 104, 105, 106,
107, 108, 109, -1, -1, -1, -1, -1, -1, -1,
1469, -1, -1, -1, -1, -1, -1, -1, -1, -1,
2558, -1, -1, 2561, 2562, 2563, 2564, -1, -1, -1,
-1, -1, -1, -1, 370, 371, 372, 373, 374, 375,
376, 377, -1, 2581, 380, 381, 382, 383, 384, 385,
386, 387, -1, -1, 1513, 2593, 392, -1, -1, -1,
396, 1520, 1521, 1522, 2602, 2603, -1, 2605, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 2615, 2616, 2617,
2618, -1, -1, 2621, -1, 2623, -1, 2625, -1, -1,
-1, 2629, -1, -1, -1, -1, 1555, -1, 2636, 2637,
-1, -1, -1, -1, -1, -1, 1565, -1, -1, -1,
-1, -1, -1, -1, 1573, -1, -1, -1, 1577, 1578,
2658, -1, 1581, 1582, 1583, -1, 7, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
2678, 1600, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 1612, 1613, -1, -1, -1, 1617, -1,
370, 371, 372, -1, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, 2715, 388, 389,
-1, -1, 392, -1, -1, -1, -1, -1, -1, -1,
-1, 401, 2730, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 2743, 2744, 2745, 2746, -1,
-1, -1, -1, 2751, 2752, 2753, -1, 2755, -1, -1,
-1, -1, 2760, 2761, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 2772, -1, 2774, -1, -1, 370,
371, 372, 2780, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, 2801, -1, 396, -1, -1, -1, -1,
401, -1, -1, 404, -1, -1, 383, -1, -1, -1,
-1, -1, -1, 390, -1, -1, 393, -1, -1, -1,
397, -1, -1, -1, 401, -1, 370, 371, 372, -1,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, 2859, 2860, 2861, -1, -1, 2864, 401, -1, 2867,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 2883, -1, 2885, 2886, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 2900, 2901, -1, -1, -1, -1, -1, 2907,
-1, -1, 2910, -1, -1, -1, -1, -1, -1, -1,
-1, 2919, -1, -1, -1, -1, 1845, -1, -1, -1,
-1, -1, -1, -1, -1, 7, -1, -1, -1, -1,
2938, 2939, -1, -1, -1, -1, -1, -1, 2946, -1,
-1, -1, -1, -1, -1, -1, -1, 2955, -1, -1,
-1, -1, -1, 7, -1, -1, -1, -1, -1, -1,
-1, -1, 2970, -1, -1, -1, -1, -1, 2976, -1,
2978, -1, -1, -1, -1, -1, -1, -1, -1, 2987,
-1, -1, -1, 2991, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 3005, -1, -1,
-1, 3009, -1, -1, -1, -1, 3014, 3015, -1, -1,
-1, 3019, -1, -1, -1, -1, -1, 3025, 3026, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, 370, 371, 372, 373, 374, 375, 376, 377,
401, -1, 380, 381, 382, 383, 384, 385, 386, 387,
-1, -1, -1, -1, 392, -1, -1, -1, 396, 3,
4, 5, 6, -1, -1, -1, 10, 2006, 12, 13,
-1, -1, -1, -1, 18, 19, 20, 21, 22, 23,
24, 25, 26, 27, 28, 29, 30, -1, -1, 2028,
-1, 2030, 2031, 2032, -1, 2034, -1, -1, -1, -1,
-1, 45, 46, 47, 48, -1, 50, -1, 52, 53,
54, 55, 56, -1, -1, -1, 60, 61, 62, 63,
64, 65, 66, -1, -1, 69, 70, 71, 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, 98, 99, 100, 101, 102, 103,
104, 105, 106, 107, 108, 109, -1, -1, -1, -1,
3, 4, 5, 6, -1, -1, -1, 10, 122, 12,
13, -1, 126, -1, -1, 18, 19, 20, 21, 22,
23, 24, 25, 26, 27, 28, 29, 30, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 45, 46, 47, 48, -1, 50, -1, 52,
53, 54, 55, 56, -1, -1, -1, 60, 61, 62,
63, 64, 65, 66, -1, -1, 69, 70, 71, 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, 98, 99, 100, 101, 102,
103, 104, 105, 106, 107, 108, 109, -1, 370, 371,
372, -1, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, 2234, 388, 389, -1, -1,
392, -1, -1, -1, -1, -1, 370, 371, 372, 401,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, 5, -1, -1, -1, -1, -1, 401, -1, -1,
14, 15, 16, 17, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 2293, 29, 2295, 31, 32, 33,
34, 35, 36, 37, 38, 39, 40, -1, -1, 43,
-1, -1, -1, -1, 8, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 58, 59, -1, -1, 62, -1,
-1, -1, -1, 67, 68, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 2343, 2344, -1, -1, 8, 2348,
-1, -1, -1, 2352, 5, -1, -1, -1, -1, 363,
364, 365, 366, -1, -1, -1, -1, 2366, -1, 2368,
2369, 2370, -1, -1, -1, 2374, -1, -1, 29, 383,
2379, 2380, 2381, 2382, -1, -1, 390, 2386, -1, 393,
124, 2390, -1, 397, -1, -1, 2395, 401, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 142, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 152, -1,
-1, -1, -1, -1, -1, 2424, 2425, -1, -1, 2428,
-1, -1, 2431, -1, 2433, -1, 87, 88, 89, 90,
91, 92, 93, 94, 95, 96, 97, 98, 99, 100,
101, 102, 103, 104, 105, 106, 107, 108, 109, -1,
-1, -1, 196, 197, 198, 199, 200, 201, -1, -1,
363, 364, 365, 366, -1, -1, -1, -1, -1, -1,
8, -1, -1, -1, -1, -1, -1, -1, -1, -1,
383, -1, -1, -1, -1, -1, -1, 390, -1, -1,
393, -1, -1, -1, 397, -1, -1, -1, 401, 2508,
-1, -1, 2511, 2512, 2513, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 8, -1, 262, -1,
-1, -1, -1, -1, 268, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 2544, 2545, -1, -1, -1,
-1, 3, 4, 5, 6, -1, -1, -1, 10, 2558,
12, 13, -1, -1, -1, 2564, 18, 19, 20, 21,
22, 23, 24, 25, 26, 27, 28, 29, 30, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 45, 46, 47, 48, -1, 50, -1,
52, 53, 54, 55, 56, -1, -1, -1, 60, 61,
62, 63, 64, 65, 66, -1, -1, 69, 70, 71,
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, 98, 99, 100, 101,
102, 103, 104, 105, 106, 107, 108, 109, -1, -1,
-1, -1, -1, -1, 398, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 370, 371, 372, 2678,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, 8, -1, 392, -1,
394, -1, -1, -1, -1, -1, -1, 401, -1, -1,
370, 371, 372, -1, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, 3, 4, 5, 6, -1, 398, -1,
10, 401, 12, 13, 2743, 2744, 2745, 2746, 18, 19,
20, 21, 22, 23, 24, 25, 26, 27, -1, 29,
30, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 2770, -1, -1, 2773, 45, 46, 47, 48, -1,
50, -1, -1, -1, -1, -1, -1, -1, -1, -1,
60, 61, 62, 63, 64, 65, 66, -1, -1, 69,
70, 71, 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, 98, 99,
100, 101, 102, 103, 104, 105, 106, 107, 108, 109,
-1, -1, 370, 371, 372, -1, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, 394, -1, -1, -1,
-1, 2870, 2871, 401, -1, -1, 2875, -1, -1, -1,
-1, -1, -1, 2882, 2883, -1, 2885, 2886, 370, 371,
372, -1, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, 363, 364, 365, 366, -1, -1, -1, -1, 401,
-1, -1, 2921, 2922, -1, -1, 2925, -1, -1, 2928,
-1, 383, -1, -1, -1, -1, -1, -1, 390, -1,
-1, 393, -1, -1, -1, 397, -1, 2946, -1, 401,
3, 4, 5, 6, 2953, 2954, -1, 10, -1, 12,
13, -1, -1, -1, -1, 18, 19, 20, 21, 22,
23, 24, 25, 26, 27, -1, 29, 30, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 45, 46, 47, 48, -1, 50, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 60, 61, 62,
63, 64, 65, 66, -1, -1, 69, 70, 71, 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, 98, 99, 100, 101, 102,
103, 104, 105, 106, 107, 108, 109, 369, 370, 371,
372, -1, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, -1, -1, 3, 4, 5, 401,
-1, -1, -1, 363, 364, 365, 366, -1, -1, -1,
-1, 18, 19, 20, -1, -1, -1, -1, -1, 26,
27, 28, 29, 383, -1, -1, -1, -1, -1, -1,
390, -1, -1, 393, -1, -1, -1, 397, 45, 46,
47, 401, -1, 50, -1, 52, 53, 54, 55, 56,
-1, -1, -1, 60, -1, 62, -1, 64, 65, -1,
-1, -1, 69, 70, 71, 72, 73, 74, 75, 76,
77, 78, -1, -1, -1, -1, -1, 84, 85, 86,
87, 88, 89, 90, 91, 92, 93, 94, 95, 96,
97, 98, 99, 100, 101, 102, 103, 104, 105, 106,
107, 108, 109, 3, 4, 5, -1, -1, -1, -1,
10, -1, -1, -1, -1, -1, -1, -1, 18, 19,
20, -1, -1, -1, -1, -1, 26, 27, 28, 29,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 45, 46, 47, -1, -1,
50, -1, 52, 53, 54, 55, 56, -1, -1, -1,
60, -1, 62, -1, 64, 65, -1, -1, -1, 69,
70, 71, 72, 73, 74, 75, 76, 77, 78, -1,
-1, -1, -1, -1, 84, 85, 86, 87, 88, 89,
90, 91, 92, 93, 94, 95, 96, 97, 98, 99,
100, 101, 102, 103, 104, 105, 106, 107, 108, 109,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
363, 364, 365, 366, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
383, -1, -1, -1, -1, -1, -1, 390, -1, -1,
393, -1, 5, -1, 397, -1, -1, -1, 401, -1,
-1, 14, 15, 16, 17, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, -1, -1,
43, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 58, 59, -1, 315, 62,
-1, -1, 319, 8, 67, 68, -1, -1, 325, -1,
-1, 370, 371, 372, -1, 374, 375, 376, 377, 378,
379, 380, 381, 382, 383, 384, 385, 386, -1, 388,
389, -1, -1, 392, -1, -1, -1, 396, -1, 3,
4, 5, 401, -1, -1, 404, -1, -1, -1, -1,
-1, -1, -1, -1, 18, 19, 20, -1, -1, -1,
-1, 124, 26, 27, 28, 29, 383, -1, -1, -1,
-1, -1, -1, 390, -1, -1, 393, -1, -1, 142,
397, 45, 46, 47, 401, -1, 50, -1, 52, 53,
54, 55, 56, -1, -1, -1, 60, -1, 62, -1,
64, 65, -1, -1, 167, 69, 70, 71, 72, 73,
74, 75, 76, 77, 78, -1, -1, -1, -1, -1,
84, 85, 86, 87, 88, 89, 90, 91, 92, 93,
94, 95, 96, 97, 98, 99, 100, 101, 102, 103,
104, 105, 106, 107, 108, 109, -1, -1, -1, -1,
-1, 3, 4, 5, -1, -1, -1, -1, -1, -1,
-1, -1, 126, -1, -1, -1, 18, 19, 20, -1,
-1, -1, -1, 383, 26, 27, 28, 29, -1, -1,
390, -1, -1, 393, -1, -1, -1, 397, -1, -1,
-1, 401, -1, 45, 46, 47, -1, -1, 50, 262,
52, 53, 54, 55, 56, 268, -1, -1, 60, -1,
62, -1, 64, 65, -1, -1, -1, 69, 70, 71,
72, 73, 74, 75, 76, 77, 78, -1, -1, -1,
-1, -1, 84, 85, 86, 87, 88, 89, 90, 91,
92, 93, 94, 95, 96, 97, 98, 99, 100, 101,
102, 103, 104, 105, 106, 107, 108, 109, 3, 4,
5, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 18, 19, 20, -1, -1, -1, -1,
-1, 26, 27, 28, 29, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
45, 46, 47, -1, -1, 50, -1, 52, 53, 54,
55, 56, -1, -1, -1, 60, -1, 62, -1, 64,
65, -1, -1, -1, 69, 70, 71, 72, 73, 74,
75, 76, 77, 78, 397, 398, -1, -1, -1, 84,
85, 86, 87, 88, 89, 90, 91, 92, 93, 94,
95, 96, 97, 98, 99, 100, 101, 102, 103, 104,
105, 106, 107, 108, 109, 370, 371, 372, -1, 374,
375, 376, 377, 378, 379, 380, 381, 382, 383, 384,
385, 386, -1, 388, 389, -1, -1, 392, -1, -1,
-1, -1, 3, 4, 5, -1, 401, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 18, 19, 20,
-1, -1, -1, -1, -1, 26, 27, 28, 29, 383,
-1, -1, -1, -1, -1, -1, 390, -1, -1, 393,
-1, -1, -1, 397, 45, 46, 47, 401, -1, 50,
-1, 52, 53, 54, 55, 56, -1, -1, -1, 60,
-1, 62, -1, 64, 65, -1, -1, -1, 69, 70,
71, 72, 73, 74, 75, 76, 77, 78, -1, -1,
-1, -1, -1, 84, 85, 86, 87, 88, 89, 90,
91, 92, 93, 94, 95, 96, 97, 98, 99, 100,
101, 102, 103, 104, 105, 106, 107, 108, 109, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 3,
4, 5, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 18, 19, 20, -1, -1, -1,
-1, 383, 26, 27, 28, 29, -1, -1, 390, -1,
-1, 393, -1, -1, -1, 397, 398, -1, -1, 401,
-1, 45, 46, 47, -1, -1, 50, -1, 52, 53,
54, 55, 56, -1, -1, -1, 60, -1, 62, -1,
64, 65, -1, -1, -1, 69, 70, 71, 72, 73,
74, 75, 76, 77, 78, -1, -1, -1, -1, -1,
84, 85, 86, 87, 88, 89, 90, 91, 92, 93,
94, 95, 96, 97, 98, 99, 100, 101, 102, 103,
104, 105, 106, 107, 108, 109, 3, 4, 5, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 18, 19, 20, -1, -1, -1, -1, 383, 26,
27, 28, 29, -1, -1, 390, -1, -1, 393, 394,
-1, -1, -1, -1, -1, -1, 401, -1, 45, 46,
47, -1, -1, 50, -1, 52, 53, 54, 55, 56,
-1, -1, -1, 60, -1, 62, -1, 64, 65, -1,
-1, -1, 69, 70, 71, 72, 73, 74, 75, 76,
77, 78, -1, -1, -1, -1, -1, 84, 85, 86,
87, 88, 89, 90, 91, 92, 93, 94, 95, 96,
97, 98, 99, 100, 101, 102, 103, 104, 105, 106,
107, 108, 109, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 3, 4, 5, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
18, 19, 20, -1, -1, -1, -1, -1, 26, 27,
28, 29, 383, -1, -1, -1, -1, -1, -1, 390,
-1, -1, 393, -1, -1, -1, 397, 45, 46, 47,
401, -1, 50, -1, 52, 53, 54, 55, 56, -1,
-1, -1, 60, -1, 62, -1, 64, 65, -1, -1,
-1, 69, 70, 71, 72, 73, 74, 75, 76, 77,
78, -1, -1, -1, -1, -1, 84, 85, 86, 87,
88, 89, 90, 91, 92, 93, 94, 95, 96, 97,
98, 99, 100, 101, 102, 103, 104, 105, 106, 107,
108, 109, -1, -1, -1, -1, -1, -1, -1, 3,
4, 5, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 18, 19, 20, -1, -1, -1,
-1, -1, 26, 27, 28, 29, -1, -1, -1, 383,
-1, -1, -1, -1, -1, -1, 390, -1, -1, 393,
-1, 45, 46, 47, 398, -1, 50, 401, 52, 53,
54, 55, 56, -1, -1, -1, 60, -1, 62, -1,
64, 65, -1, -1, -1, 69, 70, 71, 72, 73,
74, 75, 76, 77, 78, -1, -1, -1, -1, -1,
84, 85, 86, 87, 88, 89, 90, 91, 92, 93,
94, 95, 96, 97, 98, 99, 100, 101, 102, 103,
104, 105, 106, 107, 108, 109, -1, -1, -1, 3,
4, 5, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 18, 19, 20, -1, -1, -1,
-1, -1, 26, 27, 28, 29, 383, -1, -1, -1,
-1, -1, -1, 390, -1, -1, 393, -1, -1, -1,
397, 45, 46, 47, 401, -1, 50, -1, 52, 53,
54, 55, 56, -1, -1, -1, 60, -1, 62, -1,
64, 65, -1, -1, -1, 69, 70, 71, 72, 73,
74, 75, 76, 77, 78, -1, -1, -1, -1, -1,
84, 85, 86, 87, 88, 89, 90, 91, 92, 93,
94, 95, 96, 97, 98, 99, 100, 101, 102, 103,
104, 105, 106, 107, 108, 109, -1, -1, -1, 3,
4, 5, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 18, 19, 20, -1, -1, -1,
-1, -1, 26, 27, -1, 29, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 45, 46, 47, -1, 383, 50, -1, -1, -1,
-1, -1, 390, -1, -1, 393, 60, -1, 62, 397,
64, 65, -1, 401, -1, 69, 70, 71, 72, 73,
74, 75, 76, 77, 78, -1, -1, -1, -1, -1,
84, 85, 86, 87, 88, 89, 90, 91, 92, 93,
94, 95, 96, 97, 98, 99, 100, 101, 102, 103,
104, 105, 106, 107, 108, 109, -1, -1, -1, -1,
-1, -1, -1, 3, 4, 5, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 18, 19,
20, -1, -1, -1, -1, -1, 26, 27, -1, 29,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 45, 46, 47, -1, 383,
50, -1, -1, -1, -1, -1, 390, -1, -1, 393,
60, -1, 62, 397, 64, 65, -1, 401, -1, 69,
70, 71, 72, 73, 74, 75, 76, 77, 78, -1,
-1, -1, -1, -1, 84, 85, 86, 87, 88, 89,
90, 91, 92, 93, 94, 95, 96, 97, 98, 99,
100, 101, 102, 103, 104, 105, 106, 107, 108, 109,
-1, -1, -1, 3, 4, 5, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 18, 19,
20, -1, -1, -1, -1, -1, 26, 27, -1, 29,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 45, 46, 47, -1, 383,
50, -1, -1, -1, -1, -1, 390, -1, -1, 393,
60, -1, 62, -1, 64, 65, -1, 401, -1, 69,
70, 71, 72, 73, 74, 75, 76, 77, 78, -1,
-1, -1, -1, -1, 84, 85, 86, 87, 88, 89,
90, 91, 92, 93, 94, 95, 96, 97, 98, 99,
100, 101, 102, 103, 104, 105, 106, 107, 108, 109,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 3, 4, 5, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 18, 19, 20, -1,
-1, -1, -1, -1, 26, 27, -1, 29, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 383,
-1, -1, -1, 45, 46, 47, 390, -1, 50, 393,
394, -1, -1, 397, -1, -1, -1, 401, 60, -1,
62, -1, 64, 65, -1, -1, -1, 69, 70, 71,
72, 73, 74, 75, 76, 77, 78, -1, -1, -1,
-1, -1, 84, 85, 86, 87, 88, 89, 90, 91,
92, 93, 94, 95, 96, 97, 98, 99, 100, 101,
102, 103, 104, 105, 106, 107, 108, 109, 3, 4,
5, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 18, 19, 20, -1, -1, -1, -1,
-1, 26, 27, -1, 29, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
45, 46, 47, 383, -1, 50, -1, -1, -1, -1,
390, -1, -1, 393, 394, 60, -1, 62, -1, 64,
65, 401, -1, -1, 69, 70, 71, 72, 73, 74,
75, 76, 77, 78, -1, -1, -1, -1, -1, 84,
85, 86, 87, 88, 89, 90, 91, 92, 93, 94,
95, 96, 97, 98, 99, 100, 101, 102, 103, 104,
105, 106, 107, 108, 109, -1, -1, -1, 3, 4,
5, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 18, 19, 20, -1, -1, -1, -1,
-1, 26, 27, -1, 29, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
45, 46, 47, 383, -1, 50, -1, -1, -1, -1,
390, -1, -1, 393, 394, 60, -1, 62, -1, 64,
65, 401, -1, -1, 69, 70, 71, 72, 73, 74,
75, 76, 77, 78, -1, -1, -1, -1, -1, 84,
85, 86, 87, 88, 89, 90, 91, 92, 93, 94,
95, 96, 97, 98, 99, 100, 101, 102, 103, 104,
105, 106, 107, 108, 109, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 3, 4, 5, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 18, 19, 20, -1, -1, -1, -1, -1, 26,
27, -1, 29, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 45, 46,
47, 383, -1, 50, -1, -1, -1, -1, 390, -1,
-1, 393, 394, 60, -1, 62, -1, 64, 65, 401,
8, -1, 69, 70, 71, 72, 73, 74, 75, 76,
77, 78, 197, -1, -1, -1, -1, 84, 85, 86,
87, 88, 89, 90, 91, 92, 93, 94, 95, 96,
97, 98, 99, 100, 101, 102, 103, 104, 105, 106,
107, 108, 109, 3, 4, 5, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 18, 19,
20, -1, -1, -1, -1, -1, 26, 27, -1, 29,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 45, 46, 47, 383, -1,
50, -1, -1, -1, -1, 390, -1, -1, 393, 394,
60, -1, 62, -1, 64, 65, 401, -1, -1, 69,
70, 71, 72, 73, 74, 75, 76, 77, 78, -1,
-1, -1, -1, -1, 84, 85, 86, 87, 88, 89,
90, 91, 92, 93, 94, 95, 96, 97, 98, 99,
100, 101, 102, 103, 104, 105, 106, 107, 108, 109,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 5, -1, -1, -1, -1, -1, -1, -1, -1,
14, 15, 16, 17, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 29, -1, 31, 32, 33,
34, 35, 36, 37, 38, 39, 40, -1, 383, 43,
-1, -1, -1, -1, -1, 390, -1, -1, 393, -1,
-1, -1, -1, -1, 58, 59, 401, -1, 62, -1,
-1, -1, -1, 67, 68, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 5,
-1, -1, -1, -1, -1, -1, -1, -1, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, 5,
124, -1, -1, -1, -1, -1, -1, -1, 14, 15,
16, 17, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 8, 383, 43, -1, -1,
-1, -1, -1, 390, -1, -1, 393, -1, -1, 173,
397, -1, 58, 59, 401, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 124, -1,
-1, -1, 370, 371, 372, -1, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, -1, -1,
-1, 117, -1, 401, -1, -1, -1, -1, 124, 125,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 142, -1, 262, -1,
-1, -1, -1, 383, 268, -1, 152, 153, -1, -1,
390, -1, -1, 393, -1, 161, -1, 163, 204, 205,
206, 401, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, 262, 303, 14, 15,
16, 17, 268, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, 398, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 5, -1, -1,
-1, -1, -1, -1, -1, -1, 14, 15, 16, 17,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 29, 398, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, -1, 124, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
58, 59, -1, -1, 62, -1, -1, -1, -1, 67,
68, -1, 398, -1, -1, -1, -1, 370, 371, 372,
-1, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, -1, 388, 389, -1, -1, 392,
-1, -1, -1, -1, -1, -1, -1, -1, 401, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 119, -1, -1, -1, -1, 124, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, 262, -1, -1, -1, -1, -1,
268, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 8, -1, -1, 5, -1, -1,
-1, -1, -1, -1, -1, -1, 14, 15, 16, 17,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 29, 398, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, -1, 124, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
58, 59, 5, -1, 62, -1, -1, -1, -1, 67,
68, 14, 15, 16, 17, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, -1, -1,
43, -1, -1, -1, -1, -1, -1, -1, -1, -1,
398, -1, -1, -1, -1, 58, 59, -1, -1, 62,
-1, -1, -1, -1, 67, 68, 124, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, 124, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, 262, -1, -1, -1, -1, -1,
268, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, 8,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 5, -1, -1, -1, -1, -1, -1, -1,
-1, 14, 15, 16, 17, -1, -1, -1, -1, 262,
-1, -1, 398, -1, -1, 268, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, 124, -1,
43, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 58, 59, -1, -1, 62,
-1, -1, -1, -1, 67, 68, 370, 371, 372, -1,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, -1, -1, -1, -1, -1, 401, -1, 397,
398, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 204, 205,
206, 124, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, 397, 398, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 262,
-1, -1, 58, 59, -1, 268, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 5, -1, -1,
-1, -1, -1, -1, -1, -1, 14, 15, 16, 17,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 29, 398, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, -1, 124, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
58, 59, -1, -1, 62, -1, -1, -1, -1, 67,
68, 370, 371, 372, -1, 374, 375, 376, 377, 378,
379, 380, 381, 382, 383, 384, 385, 386, -1, 388,
389, -1, -1, 392, -1, -1, -1, -1, -1, -1,
-1, -1, 401, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 397, 398, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 124, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, 262, -1, -1, -1, -1, -1,
268, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 5, -1, -1,
-1, -1, -1, -1, -1, -1, 14, 15, 16, 17,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 29, 398, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, -1, 124, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
58, 59, -1, -1, 62, -1, -1, -1, -1, 67,
68, 370, 371, 372, -1, 374, 375, 376, 377, 378,
379, 380, 381, 382, 383, 384, 385, 386, -1, 388,
389, -1, -1, 392, -1, -1, -1, -1, -1, -1,
-1, -1, 401, -1, -1, 404, -1, -1, -1, 397,
398, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 123, 124, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, 262, -1, -1, -1, -1, -1,
268, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 5, -1, -1,
-1, -1, -1, -1, -1, -1, 14, 15, 16, 17,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 29, 398, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, -1, 124, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
58, 59, 5, -1, 62, -1, -1, -1, -1, 67,
68, 14, 15, 16, 17, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, -1, -1,
43, -1, -1, -1, -1, -1, -1, -1, -1, -1,
398, -1, -1, -1, -1, 58, 59, -1, -1, 62,
-1, -1, -1, -1, 67, 68, 124, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, 124, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, 262, -1, -1, -1, -1, -1,
268, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, 369, 370, 371, 372, -1, 374,
375, 376, 377, 378, 379, 380, 381, 382, 383, 384,
385, 386, 5, 388, 389, -1, -1, 392, -1, -1,
-1, 14, 15, 16, 17, -1, 401, -1, -1, 262,
-1, -1, 398, -1, -1, 268, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, 124, -1,
43, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 58, 59, -1, -1, 62,
-1, -1, -1, -1, 67, 68, -1, 370, 371, 372,
-1, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, -1, 388, 389, -1, -1, 392,
-1, -1, -1, -1, -1, -1, -1, -1, 401, 397,
398, 404, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 204, 205,
206, 124, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, 397, 398, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 262,
-1, -1, 58, 59, -1, 268, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 5, -1, -1,
-1, -1, -1, -1, -1, -1, 14, 15, 16, 17,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 29, 398, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, 5, 124, -1,
-1, -1, -1, -1, -1, -1, 14, 15, 16, 17,
58, 59, -1, -1, 62, -1, -1, -1, -1, 67,
68, 29, -1, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
58, 59, -1, -1, 62, -1, -1, -1, -1, 67,
68, -1, -1, -1, 397, 398, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 124, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, 124, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, 262, -1, -1, -1, -1, -1,
268, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 5, -1, -1,
-1, -1, -1, -1, 262, -1, 14, 15, 16, 17,
268, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 29, 398, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, -1, 124, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
58, 59, 5, -1, 62, -1, -1, -1, -1, 67,
68, 14, 15, 16, 17, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, -1, -1,
43, -1, -1, -1, -1, -1, -1, -1, -1, 397,
398, -1, -1, -1, -1, 58, 59, -1, -1, 62,
-1, -1, -1, -1, 67, 68, 124, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, 124, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, 262, -1, -1, -1, -1, -1,
268, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, 370, 371, 372, -1, 374,
375, 376, 377, 378, 379, 380, 381, 382, 383, 384,
385, 386, 5, 388, 389, -1, -1, 392, -1, 394,
-1, 14, 15, 16, 17, -1, 401, -1, -1, 262,
-1, -1, 398, -1, -1, 268, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, 124, -1,
43, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 58, 59, -1, -1, 62,
-1, -1, -1, -1, 67, 68, -1, 370, 371, 372,
-1, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, -1, 388, 389, -1, -1, 392,
-1, -1, -1, -1, -1, -1, -1, -1, 401, 397,
398, 404, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 204, 205,
206, 124, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, 397, 398, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 262,
-1, -1, 58, 59, -1, 268, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 5, -1, -1,
-1, -1, -1, -1, -1, -1, 14, 15, 16, 17,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 29, 398, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, -1, 124, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
58, 59, -1, -1, 62, -1, -1, -1, -1, 67,
68, 370, 371, 372, -1, 374, 375, 376, 377, 378,
379, 380, 381, 382, 383, 384, 385, 386, -1, 388,
389, -1, -1, 392, -1, -1, -1, -1, -1, -1,
-1, -1, 401, -1, -1, 404, -1, -1, -1, -1,
-1, -1, -1, -1, 397, 398, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 124, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, 262, -1, -1, -1, -1, -1,
268, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 5, -1, -1,
-1, -1, -1, -1, -1, -1, 14, 15, 16, 17,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 29, 398, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, -1, 124, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
58, 59, 5, -1, 62, -1, -1, -1, -1, 67,
68, 14, 15, 16, 17, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, -1, -1,
43, -1, -1, -1, -1, -1, -1, -1, -1, 397,
398, -1, -1, -1, -1, 58, 59, -1, -1, 62,
-1, -1, -1, -1, 67, 68, 124, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, 124, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, 262, -1, -1, -1, -1, -1,
268, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, 370, 371, 372, -1, 374,
375, 376, 377, 378, 379, 380, 381, 382, 383, 384,
385, 386, 5, 388, 389, -1, -1, 392, -1, 394,
-1, 14, 15, 16, 17, -1, 401, -1, -1, 262,
-1, -1, 398, -1, -1, 268, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, 124, -1,
43, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 58, 59, -1, -1, 62,
-1, -1, -1, -1, 67, 68, -1, 370, 371, 372,
-1, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, -1, 388, 389, -1, -1, 392,
-1, -1, -1, -1, -1, -1, -1, -1, 401, 397,
398, 404, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 204, 205,
206, 124, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, 397, 398, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 262,
-1, -1, 58, 59, -1, 268, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 5, -1, -1,
-1, -1, -1, -1, -1, -1, 14, 15, 16, 17,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 29, 398, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, -1, 124, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
58, 59, -1, -1, 62, -1, -1, -1, -1, 67,
68, 370, 371, 372, -1, 374, 375, 376, 377, 378,
379, 380, 381, 382, 383, 384, 385, 386, -1, 388,
389, -1, -1, 392, -1, -1, -1, -1, -1, -1,
-1, -1, 401, -1, -1, 404, -1, -1, -1, -1,
-1, -1, -1, -1, 397, 398, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 124, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, 262, -1, -1, -1, -1, -1,
268, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 5, -1, -1,
-1, -1, -1, -1, -1, -1, 14, 15, 16, 17,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 29, 398, 31, 32, 33, 34, 35, 36, 37,
38, 39, 40, -1, -1, 43, -1, -1, 124, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
58, 59, 5, -1, 62, -1, -1, -1, -1, 67,
68, 14, 15, 16, 17, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, -1, -1,
43, -1, -1, -1, -1, -1, -1, -1, -1, 397,
398, -1, -1, -1, -1, 58, 59, -1, -1, 62,
-1, -1, -1, -1, 67, 68, 124, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, 124, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, 262, -1, -1, -1, -1, -1,
268, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, -1, -1, 370, 371, 372, -1, 374,
375, 376, 377, 378, 379, 380, 381, 382, 383, 384,
385, 386, 5, 388, 389, -1, -1, 392, -1, 394,
-1, 14, 15, 16, 17, -1, 401, -1, -1, 262,
-1, -1, 398, -1, -1, 268, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, 124, -1,
43, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 58, 59, -1, -1, 62,
-1, -1, -1, -1, 67, 68, -1, 370, 371, 372,
-1, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, -1, 388, 389, -1, -1, 392,
-1, -1, -1, -1, -1, -1, -1, -1, 401, 397,
398, 404, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 204, 205,
206, 124, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, 397, 398, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 262,
-1, -1, 58, 59, -1, 268, 62, -1, 5, 6,
-1, 67, 68, 10, -1, 12, 13, -1, -1, -1,
-1, -1, -1, -1, 21, 22, 23, 24, 25, -1,
-1, -1, 29, 30, -1, -1, -1, 5, 6, -1,
-1, -1, 10, -1, 12, 13, -1, -1, -1, -1,
-1, 48, 398, 21, 22, 23, 24, 25, -1, -1,
-1, 29, 30, -1, 61, -1, 63, -1, 124, 66,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
48, -1, 79, 80, 81, 82, 83, -1, -1, -1,
-1, -1, -1, 61, -1, 63, -1, -1, 66, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 79, 80, 81, 82, 83, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 397, 398, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 58, 59, -1, -1, 62, -1, 5, 6,
-1, 67, 68, 10, -1, 12, 13, -1, -1, -1,
-1, -1, -1, -1, 21, 22, 23, 24, 25, -1,
-1, -1, -1, 30, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 48, 398, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 61, -1, 63, -1, 124, 66,
-1, -1, -1, -1, -1, -1, 363, 364, 365, 366,
-1, -1, 79, 80, 81, 82, 83, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, 363, 364, 365, 366, -1,
397, 370, 371, 372, -1, 374, 375, 376, 377, 378,
379, 380, 381, 382, 383, 384, 385, 386, -1, 388,
389, -1, -1, 392, -1, -1, -1, -1, -1, -1,
-1, -1, 401, -1, -1, 404, -1, -1, 204, 205,
206, -1, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, -1, 250, 251, 252, 253, 254, 255,
256, -1, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, 5,
-1, -1, -1, 299, -1, -1, -1, 303, 14, 15,
16, 17, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 58, 59, 5, -1, 62, -1, -1, -1,
-1, 67, 68, 14, 15, 16, 17, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 29, -1,
31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
-1, -1, 43, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 398, -1, -1, -1, -1, 58, 59, -1,
-1, 62, -1, -1, -1, -1, 67, 68, 124, -1,
-1, -1, -1, -1, -1, -1, 363, 364, 365, 366,
370, 371, 372, -1, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, -1, -1, -1, -1,
-1, 401, -1, -1, 404, -1, 117, -1, -1, -1,
-1, -1, -1, 124, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 204, 205,
206, 152, 208, 209, 210, 211, 212, 213, 214, 215,
216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235,
236, 237, 238, 239, -1, -1, -1, -1, -1, 245,
246, 247, -1, 194, 250, 251, 252, 253, 254, 255,
256, 202, -1, 259, -1, 261, 262, 263, 264, 265,
266, 267, 268, 269, 270, 271, 272, 273, 274, 275,
276, 277, 278, 279, 280, 281, 282, 283, 284, 285,
286, 287, 288, 289, 290, -1, -1, -1, 294, -1,
-1, -1, -1, 299, 5, -1, -1, 303, -1, -1,
-1, -1, -1, 14, 15, 16, 17, -1, -1, -1,
-1, 262, -1, -1, -1, -1, -1, 268, 29, -1,
31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
-1, -1, 43, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 295, -1, 297, 58, 59, -1,
-1, 62, -1, -1, -1, -1, 67, 68, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 325, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 398, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 353, -1, 355, 356, 117, -1, -1, 360,
361, -1, -1, 124, -1, -1, 367, -1, -1, -1,
-1, -1, -1, -1, -1, 5, -1, -1, -1, -1,
-1, -1, -1, -1, 14, 15, 16, 17, -1, -1,
-1, 152, -1, -1, -1, -1, -1, 398, -1, 29,
-1, 31, 32, 33, 34, 35, 36, 37, 38, 39,
40, -1, -1, 43, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 58, 59,
-1, -1, 62, 194, 195, 5, -1, 67, 68, -1,
-1, 202, -1, -1, 14, 15, 16, 17, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 29,
-1, 31, 32, 33, 34, 35, 36, 37, 38, 39,
40, -1, -1, 43, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 117, 58, 59,
-1, -1, 62, -1, 124, -1, -1, 67, 68, -1,
-1, 262, 5, -1, -1, -1, -1, 268, -1, -1,
-1, 14, 15, 16, 17, -1, -1, -1, -1, -1,
-1, -1, 152, -1, -1, -1, 29, -1, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, -1, 169,
43, -1, -1, -1, -1, -1, -1, 117, -1, -1,
-1, -1, -1, -1, 124, 58, 59, -1, -1, 62,
-1, -1, -1, -1, 67, 68, 196, -1, -1, 139,
-1, -1, -1, -1, 144, -1, -1, -1, -1, 370,
371, 372, 152, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 117, -1, -1, -1, -1, -1,
-1, 124, -1, -1, 5, -1, -1, -1, -1, -1,
-1, -1, 262, 14, 15, 16, 17, 398, 268, 142,
5, -1, -1, -1, -1, -1, -1, -1, 29, 152,
31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
-1, -1, 43, 293, -1, -1, 169, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 58, 59, 5,
-1, 62, -1, -1, -1, -1, 67, 68, 14, 15,
16, 17, 262, -1, -1, -1, -1, -1, 268, -1,
-1, -1, -1, 29, -1, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, -1, -1, 43, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, 58, 59, -1, -1, 62, -1, -1, -1,
-1, 67, 68, 124, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 262,
-1, -1, -1, -1, -1, 268, -1, -1, 398, 134,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 152, -1, -1,
-1, 117, 173, 174, 175, 176, -1, -1, 124, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 139, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, 152, -1, 398, -1,
-1, -1, -1, 198, -1, -1, -1, -1, -1, -1,
-1, 370, 371, 372, 209, 374, 375, 376, 377, 378,
379, 380, 381, 382, 383, 384, 385, 386, -1, 388,
389, -1, -1, 392, -1, -1, -1, -1, -1, -1,
-1, -1, 401, -1, -1, 404, -1, -1, -1, -1,
-1, 262, -1, -1, -1, -1, -1, 268, -1, -1,
-1, -1, -1, -1, 259, 398, 370, 371, 372, -1,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, -1, -1, -1, -1, -1, 401, -1, -1,
404, -1, -1, -1, -1, -1, 262, -1, -1, 304,
-1, -1, 268, -1, -1, -1, -1, -1, -1, -1,
315, 316, 317, 318, 319, 320, 321, 322, 323, 324,
325, -1, -1, 328, 329, 330, 331, 332, 333, 334,
335, 336, 337, 338, 339, 340, 341, 342, 343, 344,
345, 346, 347, 348, 349, 350, 351, 352, 353, 354,
355, 356, 357, 358, 359, 360, 361, 362, 5, -1,
-1, -1, 367, 368, -1, -1, -1, 14, 15, 16,
17, -1, -1, -1, -1, -1, -1, 398, -1, -1,
-1, -1, 29, -1, 31, 32, 33, 34, 35, 36,
37, 38, 39, 40, -1, -1, 43, -1, -1, -1,
-1, -1, 49, -1, -1, -1, -1, -1, -1, -1,
-1, 58, 59, -1, -1, 62, -1, -1, -1, -1,
67, 68, -1, -1, -1, -1, -1, -1, -1, 370,
371, 372, 398, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, -1, -1, -1, -1, -1, -1,
-1, 118, -1, -1, -1, -1, -1, 124, 125, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, 138, -1, -1, 141, -1, -1, -1, -1, -1,
-1, -1, -1, -1, 151, -1, -1, -1, 155, -1,
-1, -1, -1, -1, -1, -1, -1, -1, 370, 371,
372, 168, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, -1, -1, 193, -1, -1, 401,
-1, -1, 404, 370, 371, 372, -1, 374, 375, 376,
377, 378, 379, 380, 381, 382, 383, 384, 385, 386,
-1, 388, 389, -1, -1, 392, -1, -1, -1, -1,
-1, -1, -1, -1, 401, -1, -1, 404, 370, 371,
372, -1, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, -1, 262, -1, -1, -1, 401,
-1, 268, 404, -1, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, 292, 392, 294, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, -1, -1, -1, 401, -1, -1, 404, 370,
371, 372, -1, 374, 375, 376, 377, 378, 379, 380,
381, 382, 383, 384, 385, 386, -1, 388, 389, -1,
-1, 392, -1, -1, -1, -1, -1, -1, -1, -1,
401, -1, -1, 404, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, 394, -1,
396, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, -1, -1,
398, -1, -1, 401, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, 394, -1,
-1, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, 394, -1, -1, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, -1, -1, 398, -1,
-1, 401, 370, 371, 372, -1, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, -1, -1,
398, -1, -1, 401, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
396, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, 396, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, 396, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, 396, -1, 370, 371, 372, 401,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, 396, -1, 370, 371, 372, 401, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
396, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, 396, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, 396, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, 396, -1, 370, 371, 372, 401,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, 396, -1, 370, 371, 372, 401, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
396, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, 396, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, 396, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, 396, -1, 370, 371, 372, 401,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, 396, -1, 370, 371, 372, 401, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
396, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, 396, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, 396, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, 396, -1, 370, 371, 372, 401,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
394, -1, -1, -1, 370, 371, 372, 401, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
396, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, 394, -1, -1, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, -1, -1, 398, -1,
-1, 401, 370, 371, 372, -1, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, 396, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, 396, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, 396, -1, 370, 371, 372, 401,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, 396, -1, 370, 371, 372, 401, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
396, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, 394, -1, -1, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, 394, -1, -1, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, -1, -1, 398, -1, -1, 401,
370, 371, 372, -1, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, -1, -1, 398, -1,
-1, 401, 370, 371, 372, -1, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, 396, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, 396, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, 396, -1, 370, 371, 372, 401,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, -1, -1, 398, -1, -1, 401, 370, 371,
372, -1, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, -1, -1, 398, -1, -1, 401,
370, 371, 372, -1, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, 396, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, 394, -1, -1, -1, 370, 371, 372, 401,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, 396, -1, 370, 371, 372, 401, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
396, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, 396, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, 396, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, 396, -1, 370, 371, 372, 401,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, 396, -1, 370, 371, 372, 401, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
396, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, 396, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, 396, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, 394, -1, -1, -1, 370, 371, 372, 401,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, -1, -1, 398, -1, -1, 401, 370, 371,
372, -1, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, -1, -1, 398, -1, -1, 401,
370, 371, 372, -1, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, 396, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, 396, -1, 370, 371, 372, 401,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, 396, -1, 370, 371, 372, 401, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
396, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, 396, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, -1, -1, 398, -1,
-1, 401, 370, 371, 372, -1, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, -1, -1,
398, -1, -1, 401, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
396, -1, 370, 371, 372, 401, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, -1, -1,
398, -1, -1, 401, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, 398, -1, -1, 401, 370, 371, 372, -1,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, -1, -1, 398, -1, -1, 401, 370, 371,
372, -1, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, -1, -1, 398, -1, -1, 401,
370, 371, 372, -1, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, 396, -1, 370, 371,
372, 401, 374, 375, 376, 377, 378, 379, 380, 381,
382, 383, 384, 385, 386, -1, 388, 389, -1, -1,
392, -1, -1, -1, -1, -1, 398, -1, -1, 401,
370, 371, 372, -1, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, -1, -1, 398, -1,
-1, 401, 370, 371, 372, -1, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, 396, -1,
370, 371, 372, 401, 374, 375, 376, 377, 378, 379,
380, 381, 382, 383, 384, 385, 386, -1, 388, 389,
-1, -1, 392, -1, -1, -1, -1, -1, 398, -1,
-1, 401, 370, 371, 372, -1, 374, 375, 376, 377,
378, 379, 380, 381, 382, 383, 384, 385, 386, -1,
388, 389, -1, -1, 392, -1, -1, -1, -1, -1,
398, -1, -1, 401, 370, 371, 372, -1, 374, 375,
376, 377, 378, 379, 380, 381, 382, 383, 384, 385,
386, -1, 388, 389, -1, -1, 392, -1, -1, -1,
-1, -1, 398, -1, -1, 401, 370, 371, 372, -1,
374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
384, 385, 386, -1, 388, 389, -1, -1, 392, -1,
-1, -1, -1, -1, -1, -1, -1, 401
};
/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
symbol of state STATE-NUM. */
static const yytype_uint16 yystos[] =
{
0, 407, 408, 0, 409, 410, 5, 14, 15, 16,
17, 29, 31, 32, 33, 34, 35, 36, 37, 38,
39, 40, 43, 49, 58, 59, 62, 67, 68, 118,
124, 125, 138, 141, 151, 155, 168, 193, 262, 268,
292, 294, 411, 583, 596, 597, 599, 620, 628, 629,
399, 393, 395, 7, 395, 393, 629, 393, 393, 5,
6, 10, 12, 13, 21, 22, 23, 24, 25, 30,
48, 61, 63, 66, 79, 80, 81, 82, 83, 363,
364, 365, 366, 630, 640, 595, 629, 630, 393, 393,
395, 638, 622, 629, 630, 633, 395, 395, 622, 638,
638, 397, 395, 397, 397, 397, 397, 397, 397, 397,
393, 62, 395, 629, 397, 393, 397, 644, 401, 629,
638, 7, 399, 369, 382, 383, 393, 397, 629, 629,
633, 3, 4, 18, 19, 20, 26, 27, 45, 46,
47, 50, 60, 64, 65, 69, 70, 71, 72, 73,
74, 75, 76, 77, 78, 84, 85, 86, 87, 88,
89, 90, 91, 92, 93, 94, 95, 96, 97, 98,
99, 100, 101, 102, 103, 104, 105, 106, 107, 108,
109, 383, 390, 393, 401, 615, 616, 620, 622, 641,
642, 191, 615, 615, 638, 638, 638, 638, 638, 395,
395, 395, 395, 393, 395, 638, 638, 638, 638, 638,
638, 7, 615, 633, 393, 400, 9, 608, 612, 644,
633, 633, 412, 434, 472, 455, 462, 479, 430, 500,
526, 633, 7, 629, 7, 568, 117, 643, 579, 629,
7, 7, 630, 397, 28, 52, 53, 54, 55, 56,
383, 397, 615, 622, 624, 627, 630, 369, 369, 383,
394, 615, 625, 627, 615, 394, 396, 404, 396, 638,
638, 638, 395, 395, 638, 638, 638, 395, 638, 638,
395, 395, 395, 395, 395, 395, 395, 395, 395, 395,
395, 395, 395, 395, 395, 395, 395, 395, 395, 395,
395, 395, 395, 615, 615, 615, 622, 8, 370, 371,
372, 374, 375, 376, 377, 378, 379, 380, 381, 382,
383, 384, 385, 386, 388, 389, 392, 401, 393, 400,
397, 394, 394, 622, 626, 633, 637, 637, 633, 615,
633, 633, 633, 633, 629, 622, 630, 401, 629, 632,
633, 633, 633, 633, 633, 394, 394, 396, 639, 615,
5, 142, 623, 629, 396, 404, 429, 396, 429, 621,
404, 404, 119, 398, 413, 596, 629, 396, 429, 397,
398, 473, 596, 397, 398, 456, 596, 397, 398, 463,
596, 397, 398, 480, 596, 123, 398, 431, 596, 629,
397, 398, 501, 596, 397, 398, 527, 596, 394, 396,
397, 398, 569, 596, 615, 394, 397, 398, 580, 596,
296, 404, 639, 615, 395, 395, 395, 395, 395, 395,
397, 615, 627, 398, 625, 8, 384, 385, 393, 400,
7, 382, 383, 384, 385, 392, 7, 624, 624, 369,
382, 383, 384, 394, 404, 398, 7, 395, 7, 615,
399, 633, 633, 633, 396, 629, 629, 622, 629, 633,
622, 615, 629, 639, 633, 615, 615, 615, 615, 615,
615, 615, 615, 615, 615, 615, 615, 615, 615, 615,
615, 615, 615, 615, 615, 615, 615, 615, 394, 393,
400, 615, 615, 615, 615, 615, 615, 615, 615, 615,
615, 615, 615, 615, 615, 615, 615, 615, 615, 615,
615, 615, 623, 615, 393, 400, 404, 639, 639, 404,
639, 404, 404, 396, 396, 396, 396, 400, 404, 619,
631, 615, 9, 639, 404, 639, 639, 639, 639, 639,
595, 7, 394, 393, 7, 629, 7, 629, 630, 395,
615, 633, 395, 369, 382, 7, 629, 474, 457, 464,
481, 395, 395, 502, 528, 7, 7, 570, 581, 629,
625, 7, 377, 378, 598, 398, 5, 120, 126, 401,
416, 418, 419, 629, 397, 615, 627, 629, 627, 629,
615, 615, 633, 625, 398, 615, 397, 615, 627, 615,
627, 394, 397, 623, 627, 627, 615, 627, 615, 627,
615, 7, 7, 10, 624, 369, 369, 369, 382, 383,
615, 627, 615, 398, 397, 404, 404, 639, 396, 404,
400, 639, 395, 639, 400, 404, 618, 617, 639, 404,
639, 396, 396, 396, 396, 396, 396, 396, 396, 396,
396, 404, 396, 396, 396, 396, 396, 396, 396, 396,
404, 404, 404, 396, 394, 623, 8, 394, 8, 394,
393, 8, 394, 623, 626, 633, 625, 633, 615, 623,
633, 394, 404, 605, 401, 633, 7, 615, 369, 393,
397, 5, 142, 152, 602, 603, 604, 639, 639, 427,
122, 401, 416, 369, 139, 142, 152, 398, 475, 643,
139, 152, 398, 458, 596, 643, 139, 144, 152, 398,
465, 596, 643, 125, 142, 152, 153, 161, 163, 398,
482, 596, 643, 433, 396, 418, 5, 142, 152, 169,
398, 503, 596, 643, 152, 194, 195, 202, 398, 529,
596, 643, 152, 169, 196, 293, 398, 571, 596, 643,
152, 194, 202, 295, 297, 325, 353, 355, 356, 360,
361, 367, 398, 582, 596, 643, 584, 639, 633, 3,
393, 397, 405, 423, 425, 622, 396, 395, 625, 396,
396, 404, 404, 404, 404, 396, 398, 8, 625, 625,
393, 395, 638, 7, 10, 624, 624, 624, 369, 369,
396, 7, 615, 633, 633, 615, 623, 396, 623, 615,
639, 404, 601, 615, 615, 615, 615, 615, 393, 615,
615, 615, 615, 393, 639, 404, 404, 639, 619, 5,
37, 152, 606, 607, 396, 615, 639, 394, 397, 615,
630, 394, 615, 10, 397, 624, 630, 634, 624, 630,
396, 404, 7, 7, 396, 429, 395, 622, 7, 416,
5, 397, 5, 629, 596, 7, 397, 629, 7, 397,
51, 155, 384, 435, 436, 629, 7, 397, 5, 629,
397, 397, 397, 7, 396, 429, 369, 396, 432, 397,
5, 629, 397, 7, 629, 615, 397, 530, 7, 629,
397, 629, 629, 7, 629, 615, 397, 629, 395, 5,
7, 615, 624, 624, 615, 615, 615, 7, 397, 7,
598, 7, 8, 615, 627, 424, 627, 120, 420, 423,
398, 627, 629, 615, 615, 615, 398, 398, 394, 396,
397, 635, 636, 637, 638, 7, 7, 7, 624, 624,
7, 398, 639, 639, 396, 639, 639, 618, 603, 396,
639, 396, 396, 396, 396, 394, 394, 394, 8, 398,
394, 633, 615, 394, 615, 630, 634, 636, 630, 630,
404, 624, 630, 369, 398, 638, 600, 615, 627, 604,
7, 629, 425, 7, 397, 476, 7, 7, 459, 7,
466, 395, 395, 384, 7, 439, 440, 7, 497, 7,
7, 483, 487, 494, 7, 629, 435, 369, 404, 510,
7, 7, 504, 7, 7, 531, 397, 7, 572, 7,
7, 7, 7, 585, 7, 615, 7, 7, 7, 7,
7, 7, 7, 585, 633, 3, 394, 394, 398, 429,
405, 417, 396, 396, 396, 404, 404, 394, 7, 637,
639, 635, 7, 7, 639, 615, 639, 639, 607, 609,
611, 397, 636, 398, 404, 369, 369, 369, 397, 414,
476, 397, 398, 596, 397, 398, 596, 397, 398, 596,
615, 5, 384, 5, 87, 88, 89, 90, 91, 92,
93, 94, 95, 96, 97, 98, 99, 100, 101, 102,
103, 104, 105, 106, 107, 108, 109, 110, 111, 112,
113, 115, 116, 177, 188, 189, 190, 376, 382, 383,
390, 393, 397, 401, 402, 441, 445, 525, 613, 614,
616, 629, 641, 642, 397, 398, 596, 397, 398, 596,
397, 398, 596, 397, 398, 596, 397, 7, 435, 418,
173, 174, 175, 176, 398, 511, 596, 397, 398, 596,
397, 398, 596, 538, 397, 398, 596, 398, 586, 404,
398, 7, 8, 383, 425, 421, 615, 615, 398, 7,
639, 398, 601, 605, 398, 624, 639, 615, 633, 629,
397, 615, 404, 398, 477, 460, 467, 396, 396, 525,
395, 451, 395, 395, 395, 395, 446, 447, 448, 449,
5, 57, 441, 441, 441, 441, 5, 629, 615, 622,
3, 207, 319, 629, 370, 371, 372, 373, 374, 375,
376, 377, 380, 381, 382, 383, 384, 385, 386, 387,
392, 401, 403, 395, 452, 452, 498, 484, 488, 495,
615, 7, 396, 397, 397, 397, 397, 505, 532, 5,
41, 42, 204, 205, 206, 208, 209, 210, 211, 212,
213, 214, 215, 216, 217, 218, 219, 220, 221, 222,
223, 224, 225, 226, 227, 228, 229, 230, 231, 232,
233, 234, 235, 236, 237, 238, 239, 245, 246, 247,
250, 251, 252, 253, 254, 255, 256, 259, 261, 262,
263, 264, 265, 266, 267, 269, 270, 271, 272, 273,
274, 275, 276, 277, 278, 279, 280, 281, 282, 283,
284, 285, 286, 287, 288, 289, 290, 294, 299, 303,
398, 540, 541, 542, 543, 544, 596, 573, 298, 299,
300, 301, 302, 587, 596, 615, 3, 425, 396, 429,
396, 396, 7, 398, 398, 610, 369, 393, 428, 398,
423, 126, 127, 128, 129, 130, 131, 132, 133, 134,
135, 136, 137, 142, 155, 398, 478, 126, 133, 138,
398, 461, 139, 142, 143, 398, 468, 525, 395, 525,
441, 614, 629, 614, 395, 395, 395, 395, 377, 395,
394, 629, 398, 393, 400, 369, 442, 441, 441, 441,
441, 441, 441, 441, 441, 441, 441, 441, 441, 441,
441, 441, 441, 615, 615, 396, 400, 441, 453, 397,
454, 154, 164, 166, 167, 398, 499, 152, 154, 155,
156, 157, 158, 159, 160, 398, 485, 643, 152, 154,
162, 398, 489, 643, 142, 152, 154, 398, 496, 398,
369, 516, 516, 520, 512, 138, 141, 142, 152, 170,
171, 172, 191, 291, 395, 398, 506, 142, 152, 196,
197, 198, 199, 200, 201, 398, 533, 596, 395, 629,
395, 395, 395, 435, 395, 435, 395, 395, 395, 395,
395, 395, 395, 395, 395, 395, 7, 395, 395, 395,
395, 395, 395, 395, 395, 395, 395, 397, 395, 397,
395, 395, 395, 397, 395, 395, 397, 7, 395, 7,
395, 7, 395, 395, 395, 395, 395, 395, 395, 7,
395, 395, 395, 395, 395, 395, 395, 395, 395, 395,
395, 395, 395, 395, 395, 395, 395, 395, 545, 546,
395, 395, 395, 395, 134, 152, 398, 574, 643, 395,
395, 395, 395, 395, 404, 5, 121, 422, 601, 633,
394, 397, 415, 418, 418, 418, 418, 418, 395, 435,
615, 395, 435, 395, 435, 435, 397, 629, 5, 395,
435, 418, 435, 629, 397, 5, 5, 396, 439, 396,
404, 450, 452, 439, 439, 439, 439, 395, 441, 398,
623, 441, 441, 396, 396, 404, 126, 402, 625, 630,
629, 5, 165, 419, 422, 629, 629, 629, 5, 397,
397, 437, 437, 418, 418, 7, 5, 5, 397, 492,
5, 397, 490, 7, 5, 629, 629, 435, 5, 127,
138, 140, 141, 177, 178, 179, 180, 181, 182, 183,
184, 185, 186, 187, 191, 192, 398, 517, 524, 398,
143, 191, 398, 521, 524, 142, 167, 397, 398, 513,
596, 629, 5, 5, 163, 173, 629, 629, 615, 3,
418, 624, 508, 5, 629, 397, 534, 629, 633, 624,
633, 397, 536, 629, 629, 629, 7, 435, 435, 435,
7, 435, 7, 435, 629, 629, 629, 629, 629, 629,
629, 629, 629, 396, 629, 435, 438, 629, 629, 629,
629, 629, 633, 615, 557, 615, 559, 629, 615, 615,
561, 615, 633, 563, 396, 396, 396, 624, 396, 435,
418, 633, 633, 396, 633, 633, 633, 629, 629, 629,
629, 629, 629, 629, 629, 629, 629, 629, 629, 629,
629, 395, 395, 633, 629, 629, 630, 629, 397, 629,
7, 589, 629, 6, 589, 418, 633, 633, 615, 629,
423, 398, 3, 5, 426, 404, 7, 7, 7, 7,
7, 435, 7, 7, 435, 7, 435, 7, 7, 393,
616, 7, 7, 435, 7, 7, 7, 454, 469, 7,
7, 404, 441, 395, 454, 396, 404, 404, 404, 439,
396, 393, 8, 441, 395, 629, 398, 398, 7, 7,
7, 7, 7, 7, 7, 397, 486, 5, 438, 7,
7, 7, 7, 7, 493, 7, 491, 7, 7, 7,
7, 7, 395, 418, 629, 435, 629, 418, 7, 395,
5, 418, 395, 5, 629, 514, 7, 7, 7, 7,
7, 7, 507, 7, 7, 7, 7, 439, 7, 7,
535, 7, 7, 7, 7, 537, 7, 7, 404, 539,
396, 396, 396, 396, 396, 404, 404, 404, 404, 404,
404, 404, 396, 404, 396, 404, 7, 396, 404, 396,
404, 404, 396, 404, 404, 396, 404, 396, 404, 202,
207, 240, 241, 242, 398, 558, 404, 202, 207, 240,
241, 243, 244, 398, 560, 404, 404, 404, 44, 144,
202, 248, 249, 398, 562, 404, 404, 44, 144, 195,
202, 203, 248, 257, 258, 398, 564, 7, 7, 7,
396, 7, 396, 404, 396, 396, 7, 396, 404, 396,
404, 404, 404, 404, 404, 396, 404, 396, 396, 404,
404, 396, 404, 404, 396, 6, 437, 547, 629, 547,
396, 404, 404, 393, 404, 404, 404, 575, 7, 305,
306, 307, 308, 309, 310, 311, 312, 313, 592, 395,
591, 404, 592, 588, 593, 396, 396, 398, 404, 423,
404, 404, 404, 615, 429, 404, 7, 397, 398, 418,
396, 439, 396, 3, 615, 615, 396, 377, 443, 418,
398, 169, 7, 429, 398, 398, 429, 398, 429, 3,
7, 7, 7, 7, 7, 518, 7, 7, 522, 7,
7, 5, 191, 398, 515, 395, 509, 396, 398, 429,
398, 429, 615, 396, 397, 397, 7, 7, 7, 435,
629, 629, 615, 615, 615, 629, 7, 435, 7, 418,
7, 615, 7, 435, 615, 7, 615, 615, 7, 629,
7, 615, 397, 435, 615, 615, 435, 615, 397, 435,
615, 615, 615, 615, 615, 615, 615, 615, 615, 397,
615, 435, 435, 633, 615, 615, 629, 397, 397, 615,
615, 397, 7, 7, 435, 7, 7, 7, 633, 7,
624, 624, 624, 615, 624, 7, 418, 7, 7, 629,
629, 7, 418, 629, 7, 548, 548, 7, 615, 418,
394, 629, 630, 629, 402, 5, 173, 398, 596, 418,
418, 397, 418, 397, 397, 397, 397, 397, 593, 418,
382, 383, 384, 385, 404, 590, 10, 435, 593, 404,
396, 404, 594, 7, 7, 605, 3, 5, 404, 435,
435, 435, 394, 616, 435, 470, 396, 396, 397, 396,
404, 404, 444, 441, 396, 5, 5, 5, 5, 396,
439, 439, 525, 418, 629, 7, 7, 629, 629, 7,
538, 538, 396, 404, 404, 404, 404, 404, 404, 396,
404, 396, 396, 396, 396, 396, 404, 538, 7, 7,
7, 7, 404, 538, 7, 7, 7, 7, 7, 404,
404, 404, 7, 7, 538, 7, 7, 404, 404, 7,
7, 7, 538, 538, 7, 7, 565, 396, 404, 396,
396, 396, 404, 404, 404, 539, 404, 404, 404, 396,
404, 396, 404, 549, 396, 396, 396, 404, 393, 396,
396, 629, 397, 397, 314, 435, 397, 625, 397, 397,
397, 396, 396, 5, 395, 593, 396, 191, 7, 5,
134, 152, 198, 209, 259, 304, 315, 316, 317, 318,
319, 320, 321, 322, 323, 324, 325, 328, 329, 330,
331, 332, 333, 334, 335, 336, 337, 338, 339, 340,
341, 342, 343, 344, 345, 346, 347, 348, 349, 350,
351, 352, 353, 354, 355, 356, 357, 358, 359, 360,
361, 362, 367, 368, 398, 615, 396, 396, 396, 429,
398, 396, 145, 146, 147, 148, 149, 150, 398, 471,
396, 615, 615, 615, 395, 398, 7, 398, 429, 7,
519, 523, 7, 7, 396, 398, 398, 7, 624, 615,
624, 615, 615, 629, 7, 629, 7, 7, 7, 7,
7, 435, 398, 435, 398, 615, 615, 435, 398, 554,
615, 398, 398, 397, 398, 7, 615, 7, 7, 7,
615, 633, 633, 396, 615, 615, 633, 7, 197, 615,
7, 315, 319, 325, 624, 7, 7, 7, 629, 394,
7, 7, 396, 576, 576, 5, 404, 625, 398, 625,
625, 625, 7, 591, 633, 396, 7, 418, 633, 624,
633, 624, 397, 5, 377, 378, 633, 615, 615, 624,
615, 615, 615, 633, 5, 615, 615, 5, 397, 615,
437, 397, 397, 397, 397, 615, 402, 615, 615, 615,
615, 615, 615, 615, 615, 615, 615, 615, 615, 624,
624, 397, 435, 633, 615, 615, 633, 615, 633, 396,
7, 7, 7, 393, 7, 7, 5, 615, 615, 615,
615, 615, 397, 404, 396, 404, 441, 168, 7, 5,
404, 404, 397, 396, 396, 404, 404, 404, 404, 396,
404, 404, 404, 404, 396, 404, 195, 294, 396, 404,
566, 404, 396, 396, 396, 7, 404, 404, 396, 404,
633, 396, 404, 633, 624, 633, 396, 396, 7, 127,
138, 141, 142, 191, 398, 524, 577, 398, 397, 435,
398, 398, 398, 398, 404, 396, 7, 593, 435, 633,
633, 625, 615, 615, 615, 625, 629, 615, 397, 7,
615, 7, 7, 7, 7, 7, 7, 615, 615, 615,
396, 629, 398, 439, 525, 538, 7, 7, 615, 615,
615, 615, 7, 435, 615, 435, 615, 397, 615, 397,
397, 397, 615, 44, 142, 144, 155, 169, 191, 398,
567, 435, 7, 7, 7, 615, 615, 7, 435, 396,
404, 7, 418, 7, 7, 418, 629, 629, 5, 418,
395, 615, 404, 397, 397, 397, 397, 593, 396, 404,
398, 404, 404, 404, 398, 404, 625, 394, 398, 398,
404, 397, 7, 396, 396, 398, 396, 396, 404, 396,
404, 396, 404, 404, 404, 538, 396, 555, 556, 538,
404, 5, 5, 615, 435, 5, 418, 396, 396, 396,
396, 7, 615, 396, 7, 7, 7, 7, 7, 578,
398, 404, 435, 625, 625, 625, 625, 396, 7, 435,
615, 615, 615, 615, 398, 398, 615, 615, 7, 7,
7, 7, 435, 7, 624, 397, 615, 624, 615, 398,
397, 397, 398, 397, 398, 398, 615, 7, 7, 7,
7, 7, 7, 7, 397, 397, 7, 396, 404, 7,
439, 615, 398, 398, 398, 398, 398, 7, 404, 404,
404, 404, 398, 7, 404, 398, 396, 404, 538, 396,
404, 404, 538, 629, 629, 404, 538, 538, 7, 418,
396, 398, 397, 397, 398, 397, 397, 435, 615, 615,
615, 615, 7, 7, 615, 398, 397, 624, 633, 398,
404, 404, 624, 398, 398, 396, 7, 397, 624, 625,
397, 625, 625, 398, 398, 398, 398, 396, 118, 404,
538, 404, 404, 615, 615, 404, 7, 615, 404, 398,
615, 398, 398, 418, 615, 398, 624, 624, 404, 404,
624, 398, 624, 398, 398, 398, 397, 7, 396, 396,
404, 615, 615, 404, 404, 397, 625, 193, 7, 7,
551, 404, 404, 624, 624, 615, 398, 629, 195, 294,
404, 550, 5, 5, 396, 398, 404, 398, 397, 397,
397, 615, 396, 5, 398, 397, 615, 397, 615, 552,
553, 404, 397, 398, 538, 398, 615, 398, 397, 398,
397, 398, 615, 538, 398, 404, 7, 629, 629, 404,
398, 397, 615, 398, 404, 404, 615, 397, 538, 404,
615, 615, 538, 398, 615, 404, 404, 398, 398, 615,
615, 404, 404, 5, 5, 398, 398
};
#define yyerrok (yyerrstatus = 0)
#define yyclearin (yychar = YYEMPTY)
#define YYEMPTY (-2)
#define YYEOF 0
#define YYACCEPT goto yyacceptlab
#define YYABORT goto yyabortlab
#define YYERROR goto yyerrorlab
/* Like YYERROR except do call yyerror. This remains here temporarily
to ease the transition to the new meaning of YYERROR, for GCC.
Once GCC version 2 has supplanted version 1, this can go. */
#define YYFAIL goto yyerrlab
#define YYRECOVERING() (!!yyerrstatus)
#define YYBACKUP(Token, Value) \
do \
if (yychar == YYEMPTY && yylen == 1) \
{ \
yychar = (Token); \
yylval = (Value); \
yytoken = YYTRANSLATE (yychar); \
YYPOPSTACK (1); \
goto yybackup; \
} \
else \
{ \
yyerror (YY_("syntax error: cannot back up")); \
YYERROR; \
} \
while (YYID (0))
#define YYTERROR 1
#define YYERRCODE 256
/* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N].
If N is 0, then set CURRENT to the empty location which ends
the previous symbol: RHS[0] (always defined). */
#define YYRHSLOC(Rhs, K) ((Rhs)[K])
#ifndef YYLLOC_DEFAULT
# define YYLLOC_DEFAULT(Current, Rhs, N) \
do \
if (YYID (N)) \
{ \
(Current).first_line = YYRHSLOC (Rhs, 1).first_line; \
(Current).first_column = YYRHSLOC (Rhs, 1).first_column; \
(Current).last_line = YYRHSLOC (Rhs, N).last_line; \
(Current).last_column = YYRHSLOC (Rhs, N).last_column; \
} \
else \
{ \
(Current).first_line = (Current).last_line = \
YYRHSLOC (Rhs, 0).last_line; \
(Current).first_column = (Current).last_column = \
YYRHSLOC (Rhs, 0).last_column; \
} \
while (YYID (0))
#endif
/* YY_LOCATION_PRINT -- Print the location on the stream.
This macro was not mandated originally: define only if we know
we won't break user code: when these are the locations we know. */
#ifndef YY_LOCATION_PRINT
# if defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL
# define YY_LOCATION_PRINT(File, Loc) \
fprintf (File, "%d.%d-%d.%d", \
(Loc).first_line, (Loc).first_column, \
(Loc).last_line, (Loc).last_column)
# else
# define YY_LOCATION_PRINT(File, Loc) ((void) 0)
# endif
#endif
/* YYLEX -- calling `yylex' with the right arguments. */
#ifdef YYLEX_PARAM
# define YYLEX yylex (YYLEX_PARAM)
#else
# define YYLEX yylex ()
#endif
/* Enable debugging if requested. */
#if YYDEBUG
# ifndef YYFPRINTF
# include <stdio.h> /* INFRINGES ON USER NAME SPACE */
# define YYFPRINTF fprintf
# endif
# define YYDPRINTF(Args) \
do { \
if (yydebug) \
YYFPRINTF Args; \
} while (YYID (0))
# define YY_SYMBOL_PRINT(Title, Type, Value, Location) \
do { \
if (yydebug) \
{ \
YYFPRINTF (stderr, "%s ", Title); \
yy_symbol_print (stderr, \
Type, Value); \
YYFPRINTF (stderr, "\n"); \
} \
} while (YYID (0))
/*--------------------------------.
| Print this symbol on YYOUTPUT. |
`--------------------------------*/
/*ARGSUSED*/
#if (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
static void
yy_symbol_value_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep)
#else
static void
yy_symbol_value_print (yyoutput, yytype, yyvaluep)
FILE *yyoutput;
int yytype;
YYSTYPE const * const yyvaluep;
#endif
{
if (!yyvaluep)
return;
# ifdef YYPRINT
if (yytype < YYNTOKENS)
YYPRINT (yyoutput, yytoknum[yytype], *yyvaluep);
# else
YYUSE (yyoutput);
# endif
switch (yytype)
{
default:
break;
}
}
/*--------------------------------.
| Print this symbol on YYOUTPUT. |
`--------------------------------*/
#if (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
static void
yy_symbol_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep)
#else
static void
yy_symbol_print (yyoutput, yytype, yyvaluep)
FILE *yyoutput;
int yytype;
YYSTYPE const * const yyvaluep;
#endif
{
if (yytype < YYNTOKENS)
YYFPRINTF (yyoutput, "token %s (", yytname[yytype]);
else
YYFPRINTF (yyoutput, "nterm %s (", yytname[yytype]);
yy_symbol_value_print (yyoutput, yytype, yyvaluep);
YYFPRINTF (yyoutput, ")");
}
/*------------------------------------------------------------------.
| yy_stack_print -- Print the state stack from its BOTTOM up to its |
| TOP (included). |
`------------------------------------------------------------------*/
#if (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
static void
yy_stack_print (yytype_int16 *bottom, yytype_int16 *top)
#else
static void
yy_stack_print (bottom, top)
yytype_int16 *bottom;
yytype_int16 *top;
#endif
{
YYFPRINTF (stderr, "Stack now");
for (; bottom <= top; ++bottom)
YYFPRINTF (stderr, " %d", *bottom);
YYFPRINTF (stderr, "\n");
}
# define YY_STACK_PRINT(Bottom, Top) \
do { \
if (yydebug) \
yy_stack_print ((Bottom), (Top)); \
} while (YYID (0))
/*------------------------------------------------.
| Report that the YYRULE is going to be reduced. |
`------------------------------------------------*/
#if (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
static void
yy_reduce_print (YYSTYPE *yyvsp, int yyrule)
#else
static void
yy_reduce_print (yyvsp, yyrule)
YYSTYPE *yyvsp;
int yyrule;
#endif
{
int yynrhs = yyr2[yyrule];
int yyi;
unsigned long int yylno = yyrline[yyrule];
YYFPRINTF (stderr, "Reducing stack by rule %d (line %lu):\n",
yyrule - 1, yylno);
/* The symbols being reduced. */
for (yyi = 0; yyi < yynrhs; yyi++)
{
fprintf (stderr, " $%d = ", yyi + 1);
yy_symbol_print (stderr, yyrhs[yyprhs[yyrule] + yyi],
&(yyvsp[(yyi + 1) - (yynrhs)])
);
fprintf (stderr, "\n");
}
}
# define YY_REDUCE_PRINT(Rule) \
do { \
if (yydebug) \
yy_reduce_print (yyvsp, Rule); \
} while (YYID (0))
/* Nonzero means print parse trace. It is left uninitialized so that
multiple parsers can coexist. */
int yydebug;
#else /* !YYDEBUG */
# define YYDPRINTF(Args)
# define YY_SYMBOL_PRINT(Title, Type, Value, Location)
# define YY_STACK_PRINT(Bottom, Top)
# define YY_REDUCE_PRINT(Rule)
#endif /* !YYDEBUG */
/* YYINITDEPTH -- initial size of the parser's stacks. */
#ifndef YYINITDEPTH
# define YYINITDEPTH 200
#endif
/* YYMAXDEPTH -- maximum size the stacks can grow to (effective only
if the built-in stack extension method is used).
Do not make this value too large; the results are undefined if
YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH)
evaluated with infinite-precision integer arithmetic. */
#ifndef YYMAXDEPTH
# define YYMAXDEPTH 10000
#endif
#if YYERROR_VERBOSE
# ifndef yystrlen
# if defined __GLIBC__ && defined _STRING_H
# define yystrlen strlen
# else
/* Return the length of YYSTR. */
#if (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
static YYSIZE_T
yystrlen (const char *yystr)
#else
static YYSIZE_T
yystrlen (yystr)
const char *yystr;
#endif
{
YYSIZE_T yylen;
for (yylen = 0; yystr[yylen]; yylen++)
continue;
return yylen;
}
# endif
# endif
# ifndef yystpcpy
# if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE
# define yystpcpy stpcpy
# else
/* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in
YYDEST. */
#if (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
static char *
yystpcpy (char *yydest, const char *yysrc)
#else
static char *
yystpcpy (yydest, yysrc)
char *yydest;
const char *yysrc;
#endif
{
char *yyd = yydest;
const char *yys = yysrc;
while ((*yyd++ = *yys++) != '\0')
continue;
return yyd - 1;
}
# endif
# endif
# ifndef yytnamerr
/* Copy to YYRES the contents of YYSTR after stripping away unnecessary
quotes and backslashes, so that it's suitable for yyerror. The
heuristic is that double-quoting is unnecessary unless the string
contains an apostrophe, a comma, or backslash (other than
backslash-backslash). YYSTR is taken from yytname. If YYRES is
null, do not copy; instead, return the length of what the result
would have been. */
static YYSIZE_T
yytnamerr (char *yyres, const char *yystr)
{
if (*yystr == '"')
{
YYSIZE_T yyn = 0;
char const *yyp = yystr;
for (;;)
switch (*++yyp)
{
case '\'':
case ',':
goto do_not_strip_quotes;
case '\\':
if (*++yyp != '\\')
goto do_not_strip_quotes;
/* Fall through. */
default:
if (yyres)
yyres[yyn] = *yyp;
yyn++;
break;
case '"':
if (yyres)
yyres[yyn] = '\0';
return yyn;
}
do_not_strip_quotes: ;
}
if (! yyres)
return yystrlen (yystr);
return yystpcpy (yyres, yystr) - yyres;
}
# endif
/* Copy into YYRESULT an error message about the unexpected token
YYCHAR while in state YYSTATE. Return the number of bytes copied,
including the terminating null byte. If YYRESULT is null, do not
copy anything; just return the number of bytes that would be
copied. As a special case, return 0 if an ordinary "syntax error"
message will do. Return YYSIZE_MAXIMUM if overflow occurs during
size calculation. */
static YYSIZE_T
yysyntax_error (char *yyresult, int yystate, int yychar)
{
int yyn = yypact[yystate];
if (! (YYPACT_NINF < yyn && yyn <= YYLAST))
return 0;
else
{
int yytype = YYTRANSLATE (yychar);
YYSIZE_T yysize0 = yytnamerr (0, yytname[yytype]);
YYSIZE_T yysize = yysize0;
YYSIZE_T yysize1;
int yysize_overflow = 0;
enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 };
char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM];
int yyx;
# if 0
/* This is so xgettext sees the translatable formats that are
constructed on the fly. */
YY_("syntax error, unexpected %s");
YY_("syntax error, unexpected %s, expecting %s");
YY_("syntax error, unexpected %s, expecting %s or %s");
YY_("syntax error, unexpected %s, expecting %s or %s or %s");
YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s");
# endif
char *yyfmt;
char const *yyf;
static char const yyunexpected[] = "syntax error, unexpected %s";
static char const yyexpecting[] = ", expecting %s";
static char const yyor[] = " or %s";
char yyformat[sizeof yyunexpected
+ sizeof yyexpecting - 1
+ ((YYERROR_VERBOSE_ARGS_MAXIMUM - 2)
* (sizeof yyor - 1))];
char const *yyprefix = yyexpecting;
/* Start YYX at -YYN if negative to avoid negative indexes in
YYCHECK. */
int yyxbegin = yyn < 0 ? -yyn : 0;
/* Stay within bounds of both yycheck and yytname. */
int yychecklim = YYLAST - yyn + 1;
int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS;
int yycount = 1;
yyarg[0] = yytname[yytype];
yyfmt = yystpcpy (yyformat, yyunexpected);
for (yyx = yyxbegin; yyx < yyxend; ++yyx)
if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR)
{
if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM)
{
yycount = 1;
yysize = yysize0;
yyformat[sizeof yyunexpected - 1] = '\0';
break;
}
yyarg[yycount++] = yytname[yyx];
yysize1 = yysize + yytnamerr (0, yytname[yyx]);
yysize_overflow |= (yysize1 < yysize);
yysize = yysize1;
yyfmt = yystpcpy (yyfmt, yyprefix);
yyprefix = yyor;
}
yyf = YY_(yyformat);
yysize1 = yysize + yystrlen (yyf);
yysize_overflow |= (yysize1 < yysize);
yysize = yysize1;
if (yysize_overflow)
return YYSIZE_MAXIMUM;
if (yyresult)
{
/* Avoid sprintf, as that infringes on the user's name space.
Don't have undefined behavior even if the translation
produced a string with the wrong number of "%s"s. */
char *yyp = yyresult;
int yyi = 0;
while ((*yyp = *yyf) != '\0')
{
if (*yyp == '%' && yyf[1] == 's' && yyi < yycount)
{
yyp += yytnamerr (yyp, yyarg[yyi++]);
yyf += 2;
}
else
{
yyp++;
yyf++;
}
}
}
return yysize;
}
}
#endif /* YYERROR_VERBOSE */
/*-----------------------------------------------.
| Release the memory associated to this symbol. |
`-----------------------------------------------*/
/*ARGSUSED*/
#if (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
static void
yydestruct (const char *yymsg, int yytype, YYSTYPE *yyvaluep)
#else
static void
yydestruct (yymsg, yytype, yyvaluep)
const char *yymsg;
int yytype;
YYSTYPE *yyvaluep;
#endif
{
YYUSE (yyvaluep);
if (!yymsg)
yymsg = "Deleting";
YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp);
switch (yytype)
{
default:
break;
}
}
/* Prevent warnings from -Wmissing-prototypes. */
#ifdef YYPARSE_PARAM
#if defined __STDC__ || defined __cplusplus
int yyparse (void *YYPARSE_PARAM);
#else
int yyparse ();
#endif
#else /* ! YYPARSE_PARAM */
#if defined __STDC__ || defined __cplusplus
int yyparse (void);
#else
int yyparse ();
#endif
#endif /* ! YYPARSE_PARAM */
/* The look-ahead symbol. */
int yychar;
/* The semantic value of the look-ahead symbol. */
YYSTYPE yylval;
/* Number of syntax errors so far. */
int yynerrs;
/*----------.
| yyparse. |
`----------*/
#ifdef YYPARSE_PARAM
#if (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
int
yyparse (void *YYPARSE_PARAM)
#else
int
yyparse (YYPARSE_PARAM)
void *YYPARSE_PARAM;
#endif
#else /* ! YYPARSE_PARAM */
#if (defined __STDC__ || defined __C99__FUNC__ \
|| defined __cplusplus || defined _MSC_VER)
int
yyparse (void)
#else
int
yyparse ()
#endif
#endif
{
int yystate;
int yyn;
int yyresult;
/* Number of tokens to shift before error messages enabled. */
int yyerrstatus;
/* Look-ahead token as an internal (translated) token number. */
int yytoken = 0;
#if YYERROR_VERBOSE
/* Buffer for error messages, and its allocated size. */
char yymsgbuf[128];
char *yymsg = yymsgbuf;
YYSIZE_T yymsg_alloc = sizeof yymsgbuf;
#endif
/* Three stacks and their tools:
`yyss': related to states,
`yyvs': related to semantic values,
`yyls': related to locations.
Refer to the stacks thru separate pointers, to allow yyoverflow
to reallocate them elsewhere. */
/* The state stack. */
yytype_int16 yyssa[YYINITDEPTH];
yytype_int16 *yyss = yyssa;
yytype_int16 *yyssp;
/* The semantic value stack. */
YYSTYPE yyvsa[YYINITDEPTH];
YYSTYPE *yyvs = yyvsa;
YYSTYPE *yyvsp;
#define YYPOPSTACK(N) (yyvsp -= (N), yyssp -= (N))
YYSIZE_T yystacksize = YYINITDEPTH;
/* The variables used to return semantic value and location from the
action routines. */
YYSTYPE yyval;
/* The number of symbols on the RHS of the reduced rule.
Keep to zero when no symbol should be popped. */
int yylen = 0;
YYDPRINTF ((stderr, "Starting parse\n"));
yystate = 0;
yyerrstatus = 0;
yynerrs = 0;
yychar = YYEMPTY; /* Cause a token to be read. */
/* Initialize stack pointers.
Waste one element of value and location stack
so that they stay on the same level as the state stack.
The wasted elements are never initialized. */
yyssp = yyss;
yyvsp = yyvs;
goto yysetstate;
/*------------------------------------------------------------.
| yynewstate -- Push a new state, which is found in yystate. |
`------------------------------------------------------------*/
yynewstate:
/* In all cases, when you get here, the value and location stacks
have just been pushed. So pushing a state here evens the stacks. */
yyssp++;
yysetstate:
*yyssp = yystate;
if (yyss + yystacksize - 1 <= yyssp)
{
/* Get the current used size of the three stacks, in elements. */
YYSIZE_T yysize = yyssp - yyss + 1;
#ifdef yyoverflow
{
/* Give user a chance to reallocate the stack. Use copies of
these so that the &'s don't force the real ones into
memory. */
YYSTYPE *yyvs1 = yyvs;
yytype_int16 *yyss1 = yyss;
/* Each stack pointer address is followed by the size of the
data in use in that stack, in bytes. This used to be a
conditional around just the two extra args, but that might
be undefined if yyoverflow is a macro. */
yyoverflow (YY_("memory exhausted"),
&yyss1, yysize * sizeof (*yyssp),
&yyvs1, yysize * sizeof (*yyvsp),
&yystacksize);
yyss = yyss1;
yyvs = yyvs1;
}
#else /* no yyoverflow */
# ifndef YYSTACK_RELOCATE
goto yyexhaustedlab;
# else
/* Extend the stack our own way. */
if (YYMAXDEPTH <= yystacksize)
goto yyexhaustedlab;
yystacksize *= 2;
if (YYMAXDEPTH < yystacksize)
yystacksize = YYMAXDEPTH;
{
yytype_int16 *yyss1 = yyss;
union yyalloc *yyptr =
(union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize));
if (! yyptr)
goto yyexhaustedlab;
YYSTACK_RELOCATE (yyss);
YYSTACK_RELOCATE (yyvs);
# undef YYSTACK_RELOCATE
if (yyss1 != yyssa)
YYSTACK_FREE (yyss1);
}
# endif
#endif /* no yyoverflow */
yyssp = yyss + yysize - 1;
yyvsp = yyvs + yysize - 1;
YYDPRINTF ((stderr, "Stack size increased to %lu\n",
(unsigned long int) yystacksize));
if (yyss + yystacksize - 1 <= yyssp)
YYABORT;
}
YYDPRINTF ((stderr, "Entering state %d\n", yystate));
goto yybackup;
/*-----------.
| yybackup. |
`-----------*/
yybackup:
/* Do appropriate processing given the current state. Read a
look-ahead token if we need one and don't already have one. */
/* First try to decide what to do without reference to look-ahead token. */
yyn = yypact[yystate];
if (yyn == YYPACT_NINF)
goto yydefault;
/* Not known => get a look-ahead token if don't already have one. */
/* YYCHAR is either YYEMPTY or YYEOF or a valid look-ahead symbol. */
if (yychar == YYEMPTY)
{
YYDPRINTF ((stderr, "Reading a token: "));
yychar = YYLEX;
}
if (yychar <= YYEOF)
{
yychar = yytoken = YYEOF;
YYDPRINTF ((stderr, "Now at end of input.\n"));
}
else
{
yytoken = YYTRANSLATE (yychar);
YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc);
}
/* If the proper action on seeing token YYTOKEN is to reduce or to
detect an error, take that action. */
yyn += yytoken;
if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken)
goto yydefault;
yyn = yytable[yyn];
if (yyn <= 0)
{
if (yyn == 0 || yyn == YYTABLE_NINF)
goto yyerrlab;
yyn = -yyn;
goto yyreduce;
}
if (yyn == YYFINAL)
YYACCEPT;
/* Count tokens shifted since error; after three, turn off error
status. */
if (yyerrstatus)
yyerrstatus--;
/* Shift the look-ahead token. */
YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc);
/* Discard the shifted token unless it is eof. */
if (yychar != YYEOF)
yychar = YYEMPTY;
yystate = yyn;
*++yyvsp = yylval;
goto yynewstate;
/*-----------------------------------------------------------.
| yydefault -- do the default action for the current state. |
`-----------------------------------------------------------*/
yydefault:
yyn = yydefact[yystate];
if (yyn == 0)
goto yyerrlab;
goto yyreduce;
/*-----------------------------.
| yyreduce -- Do a reduction. |
`-----------------------------*/
yyreduce:
/* yyn is the number of a rule to reduce with. */
yylen = yyr2[yyn];
/* If YYLEN is nonzero, implement the default value of the action:
`$$ = $1'.
Otherwise, the following line sets YYVAL to garbage.
This behavior is undocumented and Bison
users should not rely upon it. Assigning to YYVAL
unconditionally makes the parser a bit smaller, and it avoids a
GCC warning that YYVAL may be used uninitialized. */
yyval = yyvsp[1-yylen];
YY_REDUCE_PRINT (yyn);
switch (yyn)
{
case 2:
#line 395 "ProParser.y"
{ Alloc_ParserVariables(); ;}
break;
case 5:
#line 409 "ProParser.y"
{ Formulation_S.DefineQuantity = NULL; ;}
break;
case 19:
#line 432 "ProParser.y"
{
num_include++; level_include++;
strcpy(getdp_yyincludename, (yyvsp[(2) - (2)].c)); getdp_yyincludenum++; return(0);
;}
break;
case 22:
#line 454 "ProParser.y"
{ Add_Group(&Group_S, (yyvsp[(1) - (4)].c), false, 0, 0); ;}
break;
case 23:
#line 457 "ProParser.y"
{ Add_Group(&Group_S, (yyvsp[(1) - (5)].c), true, 0, 0); ;}
break;
case 24:
#line 460 "ProParser.y"
{
int j = 0;
if(List_Nbr((yyvsp[(5) - (5)].l)) == 1)
List_Read((yyvsp[(5) - (5)].l), 0, &j);
else
vyyerror(0, "Single region number expected for moving band definition");
Group_S.InitialList = List_Create(1, 1, sizeof(int));
List_Add(Group_S.InitialList, &j);
Group_S.Type = MOVINGBAND2D;
Group_S.FunctionType = REGION;
Group_S.InitialSuppList = NULL;
Group_S.SuppListType = SUPPLIST_NONE;
Group_S.MovingBand2D = (struct MovingBand2D *)Malloc(sizeof(struct MovingBand2D));
Group_S.MovingBand2D->PhysNum = j;
;}
break;
case 25:
#line 476 "ProParser.y"
{
Group_S.MovingBand2D->InitialList1 = (yyvsp[(8) - (8)].l);
Group_S.MovingBand2D->ExtendedList1 = NULL;
;}
break;
case 26:
#line 481 "ProParser.y"
{
Group_S.MovingBand2D->InitialList2 = (yyvsp[(11) - (15)].l);
Group_S.MovingBand2D->Period2 = (int)(yyvsp[(13) - (15)].d);
Add_Group(&Group_S, (yyvsp[(1) - (15)].c), false, 0, 0);
;}
break;
case 29:
#line 495 "ProParser.y"
{
Group_S.FunctionType = (yyvsp[(1) - (3)].i);
switch (Group_S.FunctionType) {
case ELEMENTSOF : Group_S.Type = ELEMENTLIST; break;
default : Group_S.Type = REGIONLIST; break;
}
Group_S.InitialList = (yyvsp[(3) - (3)].l);
;}
break;
case 30:
#line 504 "ProParser.y"
{
if (nb_SuppList >=1) {
Group_S.SuppListType = Type_SuppLists[0];
Group_S.InitialSuppList = ListsOfRegion[0];
}
else {
Group_S.SuppListType = SUPPLIST_NONE;
Group_S.InitialSuppList = NULL;
}
if (nb_SuppList >=2) {
Group_S.SuppListType2 = Type_SuppLists[1];
Group_S.InitialSuppList2 = ListsOfRegion[1];
}
else {
Group_S.SuppListType2 = SUPPLIST_NONE;
Group_S.InitialSuppList2 = NULL;
}
(yyval.i) = -1;
;}
break;
case 31:
#line 526 "ProParser.y"
{
Group_S.FunctionType = REGION; Group_S.Type = REGIONLIST;
Group_S.InitialList = (yyvsp[(2) - (2)].l);
Group_S.SuppListType = SUPPLIST_NONE; Group_S.InitialSuppList = NULL;
(yyval.i) = -1;
;}
break;
case 32:
#line 537 "ProParser.y"
{
(yyval.i) = (yyvsp[(1) - (1)].i);
;}
break;
case 33:
#line 542 "ProParser.y"
{
int i;
if(!strcmp((yyvsp[(1) - (1)].c), "All")) { //+++ Never considered because token tAll exists!
(yyval.i) = -3;
}
else if((i = List_ISearchSeq(Problem_S.Group, (yyvsp[(1) - (1)].c), fcmp_Group_Name)) >= 0) {
List_Read(Problem_S.Group, i, &Group_S); (yyval.i) = i;
}
else {
(yyval.i) = -2; vyyerror(0, "Unknown Group: %s", (yyvsp[(1) - (1)].c));
}
Free((yyvsp[(1) - (1)].c));
;}
break;
case 34:
#line 557 "ProParser.y"
{
(yyval.i) = -3;
;}
break;
case 35:
#line 565 "ProParser.y"
{ (yyval.i) = REGION; ;}
break;
case 36:
#line 568 "ProParser.y"
{ (yyval.i) = Get_DefineForString(FunctionForGroup_Type, (yyvsp[(1) - (1)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(1) - (1)].c), FunctionForGroup_Type);
vyyerror(0, "Unknown type of Function for Group: %s", (yyvsp[(1) - (1)].c));
}
Free((yyvsp[(1) - (1)].c));
;}
break;
case 37:
#line 580 "ProParser.y"
{ (yyval.l) = (yyvsp[(1) - (1)].l); ;}
break;
case 38:
#line 581 "ProParser.y"
{ (yyval.l) = NULL; ;}
break;
case 39:
#line 588 "ProParser.y"
{ nb_SuppList = 0; /*Type_SuppList = SUPPLIST_NONE;*/ (yyval.l) = NULL; ;}
break;
case 40:
#line 591 "ProParser.y"
{
if (nb_SuppList+1 <= 2) {
Type_SuppLists[nb_SuppList] = (yyvsp[(3) - (4)].i); (yyval.l) = (yyvsp[(4) - (4)].l); ListsOfRegion[nb_SuppList] = (yyvsp[(4) - (4)].l);
nb_SuppList++;
}
else
vyyerror(0, "More than 2 supplementary lists of Regions not allowed");
;}
break;
case 41:
#line 601 "ProParser.y"
{
if (nb_SuppList+1 <= 2) {
int i;
Type_SuppLists[nb_SuppList] = SUPPLIST_INSUPPORT;
if((i = List_ISearchSeq(Problem_S.Group, (yyvsp[(4) - (4)].c), fcmp_Group_Name)) >= 0) {
if(((struct Group *)List_Pointer(Problem_S.Group, i))->Type ==
ELEMENTLIST) {
(yyval.l) = List_Create(1, 5, sizeof(int));
List_Add((yyval.l), &i);
ListsOfRegion[nb_SuppList] = (yyval.l);
}
else vyyerror(0, "Not a Support of Element Type: %s", (yyvsp[(4) - (4)].c));
}
else vyyerror(0, "Unknown Region for Support: %s", (yyvsp[(4) - (4)].c));
Free((yyvsp[(4) - (4)].c));
nb_SuppList++;
}
else
vyyerror(0, "More than 2 supplementary lists of Regions not allowed");
;}
break;
case 42:
#line 626 "ProParser.y"
{ (yyval.i) = Get_DefineForString(FunctionForGroup_SuppList, (yyvsp[(1) - (1)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(1) - (1)].c), FunctionForGroup_SuppList);
vyyerror(0, "Unknown type of Supplementary Region: %s", (yyvsp[(1) - (1)].c));
}
Free((yyvsp[(1) - (1)].c));
;}
break;
case 43:
#line 638 "ProParser.y"
{
(yyval.l) = List_Create(((List_Nbr((yyvsp[(1) - (1)].l)) > 0)? List_Nbr((yyvsp[(1) - (1)].l)) : 1), 5, sizeof(int));
for(int i = 0; i < List_Nbr((yyvsp[(1) - (1)].l)); i++)
List_Add((yyval.l), (int *)List_Pointer((yyvsp[(1) - (1)].l), i));
;}
break;
case 44:
#line 645 "ProParser.y"
{ (yyval.l) = (yyvsp[(2) - (3)].l); ;}
break;
case 45:
#line 651 "ProParser.y"
{
(yyval.l) = List_Create(5, 5, sizeof(int));
;}
break;
case 46:
#line 656 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (3)].l);
for(int i = 0; i < List_Nbr((yyvsp[(3) - (3)].l)); i++)
List_Add((yyval.l), (int *)List_Pointer((yyvsp[(3) - (3)].l), i));
;}
break;
case 47:
#line 663 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (4)].l);
for(int i = 0; i < List_Nbr((yyvsp[(4) - (4)].l)); i++)
List_Suppress((yyval.l), (int *)List_Pointer((yyvsp[(4) - (4)].l), i), fcmp_Integer);
;}
break;
case 48:
#line 674 "ProParser.y"
{
List_Reset(ListOfInt_L); List_Add((yyval.l) = ListOfInt_L, &((yyvsp[(1) - (1)].i)));
;}
break;
case 49:
#line 679 "ProParser.y"
{
List_Reset((yyval.l) = ListOfInt_L);
for(int j = (yyvsp[(1) - (3)].i); ((yyvsp[(1) - (3)].i) < (yyvsp[(3) - (3)].i)) ? (j <= (yyvsp[(3) - (3)].i)) : (j >= (yyvsp[(3) - (3)].i));
((yyvsp[(1) - (3)].i) < (yyvsp[(3) - (3)].i)) ? (j += 1) : (j -= 1))
List_Add(ListOfInt_L, &j);
;}
break;
case 50:
#line 687 "ProParser.y"
{
List_Reset((yyval.l) = ListOfInt_L);
if(!(yyvsp[(5) - (5)].i) || ((yyvsp[(1) - (5)].i) < (yyvsp[(3) - (5)].i) && (yyvsp[(5) - (5)].i) < 0) || ((yyvsp[(1) - (5)].i) > (yyvsp[(3) - (5)].i) && (yyvsp[(5) - (5)].i) > 0)){
vyyerror(0, "Wrong increment in '%d : %d : %d'", (yyvsp[(1) - (5)].i), (yyvsp[(3) - (5)].i), (yyvsp[(5) - (5)].i));
List_Add(ListOfInt_L, &((yyvsp[(1) - (5)].i)));
}
else
for(int j = (yyvsp[(1) - (5)].i); ((yyvsp[(5) - (5)].i) > 0) ? (j <= (yyvsp[(3) - (5)].i)) : (j >= (yyvsp[(3) - (5)].i)); j += (yyvsp[(5) - (5)].i))
List_Add((yyval.l), &j);
;}
break;
case 51:
#line 699 "ProParser.y"
{
if ((yyvsp[(1) - (1)].c2).char1) vyyerror(1, "NameSpace '%s' not used yet", (yyvsp[(1) - (1)].c2).char1);
int i;
if((i = List_ISearchSeq(Problem_S.Group, (yyvsp[(1) - (1)].c2).char2, fcmp_Group_Name)) < 0) {
// Si ce n'est pas un nom de groupe, est-ce un nom de constante ? :
Constant_S.Name = (yyvsp[(1) - (1)].c2).char2;
if(!Tree_Query(ConstantTable_L, &Constant_S)) {
vyyerror(0, "Unknown Constant: %s", (yyvsp[(1) - (1)].c2).char2);
i = 0;
List_Reset(ListOfInt_L); List_Add((yyval.l) = ListOfInt_L, &i);
}
else
if(Constant_S.Type == VAR_FLOAT) {
i = (int)Constant_S.Value.Float;
List_Reset(ListOfInt_L); List_Add((yyval.l) = ListOfInt_L, &i);
}
else if(Constant_S.Type == VAR_LISTOFFLOAT) {
List_Reset((yyval.l) = ListOfInt_L);
for(int i = 0; i < List_Nbr(Constant_S.Value.List); i++) {
double d;
List_Read(Constant_S.Value.List, i, &d);
int j = (int)d;
List_Add(ListOfInt_L, &j);
}
}
else {
vyyerror(0, "Unknown type of Constant: %s", (yyvsp[(1) - (1)].c2).char2);
i = 0;
List_Reset(ListOfInt_L); List_Add((yyval.l) = ListOfInt_L, &i);
}
}
else // Si c'est un nom de groupe :
(yyval.l) = ((struct Group *)List_Pointer(Problem_S.Group, i))->InitialList;
Free((yyvsp[(1) - (1)].c2).char1); Free((yyvsp[(1) - (1)].c2).char2);
;}
break;
case 52:
#line 737 "ProParser.y"
{
int i = (int)(yyvsp[(2) - (3)].d);
List_Reset(ListOfInt_L); List_Add((yyval.l) = ListOfInt_L, &i);
;}
break;
case 53:
#line 744 "ProParser.y"
{
List_Reset(ListOfInt_L);
for(int i = 0; i < List_Nbr((yyvsp[(2) - (3)].l)); i++) {
double d;
List_Read((yyvsp[(2) - (3)].l), i, &d);
int j = (int)d;
List_Add(ListOfInt_L, &j);
}
(yyval.l) = ListOfInt_L;
;}
break;
case 54:
#line 758 "ProParser.y"
{
List_Reset(ListOfInt_L);
for(int i = 0; i < List_Nbr((yyvsp[(2) - (3)].l)); i++) {
double d;
List_Read((yyvsp[(2) - (3)].l), i, &d);
int j = (int)d;
List_Add(ListOfInt_L, &j);
}
(yyval.l) = ListOfInt_L;
;}
break;
case 56:
#line 777 "ProParser.y"
{
charOptions["Strings"].push_back((yyvsp[(1) - (1)].c));
Free((yyvsp[(1) - (1)].c));
;}
break;
case 57:
#line 783 "ProParser.y"
{
char tmp[128];
sprintf(tmp, "%d", (yyvsp[(1) - (1)].i));
charOptions["Strings"].push_back(tmp);
;}
break;
case 58:
#line 790 "ProParser.y"
{
charOptions["Strings"].push_back((yyvsp[(3) - (3)].c));
Free((yyvsp[(3) - (3)].c));
;}
break;
case 59:
#line 796 "ProParser.y"
{
char tmp[128];
sprintf(tmp, "%d", (yyvsp[(3) - (3)].i));
charOptions["Strings"].push_back(tmp);
;}
break;
case 61:
#line 808 "ProParser.y"
{
int i;
if ( (i = List_ISearchSeq(Problem_S.Group, (yyvsp[(3) - (3)].c), fcmp_Group_Name)) < 0 ) {
Group_S.Type = REGIONLIST ; Group_S.FunctionType = REGION ;
Group_S.InitialList = List_Create( 5, 5, sizeof(int)) ;
Group_S.SuppListType = SUPPLIST_NONE ; Group_S.InitialSuppList = NULL ;
i = Add_Group(&Group_S, (yyvsp[(3) - (3)].c), false, 0, 0) ;
}
else Free((yyvsp[(3) - (3)].c)) ;
;}
break;
case 62:
#line 820 "ProParser.y"
{ floatOptions.clear(); charOptions.clear(); ;}
break;
case 63:
#line 822 "ProParser.y"
{
int i;
if ( (i = List_ISearchSeq(Problem_S.Group, (yyvsp[(3) - (11)].c), fcmp_Group_Name)) < 0 ) {
Group_S.Name = (yyvsp[(3) - (11)].c); // will be overwritten in Add_Group
Group_S.Type = REGIONLIST ; Group_S.FunctionType = REGION ;
Group_S.InitialList = List_Create( 5, 5, sizeof(int)) ;
if(charOptions.count("Strings")){
std::vector<std::string> vec(charOptions["Strings"]);
for(unsigned int i = 0; i < vec.size(); i++)
Fill_GroupInitialListFromString(Group_S.InitialList, vec[i].c_str());
}
Group_S.SuppListType = SUPPLIST_NONE ; Group_S.InitialSuppList = NULL ;
i = Add_Group(&Group_S, (yyvsp[(3) - (11)].c), false, 0, 0) ;
}
else Free((yyvsp[(3) - (11)].c)) ;
;}
break;
case 64:
#line 840 "ProParser.y"
{
for (int k = 0 ; k < (int)(yyvsp[(5) - (6)].d) ; k++) {
char tmpstr[256];
sprintf(tmpstr, "%s_%d", (yyvsp[(3) - (6)].c), k+1) ;
int i;
if ( (i = List_ISearchSeq(Problem_S.Group, tmpstr,
fcmp_Group_Name)) < 0 ) {
Group_S.Type = REGIONLIST ; Group_S.FunctionType = REGION ;
Group_S.SuppListType = SUPPLIST_NONE ; Group_S.InitialSuppList = NULL ;
Group_S.InitialList = List_Create( 5, 5, sizeof(int)) ;
Add_Group(&Group_S, (yyvsp[(3) - (6)].c), false, 2, k+1) ;
}
}
Free((yyvsp[(3) - (6)].c)) ;
;}
break;
case 70:
#line 876 "ProParser.y"
{
int i;
if((i = List_ISearchSeq
(Problem_S.Expression, (yyvsp[(1) - (6)].c), fcmp_Expression_Name)) >= 0) {
if(((struct Expression *)List_Pointer(Problem_S.Expression, i))->Type ==
UNDEFINED_EXP) {
Free(((struct Expression *)List_Pointer(Problem_S.Expression, i))->Name);
List_Read (Problem_S.Expression, (yyvsp[(5) - (6)].i), &Expression_S);
List_Write(Problem_S.Expression, i, &Expression_S);
((struct Expression *)List_Pointer(Problem_S.Expression, i))->Name = (yyvsp[(1) - (6)].c);
List_Pop(Problem_S.Expression);
}
else { vyyerror(0, "Redefinition of Function: %s", (yyvsp[(1) - (6)].c)); }
}
else { /* new identifier */
Free(((struct Expression *)List_Pointer(Problem_S.Expression, (yyvsp[(5) - (6)].i)))->Name);
((struct Expression *)List_Pointer(Problem_S.Expression, (yyvsp[(5) - (6)].i)))->Name = (yyvsp[(1) - (6)].c);
}
;}
break;
case 71:
#line 897 "ProParser.y"
{
int i;
if((i = List_ISearchSeq
(Problem_S.Expression, (yyvsp[(1) - (7)].c), fcmp_Expression_Name)) < 0) {
/* Si le nom n'existe pas : */
i = List_Nbr(Problem_S.Expression);
Expression_S.Type = PIECEWISEFUNCTION;
Expression_S.Case.PieceWiseFunction.ExpressionPerRegion =
List_Create(5, 5, sizeof(struct ExpressionPerRegion));
Expression_S.Case.PieceWiseFunction.ExpressionIndex_Default = -1;
Expression_S.Case.PieceWiseFunction.NumLastRegion = -1;
Add_Expression(&Expression_S, (yyvsp[(1) - (7)].c), 0);
Expression_P = (struct Expression*)List_Pointer(Problem_S.Expression, i);
}
else {
Expression_P = (struct Expression*)List_Pointer(Problem_S.Expression, i);
if(Expression_P->Type == UNDEFINED_EXP) {
Expression_P->Type = PIECEWISEFUNCTION;
Expression_P->Case.PieceWiseFunction.ExpressionPerRegion =
List_Create(5, 5, sizeof(struct ExpressionPerRegion));
Expression_P->Case.PieceWiseFunction.ExpressionIndex_Default = -1;
Expression_P->Case.PieceWiseFunction.NumLastRegion = -1;
}
else if(Expression_P->Type != PIECEWISEFUNCTION)
vyyerror(0, "Not piece-wise Expression: %s", (yyvsp[(1) - (7)].c));
Free((yyvsp[(1) - (7)].c));
}
if((yyvsp[(3) - (7)].i) >= 0 || (yyvsp[(3) - (7)].i) == -1) {
ExpressionPerRegion_S.ExpressionIndex = (yyvsp[(6) - (7)].i);
for(int i = 0; i < List_Nbr(Group_S.InitialList); i++) {
List_Read(Group_S.InitialList, i, &ExpressionPerRegion_S.RegionIndex);
if(List_Search(Expression_P->Case.PieceWiseFunction.ExpressionPerRegion,
&ExpressionPerRegion_S.RegionIndex, fcmp_Integer))
vyyerror(0, "Redefinition of piece-wise Function: %s [%d]",
Expression_P->Name, ExpressionPerRegion_S.RegionIndex);
else
List_Add(Expression_P->Case.PieceWiseFunction.ExpressionPerRegion,
&ExpressionPerRegion_S);
}
if((yyvsp[(3) - (7)].i) == -1) { List_Delete(Group_S.InitialList); }
}
else if ((yyvsp[(3) - (7)].i) == -3) // Default Case when GroupRHS is 'All'
Expression_P->Case.PieceWiseFunction.ExpressionIndex_Default = (yyvsp[(6) - (7)].i);
else vyyerror(0, "Bad Group right hand side");
;}
break;
case 72:
#line 947 "ProParser.y"
{
ListOfInt_Save_L = Group_S.InitialList;
;}
break;
case 73:
#line 952 "ProParser.y"
{
int i;
if((i = List_ISearchSeq
(Problem_S.Expression, (yyvsp[(1) - (10)].c), fcmp_Expression_Name)) < 0) {
/* Si le nom n'existe pas : */
i = List_Nbr(Problem_S.Expression);
Expression_S.Type = PIECEWISEFUNCTION2;
Expression_S.Case.PieceWiseFunction2.ExpressionPerRegion =
List_Create(25, 50, sizeof(struct ExpressionPerRegion2));
Expression_S.Case.PieceWiseFunction2.ExpressionIndex_Default = -1;
Expression_S.Case.PieceWiseFunction2.NumLastRegion[0] = -1;
Expression_S.Case.PieceWiseFunction2.NumLastRegion[1] = -1;
Add_Expression(&Expression_S, (yyvsp[(1) - (10)].c), 0);
Expression_P = (struct Expression*)List_Pointer(Problem_S.Expression, i);
}
else {
Expression_P = (struct Expression*)List_Pointer(Problem_S.Expression, i);
if(Expression_P->Type == UNDEFINED_EXP) {
Expression_P->Type = PIECEWISEFUNCTION2;
Expression_P->Case.PieceWiseFunction2.ExpressionPerRegion =
List_Create(25, 50, sizeof(struct ExpressionPerRegion2));
Expression_P->Case.PieceWiseFunction2.ExpressionIndex_Default = -1;
Expression_P->Case.PieceWiseFunction2.NumLastRegion[0] = -1;
Expression_P->Case.PieceWiseFunction2.NumLastRegion[1] = -1;
}
else if(Expression_P->Type != PIECEWISEFUNCTION2)
vyyerror(0, "Not double-piece-wise Expression: %s", (yyvsp[(1) - (10)].c));
Free((yyvsp[(1) - (10)].c));
}
if((yyvsp[(3) - (10)].i) >= 0 || (yyvsp[(3) - (10)].i) == -1) {
ExpressionPerRegion2_S.ExpressionIndex = (yyvsp[(9) - (10)].i);
for(int i = 0; i < List_Nbr(ListOfInt_Save_L); i++) {
List_Read(ListOfInt_Save_L, i, &ExpressionPerRegion2_S.RegionIndex[0]);
for(int j = 0; j < List_Nbr(Group_S.InitialList); j++) {
List_Read(Group_S.InitialList, i, &ExpressionPerRegion2_S.RegionIndex[1]);
if(List_Search(Expression_P->Case.PieceWiseFunction2.ExpressionPerRegion,
&ExpressionPerRegion2_S.RegionIndex[0], fcmp_Integer2))
vyyerror(0, "Redefinition of piece-wise Function: %s [%d, %d]",
Expression_P->Name, ExpressionPerRegion2_S.RegionIndex[0],
ExpressionPerRegion2_S.RegionIndex[1]);
else
List_Add(Expression_P->Case.PieceWiseFunction2.ExpressionPerRegion,
&ExpressionPerRegion2_S);
}
}
if((yyvsp[(3) - (10)].i) == -1) { List_Delete(Group_S.InitialList); }
}
else if ((yyvsp[(3) - (10)].i) == -3 && (yyvsp[(6) - (10)].i) == -3) // Default Case when GroupRHS is 'All' x2
Expression_P->Case.PieceWiseFunction2.ExpressionIndex_Default = (yyvsp[(9) - (10)].i);
else vyyerror(0, "Bad Group right hand side");
;}
break;
case 76:
#line 1015 "ProParser.y"
{
int i;
if ( (i = List_ISearchSeq
(Problem_S.Expression, (yyvsp[(3) - (3)].c), fcmp_Expression_Name)) < 0 ) {
Expression_S.Type = UNDEFINED_EXP ;
Add_Expression(&Expression_S, (yyvsp[(3) - (3)].c), 0) ;
}
else Free((yyvsp[(3) - (3)].c)) ;
;}
break;
case 77:
#line 1026 "ProParser.y"
{
for (int k = 0 ; k < (int)(yyvsp[(5) - (6)].d) ; k++) {
char tmpstr[256];
sprintf(tmpstr, "%s_%d", (yyvsp[(3) - (6)].c), k+1) ;
int i;
if ( (i = List_ISearchSeq(Problem_S.Expression, tmpstr,
fcmp_Expression_Name)) < 0 ) {
Expression_S.Type = UNDEFINED_EXP ;
Add_Expression(&Expression_S, tmpstr, 2) ;
}
}
Free((yyvsp[(3) - (6)].c)) ;
;}
break;
case 79:
#line 1046 "ProParser.y"
{
int i = List_ISearchSeq(Problem_S.Expression, (yyvsp[(3) - (3)].c), fcmp_Expression_Name);
if(i >= 0){
Free(((struct Expression *)List_Pointer(Problem_S.Expression, i))->Name);
List_PSuppress(Problem_S.Expression, i);
}
Free((yyvsp[(3) - (3)].c)) ;
;}
break;
case 80:
#line 1063 "ProParser.y"
{ Expression_S.Type = CONSTANT; Expression_S.Case.Constant = (yyvsp[(3) - (4)].d);
(yyval.i) = Add_Expression(&Expression_S, (char*)"Exp_Cst", 1);
;}
break;
case 81:
#line 1069 "ProParser.y"
{ int i;
if((i = List_ISearchSeq(Problem_S.Expression, (yyvsp[(3) - (4)].c), fcmp_Expression_Name)) < 0)
vyyerror(0, "Unknown name of Expression: %s", (yyvsp[(3) - (4)].c));
Free((yyvsp[(3) - (4)].c)); (yyval.i) = i;
;}
break;
case 82:
#line 1076 "ProParser.y"
{ Current_DofIndexInWholeQuantity = -2;
List_Reset(ListOfPointer_L); List_Reset(ListOfPointer2_L); ;}
break;
case 83:
#line 1079 "ProParser.y"
{ Expression_S.Type = WHOLEQUANTITY; Expression_S.Case.WholeQuantity = (yyvsp[(2) - (2)].l);
(yyval.i) = Add_Expression(&Expression_S, (char*)"Exp_Fct", 1); ;}
break;
case 84:
#line 1084 "ProParser.y"
{ Expression_S.Type = UNDEFINED_EXP;
(yyval.i) = Add_Expression(&Expression_S, (char*)"Exp_Undefined", 1);
;}
break;
case 85:
#line 1091 "ProParser.y"
{ List_Reset(ListOfInt_L); ;}
break;
case 87:
#line 1102 "ProParser.y"
{ List_Reset(ListOfInt_L); List_Add(ListOfInt_L, &((yyvsp[(1) - (1)].i))); ;}
break;
case 88:
#line 1105 "ProParser.y"
{ List_Add(ListOfInt_L, &((yyvsp[(3) - (3)].i))); ;}
break;
case 89:
#line 1111 "ProParser.y"
{ Current_WholeQuantity_L = List_Create(5, 5, sizeof(struct WholeQuantity));
List_Add(ListOfPointer_L, &Current_WholeQuantity_L);
;}
break;
case 90:
#line 1115 "ProParser.y"
{ (yyval.l) = *((List_T **)List_Pointer(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1));
List_Pop(ListOfPointer_L);
;}
break;
case 92:
#line 1127 "ProParser.y"
{
WholeQuantity_S.Type = WQ_TEST;
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
WholeQuantity_P = (struct WholeQuantity*)
List_Pointer(Current_WholeQuantity_L, List_Nbr(Current_WholeQuantity_L)-1);
List_Add(ListOfPointer2_L, &WholeQuantity_P);
List_Add(ListOfPointer2_L, &WholeQuantity_P);
Current_WholeQuantity_L = List_Create(5, 5, sizeof(struct WholeQuantity));
List_Add(ListOfPointer_L, &Current_WholeQuantity_L);
;}
break;
case 93:
#line 1140 "ProParser.y"
{
WholeQuantity_P =
*((struct WholeQuantity**)
List_Pointer(ListOfPointer2_L, List_Nbr(ListOfPointer2_L)-1));
List_Pop(ListOfPointer2_L);
WholeQuantity_P->Case.Test.WholeQuantity_True =
*((List_T **)List_Pointer(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1));
List_Pop(ListOfPointer_L);
Current_WholeQuantity_L = List_Create(5, 5, sizeof(struct WholeQuantity));
List_Add(ListOfPointer_L, &Current_WholeQuantity_L);
;}
break;
case 94:
#line 1154 "ProParser.y"
{
WholeQuantity_P =
*((struct WholeQuantity**)
List_Pointer(ListOfPointer2_L, List_Nbr(ListOfPointer2_L)-1));
List_Pop(ListOfPointer2_L);
WholeQuantity_P->Case.Test.WholeQuantity_False =
*((List_T **)List_Pointer(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1));
List_Pop(ListOfPointer_L);
List_Read(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1,
&Current_WholeQuantity_L);
;}
break;
case 95:
#line 1169 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_TIME;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_ProductValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 96:
#line 1177 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_CROSSPRODUCT;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_CrossProductValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 97:
#line 1185 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_CROSSPRODUCT;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_CrossProductValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 98:
#line 1193 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_DIVIDE;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_DivideValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 99:
#line 1201 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_PLUS;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_AddValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 100:
#line 1209 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_MINUS;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_SubstractValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 101:
#line 1217 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_MODULO;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_ModuloValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 102:
#line 1225 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_POWER;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_PowerValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 103:
#line 1233 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_LESS;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_LessValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 104:
#line 1241 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_GREATER;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_GreaterValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 105:
#line 1249 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_LESSOREQUAL;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_LessOrEqualValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 106:
#line 1257 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_GREATEROREQUAL;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_GreaterOrEqualValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 107:
#line 1265 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_EQUAL;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_EqualValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 108:
#line 1274 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_NOTEQUAL;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_NotEqualValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 109:
#line 1282 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_APPROXEQUAL;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_ApproxEqualValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 110:
#line 1290 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_AND;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_AndValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 111:
#line 1298 "ProParser.y"
{ WholeQuantity_S.Type = WQ_BINARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_OR;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_OrValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 112:
#line 1307 "ProParser.y"
{
WholeQuantity_S.Type = WQ_SAVENAMEDVALUE;
WholeQuantity_S.Case.NamedValue.Name = (yyvsp[(2) - (4)].c);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 113:
#line 1314 "ProParser.y"
{ WholeQuantity_S.Type = WQ_UNARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_NEG;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_NegValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S); ;}
break;
case 115:
#line 1324 "ProParser.y"
{ WholeQuantity_S.Type = WQ_UNARYOPERATOR;
WholeQuantity_S.Case.Operator.TypeOperator = OP_NOT;
#if defined(HAVE_KERNEL)
WholeQuantity_S.Case.Operator.Function = (void (*)())Cal_NotValue;
#endif
List_Add(Current_WholeQuantity_L, &WholeQuantity_S); ;}
break;
case 116:
#line 1332 "ProParser.y"
{ WholeQuantity_S.Type = WQ_CHANGECURRENTPOSITION ;
List_Add(Current_WholeQuantity_L, &WholeQuantity_S) ;
WholeQuantity_P = (struct WholeQuantity*)
List_Pointer(Current_WholeQuantity_L, List_Nbr(Current_WholeQuantity_L)-1);
List_Add(ListOfPointer2_L, &WholeQuantity_P);
Current_WholeQuantity_L = List_Create( 5, 5, sizeof(struct WholeQuantity)) ;
List_Add(ListOfPointer_L, &Current_WholeQuantity_L) ;
;}
break;
case 117:
#line 1344 "ProParser.y"
{
WholeQuantity_P =
*((struct WholeQuantity**)
List_Pointer(ListOfPointer2_L, List_Nbr(ListOfPointer2_L)-1)) ;
List_Pop(ListOfPointer2_L) ;
WholeQuantity_P->Case.ChangeCurrentPosition.WholeQuantity =
*((List_T **)List_Pointer(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1)) ;
List_Pop(ListOfPointer_L) ;
List_Read(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1,
&Current_WholeQuantity_L) ;
;}
break;
case 119:
#line 1365 "ProParser.y"
{ WholeQuantity_S.Type = WQ_CONSTANT;
WholeQuantity_S.Case.Constant = (yyvsp[(1) - (1)].d);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 120:
#line 1371 "ProParser.y"
{
/* Expression */
int l;
if((l = List_ISearchSeq(Problem_S.Expression, (yyvsp[(1) - (3)].c), fcmp_Expression_Name)) >= 0) {
WholeQuantity_S.Type = WQ_EXPRESSION;
WholeQuantity_S.Case.Expression.Index = l;
WholeQuantity_S.Case.Expression.NbrArguments = (yyvsp[(2) - (3)].i);
if((yyvsp[(2) - (3)].i) < 0) vyyerror(0, "Uncompatible argument for Function: %s", (yyvsp[(1) - (3)].c));
}
/* Built in functions */
else {
Get_Function2NbrForString(F_Function, (yyvsp[(1) - (3)].c), &FlagError,
&WholeQuantity_S.Case.Function.Fct,
&WholeQuantity_S.Case.Function.NbrParameters,
&WholeQuantity_S.Case.Function.NbrArguments);
WholeQuantity_S.Case.Function.Active = NULL;
if(!FlagError) {
/* arguments */
if((yyvsp[(2) - (3)].i) >= 0) {
if((yyvsp[(2) - (3)].i) == WholeQuantity_S.Case.Function.NbrArguments) {
WholeQuantity_S.Type = WQ_BUILTINFUNCTION;
}
else if(WholeQuantity_S.Case.Function.NbrArguments == -1 ||
(WholeQuantity_S.Case.Function.NbrArguments == -2)) {
/* && ($2)%2 == 0)) { */
WholeQuantity_S.Type = WQ_BUILTINFUNCTION;
WholeQuantity_S.Case.Function.NbrArguments = (yyvsp[(2) - (3)].i);
}
else {
vyyerror(0, "Wrong number of arguments for Function '%s' (%d instead of %d)",
(yyvsp[(1) - (3)].c), (yyvsp[(2) - (3)].i), WholeQuantity_S.Case.Function.NbrArguments);
}
}
else {
WholeQuantity_S.Type = WQ_EXTERNBUILTINFUNCTION;
}
/* parameters */
WholeQuantity_S.Case.Function.Para = 0;
WholeQuantity_S.Case.Function.String = StringForParameter;
if(WholeQuantity_S.Case.Function.NbrParameters >= 0 &&
WholeQuantity_S.Case.Function.NbrParameters != List_Nbr((yyvsp[(3) - (3)].l))) {
vyyerror(0, "Wrong number of parameters for Function '%s' (%d instead of %d)",
(yyvsp[(1) - (3)].c), List_Nbr((yyvsp[(3) - (3)].l)), WholeQuantity_S.Case.Function.NbrParameters);
}
else if(WholeQuantity_S.Case.Function.NbrParameters == -2 && List_Nbr((yyvsp[(3) - (3)].l))%2 != 0) {
vyyerror(0, "Wrong number of parameters for Function '%s' (%d is not even)",
(yyvsp[(1) - (3)].c), List_Nbr((yyvsp[(3) - (3)].l)));
}
else {
WholeQuantity_S.Case.Function.NbrParameters = List_Nbr((yyvsp[(3) - (3)].l));
if(WholeQuantity_S.Case.Function.NbrParameters > 0) {
WholeQuantity_S.Case.Function.Para =
(double *)Malloc
(WholeQuantity_S.Case.Function.NbrParameters * sizeof(double));
for(int i = 0; i < WholeQuantity_S.Case.Function.NbrParameters; i++)
List_Read((yyvsp[(3) - (3)].l), i, &WholeQuantity_S.Case.Function.Para[i]);
}
}
}
else {
vyyerror(0, "Unknown Function: %s", (yyvsp[(1) - (3)].c));
}
}
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
List_Delete((yyvsp[(3) - (3)].l));
StringForParameter = 0;
;}
break;
case 121:
#line 1448 "ProParser.y"
{ WholeQuantity_S.Type = WQ_OPERATORANDQUANTITY;
WholeQuantity_S.Case.OperatorAndQuantity.NbrArguments = 0;
WholeQuantity_S.Case.OperatorAndQuantity.TypeQuantity =
Get_DefineForString(QuantityFromFS_Type, (yyvsp[(1) - (2)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(1) - (2)].c), QuantityFromFS_Type);
vyyerror(0, "Unknown type of discrete Quantity: %s", (yyvsp[(1) - (2)].c));
}
Free((yyvsp[(1) - (2)].c));
WholeQuantity_S.Case.OperatorAndQuantity.TypeOperator = (yyvsp[(2) - (2)].t).Int1;
WholeQuantity_S.Case.OperatorAndQuantity.Index = (yyvsp[(2) - (2)].t).Int2;
switch(WholeQuantity_S.Case.OperatorAndQuantity.TypeQuantity) {
case QUANTITY_DOF :
if(Current_DofIndexInWholeQuantity == -1)
Current_DofIndexInWholeQuantity = List_Nbr(Current_WholeQuantity_L);
else if(Current_DofIndexInWholeQuantity == -2)
vyyerror(0, "Dof{} definition out of context");
else
vyyerror(0, "More than one Dof definition in Expression");
break;
case QUANTITY_NODOF :
if(Current_DofIndexInWholeQuantity == -2)
vyyerror(0, "NoDof definition out of context");
else if(Current_NoDofIndexInWholeQuantity == -1)
Current_NoDofIndexInWholeQuantity = List_Nbr(Current_WholeQuantity_L);
else
vyyerror(0, "More than one NoDof definition in Expression");
break;
}
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 122:
#line 1482 "ProParser.y"
{ WholeQuantity_S.Type = WQ_OPERATORANDQUANTITY;
WholeQuantity_S.Case.OperatorAndQuantity.NbrArguments = 0;
WholeQuantity_S.Case.OperatorAndQuantity.TypeQuantity = QUANTITY_SIMPLE;
WholeQuantity_S.Case.OperatorAndQuantity.TypeOperator = (yyvsp[(1) - (1)].t).Int1;
WholeQuantity_S.Case.OperatorAndQuantity.Index = (yyvsp[(1) - (1)].t).Int2;
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 123:
#line 1491 "ProParser.y"
{
if((yyvsp[(2) - (2)].i) != 1 && (yyvsp[(2) - (2)].i) != 2 && (yyvsp[(2) - (2)].i) != 3 && (yyvsp[(2) - (2)].i) != 4)
vyyerror(0, "Wrong number of arguments for discrete quantity evaluation (%d)", (yyvsp[(2) - (2)].i));
WholeQuantity_S.Type = WQ_OPERATORANDQUANTITYEVAL;
WholeQuantity_S.Case.OperatorAndQuantity.NbrArguments = (yyvsp[(2) - (2)].i);
WholeQuantity_S.Case.OperatorAndQuantity.TypeQuantity = QUANTITY_SIMPLE;
WholeQuantity_S.Case.OperatorAndQuantity.TypeOperator = (yyvsp[(1) - (2)].t).Int1;
WholeQuantity_S.Case.OperatorAndQuantity.Index = (yyvsp[(1) - (2)].t).Int2;
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 124:
#line 1503 "ProParser.y"
{ Last_DofIndexInWholeQuantity = Current_DofIndexInWholeQuantity; ;}
break;
case 125:
#line 1505 "ProParser.y"
{ WholeQuantity_S.Type = WQ_TIMEDERIVATIVE;
WholeQuantity_S.Case.TimeDerivative.WholeQuantity = (yyvsp[(4) - (5)].l);
List_Read(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1,
&Current_WholeQuantity_L);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
if(Current_DofIndexInWholeQuantity != Last_DofIndexInWholeQuantity)
vyyerror(0, "Dof{} definition out of context");
;}
break;
case 126:
#line 1516 "ProParser.y"
{ Last_DofIndexInWholeQuantity = Current_DofIndexInWholeQuantity; ;}
break;
case 127:
#line 1518 "ProParser.y"
{ WholeQuantity_S.Type = WQ_ATANTERIORTIMESTEP;
WholeQuantity_S.Case.AtAnteriorTimeStep.WholeQuantity = (yyvsp[(4) - (7)].l);
WholeQuantity_S.Case.AtAnteriorTimeStep.TimeStep = (yyvsp[(6) - (7)].i);
List_Read(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1,
&Current_WholeQuantity_L);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
if(Current_DofIndexInWholeQuantity != Last_DofIndexInWholeQuantity)
vyyerror(0, "Dof{} definition out of context");
;}
break;
case 128:
#line 1530 "ProParser.y"
{ Last_DofIndexInWholeQuantity = Current_DofIndexInWholeQuantity; ;}
break;
case 129:
#line 1532 "ProParser.y"
{ WholeQuantity_S.Type = WQ_MAXOVERTIME;
WholeQuantity_S.Case.MaxOverTime.WholeQuantity = (yyvsp[(4) - (9)].l);
WholeQuantity_S.Case.FourierSteinmetz.TimeInit = (yyvsp[(6) - (9)].d);
WholeQuantity_S.Case.FourierSteinmetz.TimeFinal = (yyvsp[(8) - (9)].d);
List_Read(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1,
&Current_WholeQuantity_L);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
if(Current_DofIndexInWholeQuantity != Last_DofIndexInWholeQuantity)
vyyerror(0, "Dof{} definition out of context");
;}
break;
case 130:
#line 1546 "ProParser.y"
{ Last_DofIndexInWholeQuantity = Current_DofIndexInWholeQuantity; ;}
break;
case 131:
#line 1548 "ProParser.y"
{ WholeQuantity_S.Type = WQ_FOURIERSTEINMETZ;
WholeQuantity_S.Case.FourierSteinmetz.WholeQuantity = (yyvsp[(4) - (15)].l);
WholeQuantity_S.Case.FourierSteinmetz.TimeInit = (yyvsp[(6) - (15)].d);
WholeQuantity_S.Case.FourierSteinmetz.TimeFinal = (yyvsp[(8) - (15)].d);
WholeQuantity_S.Case.FourierSteinmetz.NbrFrequency = (int)(yyvsp[(10) - (15)].d);
WholeQuantity_S.Case.FourierSteinmetz.Exponent_f = (yyvsp[(12) - (15)].d);
WholeQuantity_S.Case.FourierSteinmetz.Exponent_b = (yyvsp[(14) - (15)].d);
List_Read(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1,
&Current_WholeQuantity_L);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
if(Current_DofIndexInWholeQuantity != Last_DofIndexInWholeQuantity)
vyyerror(0, "Dof{} definition out of context");
;}
break;
case 132:
#line 1566 "ProParser.y"
{ Last_DofIndexInWholeQuantity = Current_DofIndexInWholeQuantity; ;}
break;
case 133:
#line 1568 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.Expression, (yyvsp[(3) - (11)].c), fcmp_Expression_Name)) < 0)
vyyerror(0, "Undefined function '%s' used in MHTransform", (yyvsp[(3) - (11)].c));
if(Current_DofIndexInWholeQuantity != Last_DofIndexInWholeQuantity)
vyyerror(0, "Dof{} definition cannot be used in MHTransform");
WholeQuantity_S.Type = WQ_MHTRANSFORM;
WholeQuantity_S.Case.MHTransform.Index = i;
WholeQuantity_S.Case.MHTransform.WholeQuantity = (yyvsp[(6) - (11)].l);
WholeQuantity_S.Case.MHTransform.NbrPoints = (int)(yyvsp[(10) - (11)].d);
List_Read(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1, &Current_WholeQuantity_L);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 134:
#line 1584 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.Expression, (yyvsp[(3) - (11)].c),fcmp_Expression_Name)) >= 0){
WholeQuantity_S.Type = WQ_MHJACNL;
WholeQuantity_S.Case.MHJacNL.Index = i;
WholeQuantity_S.Case.MHTransform.FunctionType = WQ_EXPRESSION;
WholeQuantity_S.Case.MHJacNL.NbrArguments = (yyvsp[(4) - (11)].i);
WholeQuantity_S.Case.MHJacNL.NbrParameters = List_Nbr((yyvsp[(5) - (11)].l));
if((yyvsp[(4) - (11)].i) < 0) vyyerror(0, "Uncompatible argument for Function (in MHJacNL): %s", (yyvsp[(3) - (11)].c));
}
/* Built in functions */
else {
Get_Function2NbrForString(F_Function, (yyvsp[(3) - (11)].c), &FlagError,
&WholeQuantity_S.Case.Function.Fct,
&WholeQuantity_S.Case.Function.NbrParameters,
&WholeQuantity_S.Case.Function.NbrArguments);
WholeQuantity_S.Case.Function.Active = NULL;
if(!FlagError) {
WholeQuantity_S.Type = WQ_MHJACNL;
// arguments
if((yyvsp[(4) - (11)].i) >= 0) {
if((yyvsp[(4) - (11)].i) == WholeQuantity_S.Case.Function.NbrArguments) {
WholeQuantity_S.Case.MHJacNL.FunctionType =WQ_BUILTINFUNCTION;
}
else if(WholeQuantity_S.Case.Function.NbrArguments == -1 ||
(WholeQuantity_S.Case.Function.NbrArguments == -2)) {
// && ($4)%2 == 0)) {
WholeQuantity_S.Case.MHJacNL.FunctionType = WQ_BUILTINFUNCTION ;
WholeQuantity_S.Case.Function.NbrArguments = (yyvsp[(4) - (11)].i);
}
else {
vyyerror(0, "Wrong number of arguments for Function (in MHJacNL) '%s' (%d instead of %d)",
(yyvsp[(3) - (11)].c), (yyvsp[(4) - (11)].i), WholeQuantity_S.Case.Function.NbrArguments);
}
}
else {
WholeQuantity_S.Case.MHJacNL.FunctionType = WQ_EXTERNBUILTINFUNCTION;
//WholeQuantity_S.Type = WQ_EXTERNBUILTINFUNCTION;
}
// parameters
WholeQuantity_S.Case.Function.Para = 0;
WholeQuantity_S.Case.Function.String = StringForParameter;
if(WholeQuantity_S.Case.Function.NbrParameters >= 0 &&
WholeQuantity_S.Case.Function.NbrParameters != List_Nbr((yyvsp[(5) - (11)].l))) {
vyyerror(0, "Wrong number of parameters for Function '%s' (%d instead of %d)",
(yyvsp[(3) - (11)].c), List_Nbr((yyvsp[(5) - (11)].l)), WholeQuantity_S.Case.Function.NbrParameters);
}
else if(WholeQuantity_S.Case.Function.NbrParameters == -2 && List_Nbr((yyvsp[(5) - (11)].l))%2 != 0) {
vyyerror(0, "Wrong number of parameters for Function '%s' (%d is not even)",
(yyvsp[(3) - (11)].c), List_Nbr((yyvsp[(5) - (11)].l)));
}
else {
WholeQuantity_S.Case.Function.NbrParameters = List_Nbr((yyvsp[(5) - (11)].l));
if(WholeQuantity_S.Case.Function.NbrParameters > 0) {
WholeQuantity_S.Case.Function.Para =
(double *)Malloc
(WholeQuantity_S.Case.Function.NbrParameters * sizeof(double));
for(int i = 0; i < WholeQuantity_S.Case.Function.NbrParameters; i++)
List_Read((yyvsp[(5) - (11)].l), i, &WholeQuantity_S.Case.Function.Para[i]);
}
}
}
else {
vyyerror(0, "Undefined function '%s' used in MHJacNL", (yyvsp[(3) - (11)].c));
}
}
WholeQuantity_S.Case.MHJacNL.NbrPoints = (int)(yyvsp[(8) - (11)].d);
WholeQuantity_S.Case.MHJacNL.FreqOffSet = (int)(yyvsp[(10) - (11)].d);
List_Read(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1, &Current_WholeQuantity_L);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
List_Delete((yyvsp[(5) - (11)].l));
StringForParameter = 0;
;}
break;
case 135:
#line 1664 "ProParser.y"
{ WholeQuantity_S.Type = WQ_SOLIDANGLE;
WholeQuantity_S.Case.OperatorAndQuantity.Index = (yyvsp[(3) - (4)].t).Int2;
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 136:
#line 1670 "ProParser.y"
{ WholeQuantity_S.Type = WQ_ORDER;
WholeQuantity_S.Case.OperatorAndQuantity.Index = (yyvsp[(3) - (4)].t).Int2;
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 137:
#line 1676 "ProParser.y"
{ Last_DofIndexInWholeQuantity = Current_DofIndexInWholeQuantity; ;}
break;
case 138:
#line 1678 "ProParser.y"
{ WholeQuantity_S.Type = WQ_TRACE;
WholeQuantity_S.Case.Trace.WholeQuantity = (yyvsp[(4) - (7)].l);
WholeQuantity_S.Case.Trace.InIndex = Num_Group(&Group_S, (char*)"WQ_Trace_In", (yyvsp[(6) - (7)].i));
if(Group_S.Type != ELEMENTLIST || Group_S.SuppListType != SUPPLIST_CONNECTEDTO)
vyyerror(0, "Group for Trace should be of Type 'ElementsOf[x, ConnectedTo y]'");
WholeQuantity_S.Case.Trace.DofIndexInWholeQuantity = -1;
if(Current_DofIndexInWholeQuantity != Last_DofIndexInWholeQuantity){
for(int i = 0; i < List_Nbr((yyvsp[(4) - (7)].l)); i++){
WholeQuantity_P = (struct WholeQuantity*)List_Pointer((yyvsp[(4) - (7)].l), i);
if(WholeQuantity_P->Type == WQ_OPERATORANDQUANTITY)
if(WholeQuantity_P->Case.OperatorAndQuantity.TypeQuantity == QUANTITY_DOF){
WholeQuantity_S.Case.Trace.DofIndexInWholeQuantity = i;
Current_DofIndexInWholeQuantity = -4;
TypeOperatorDofInTrace = WholeQuantity_P->Case.OperatorAndQuantity.TypeOperator;
DefineQuantityIndexDofInTrace = WholeQuantity_P->Case.OperatorAndQuantity.Index;
}
}
if(Current_DofIndexInWholeQuantity != -4)
vyyerror(0, "Dof{} definition out of context in Trace operator");
}
List_Read(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1,
&Current_WholeQuantity_L);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 139:
#line 1707 "ProParser.y"
{ WholeQuantity_S.Type = WQ_CAST;
WholeQuantity_S.Case.Cast.WholeQuantity = (yyvsp[(5) - (6)].l);
int i;
if((i = List_ISearchSeq(Formulation_S.DefineQuantity, (yyvsp[(2) - (6)].c),
fcmp_DefineQuantity_Name)) < 0) {
if(!strcmp((yyvsp[(2) - (6)].c), "Real"))
WholeQuantity_S.Case.Cast.NbrHar = 1;
else if(!strcmp((yyvsp[(2) - (6)].c), "Complex"))
WholeQuantity_S.Case.Cast.NbrHar = 2;
else
vyyerror(0, "Unknown Cast: %s", (yyvsp[(2) - (6)].c));
}
else {
WholeQuantity_S.Case.Cast.NbrHar = 0;
WholeQuantity_S.Case.Cast.FunctionSpaceIndexForType =
((struct DefineQuantity *)List_Pointer(Formulation_S.DefineQuantity, i))
->FunctionSpaceIndex;
}
Free((yyvsp[(2) - (6)].c));
List_Read(ListOfPointer_L, List_Nbr(ListOfPointer_L)-1,
&Current_WholeQuantity_L);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 140:
#line 1733 "ProParser.y"
{ WholeQuantity_S.Type = WQ_CURRENTVALUE;
Get_PointerForString(Current_Value, (yyvsp[(2) - (2)].c), &FlagError,
(void **)&WholeQuantity_S.Case.CurrentValue.Value);
if(FlagError){
WholeQuantity_S.Type = WQ_NAMEDVALUESAVED;
WholeQuantity_S.Case.NamedValue.Name = (yyvsp[(2) - (2)].c);
}
else{
Free((yyvsp[(2) - (2)].c));
}
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 141:
#line 1748 "ProParser.y"
{ WholeQuantity_S.Type = WQ_CURRENTVALUE;
Get_PointerForString(Current_Value, "TimeStep", &FlagError,
(void **)&WholeQuantity_S.Case.CurrentValue.Value);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 142:
#line 1754 "ProParser.y"
{ WholeQuantity_S.Type = WQ_CURRENTVALUE;
Get_PointerForString(Current_Value, "DTime", &FlagError,
(void **)&WholeQuantity_S.Case.CurrentValue.Value);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 143:
#line 1761 "ProParser.y"
{ WholeQuantity_S.Type = WQ_ARGUMENT;
WholeQuantity_S.Case.Argument.Index = (yyvsp[(2) - (2)].i);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 144:
#line 1767 "ProParser.y"
{
WholeQuantity_S.Type = WQ_SAVEVALUE;
WholeQuantity_S.Case.SaveValue.Index = (int)(yyvsp[(3) - (3)].d) - 1;
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 145:
#line 1774 "ProParser.y"
{
WholeQuantity_S.Type = WQ_VALUESAVED;
WholeQuantity_S.Case.ValueSaved.Index = (int)(yyvsp[(2) - (2)].d) - 1;
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 146:
#line 1781 "ProParser.y"
{
WholeQuantity_S.Type = WQ_SHOWVALUE;
WholeQuantity_S.Case.ShowValue.Index = (int)(yyvsp[(3) - (3)].d);
List_Add(Current_WholeQuantity_L, &WholeQuantity_S);
;}
break;
case 147:
#line 1788 "ProParser.y"
{ WholeQuantity_S.Type = WQ_CONSTANT ;
WholeQuantity_S.Case.Constant = (yyvsp[(1) - (1)].i) ;
List_Add(Current_WholeQuantity_L, &WholeQuantity_S) ;
;}
break;
case 148:
#line 1794 "ProParser.y"
{ WholeQuantity_S.Type = WQ_CONSTANT ;
WholeQuantity_S.Case.Constant = (yyvsp[(1) - (1)].i) ;
List_Add(Current_WholeQuantity_L, &WholeQuantity_S) ;
;}
break;
case 149:
#line 1803 "ProParser.y"
{ (yyval.i) = -1; ;}
break;
case 150:
#line 1804 "ProParser.y"
{ (yyval.i) = 0; ;}
break;
case 151:
#line 1805 "ProParser.y"
{ (yyval.i) = (yyvsp[(2) - (3)].i); ;}
break;
case 152:
#line 1810 "ProParser.y"
{ (yyval.i) = 1; ;}
break;
case 153:
#line 1811 "ProParser.y"
{ (yyval.i) = (yyvsp[(1) - (3)].i) + 1; ;}
break;
case 154:
#line 1817 "ProParser.y"
{ (yyval.l) = NULL; ;}
break;
case 155:
#line 1820 "ProParser.y"
{ (yyval.l) = (yyvsp[(2) - (3)].l); ;}
break;
case 156:
#line 1823 "ProParser.y"
{ /* Attention: provisoire. Note: Impossible a mettre dans MultiFExpr
car conflit avec Affectation dans Group */
(yyval.l) = List_Create(2, 1, sizeof(double));
double d = (double)Num_Group(&Group_S, (char*)"PA_Region", (yyvsp[(4) - (6)].i));
List_Add((yyval.l), &d);
;}
break;
case 157:
#line 1831 "ProParser.y"
{ (yyval.l) = NULL; StringForParameter = (yyvsp[(2) - (3)].c); ;}
break;
case 158:
#line 1834 "ProParser.y"
{ (yyval.l) = NULL; StringForParameter = (yyvsp[(3) - (4)].c); ;}
break;
case 159:
#line 1845 "ProParser.y"
{ if(!Problem_S.JacobianMethod)
Problem_S.JacobianMethod =
List_Create(5, 5, sizeof (struct JacobianMethod));
;}
break;
case 161:
#line 1857 "ProParser.y"
{
if (level_Append && index_Append>=0)
List_Write(Problem_S.JacobianMethod, index_Append, &JacobianMethod_S);
else
List_Add(Problem_S.JacobianMethod, &JacobianMethod_S);
;}
break;
case 163:
#line 1870 "ProParser.y"
{
JacobianMethod_S.Name = NULL; JacobianMethod_S.JacobianCase = NULL;
level_Append = 0;
;}
break;
case 166:
#line 1882 "ProParser.y"
{ level_Append = (yyvsp[(1) - (2)].i); index_Append = -1; ;}
break;
case 167:
#line 1885 "ProParser.y"
{
index_Append =
Check_NameOfStructExist("JacobianMethod", Problem_S.JacobianMethod,
(yyvsp[(2) - (3)].c), fcmp_JacobianMethod_Name, level_Append);
if (index_Append<0)
JacobianMethod_S.Name = (yyvsp[(2) - (3)].c);
else{
List_Read(Problem_S.JacobianMethod, index_Append, &JacobianMethod_S);
Free((yyvsp[(2) - (3)].c));
}
;}
break;
case 168:
#line 1898 "ProParser.y"
{ JacobianMethod_S.JacobianCase = (yyvsp[(3) - (4)].l); ;}
break;
case 169:
#line 1905 "ProParser.y"
{
(yyval.l) = JacobianMethod_S.JacobianCase?
JacobianMethod_S.JacobianCase :
List_Create(5, 5, sizeof (struct JacobianCase));
;}
break;
case 170:
#line 1911 "ProParser.y"
{ List_Add((yyval.l) = (yyvsp[(1) - (4)].l), &JacobianCase_S); ;}
break;
case 172:
#line 1919 "ProParser.y"
{ JacobianCase_S.RegionIndex = -1;
JacobianCase_S.TypeJacobian = JACOBIAN_VOL;
JacobianCase_S.CoefficientIndex = -1; ;}
break;
case 174:
#line 1930 "ProParser.y"
{
if ((yyvsp[(2) - (3)].i) >=0)
JacobianCase_S.RegionIndex = Num_Group(&Group_S, (char*)"JA_Region", (yyvsp[(2) - (3)].i));
else if ((yyvsp[(2) - (3)].i) == -3)
JacobianCase_S.RegionIndex = -1;
;}
break;
case 175:
#line 1938 "ProParser.y"
{ JacobianCase_S.TypeJacobian =
Get_Define1NbrForString(Jacobian_Type, (yyvsp[(2) - (4)].c), &FlagError,
&JacobianCase_S.NbrParameters);
if(!FlagError) {
if(JacobianCase_S.NbrParameters == -2 && (List_Nbr((yyvsp[(3) - (4)].l)))%2 != 0)
vyyerror(0, "Wrong number of parameters for Jacobian '%s' (%d is not even)",
(yyvsp[(2) - (4)].c), List_Nbr((yyvsp[(3) - (4)].l)));
if(JacobianCase_S.NbrParameters < 0)
JacobianCase_S.NbrParameters = List_Nbr((yyvsp[(3) - (4)].l));
if(List_Nbr((yyvsp[(3) - (4)].l)) == JacobianCase_S.NbrParameters) {
if(JacobianCase_S.NbrParameters) {
JacobianCase_S.Para =
(double *)Malloc(JacobianCase_S.NbrParameters * sizeof(double));
for(int i = 0; i < JacobianCase_S.NbrParameters; i++)
List_Read((yyvsp[(3) - (4)].l), i, &JacobianCase_S.Para[i]);
}
}
else
vyyerror(0, "Wrong number of parameters for Jacobian '%s' (%d instead of %d)",
(yyvsp[(2) - (4)].c), List_Nbr((yyvsp[(3) - (4)].l)), JacobianCase_S.NbrParameters);
}
else{
Get_Valid_SXD1N((yyvsp[(2) - (4)].c), Jacobian_Type);
vyyerror(0, "Unknown type of Jacobian: %s", (yyvsp[(2) - (4)].c));
}
Free((yyvsp[(2) - (4)].c));
List_Delete((yyvsp[(3) - (4)].l));
;}
break;
case 176:
#line 1968 "ProParser.y"
{ JacobianCase_S.CoefficientIndex = (yyvsp[(2) - (3)].i); ;}
break;
case 177:
#line 1979 "ProParser.y"
{ if(!Problem_S.IntegrationMethod)
Problem_S.IntegrationMethod =
List_Create(5, 5, sizeof(struct IntegrationMethod));
;}
break;
case 179:
#line 1990 "ProParser.y"
{
if (level_Append && index_Append>=0)
List_Write(Problem_S.IntegrationMethod, index_Append, &IntegrationMethod_S);
else
List_Add(Problem_S.IntegrationMethod, &IntegrationMethod_S);
;}
break;
case 181:
#line 2003 "ProParser.y"
{
IntegrationMethod_S.Name = NULL;
IntegrationMethod_S.IntegrationCase = NULL;
IntegrationMethod_S.CriterionIndex = -1;
level_Append = 0;
;}
break;
case 184:
#line 2018 "ProParser.y"
{ level_Append = (yyvsp[(1) - (2)].i); index_Append = -1; ;}
break;
case 185:
#line 2021 "ProParser.y"
{
index_Append =
Check_NameOfStructExist("IntegrationMethod", Problem_S.IntegrationMethod,
(yyvsp[(2) - (3)].c), fcmp_IntegrationMethod_Name, level_Append);
if (index_Append<0)
IntegrationMethod_S.Name = (yyvsp[(2) - (3)].c);
else{
List_Read(Problem_S.IntegrationMethod, index_Append, &IntegrationMethod_S);
Free((yyvsp[(2) - (3)].c));
}
;}
break;
case 186:
#line 2034 "ProParser.y"
{ IntegrationMethod_S.CriterionIndex = (yyvsp[(2) - (3)].i); ;}
break;
case 187:
#line 2037 "ProParser.y"
{ IntegrationMethod_S.IntegrationCase = (yyvsp[(3) - (4)].l); ;}
break;
case 188:
#line 2044 "ProParser.y"
{ (yyval.l) = IntegrationMethod_S.IntegrationCase?
IntegrationMethod_S.IntegrationCase :
List_Create(5, 5, sizeof (struct IntegrationCase));
;}
break;
case 189:
#line 2050 "ProParser.y"
{ List_Add((yyval.l) = (yyvsp[(1) - (4)].l), &IntegrationCase_S); ;}
break;
case 191:
#line 2058 "ProParser.y"
{
IntegrationCase_S.Type = GAUSS;
IntegrationCase_S.SubType = STANDARD;
;}
break;
case 193:
#line 2070 "ProParser.y"
{ IntegrationCase_S.Type =
Get_DefineForString(Integration_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), Integration_Type);
vyyerror(0, "Unknown type of Integration method: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 194:
#line 2080 "ProParser.y"
{ IntegrationCase_S.SubType =
Get_DefineForString(Integration_SubType, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), Integration_Type);
vyyerror(0, "Unknown subtype of Integration method: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 195:
#line 2090 "ProParser.y"
{ IntegrationCase_S.Case = (yyvsp[(3) - (4)].l); ;}
break;
case 196:
#line 2097 "ProParser.y"
{ (yyval.l) = List_Create(5, 5, sizeof (struct Quadrature)); ;}
break;
case 197:
#line 2100 "ProParser.y"
{ List_Add((yyval.l) = (yyvsp[(1) - (4)].l), &QuadratureCase_S); ;}
break;
case 198:
#line 2107 "ProParser.y"
{ QuadratureCase_S.ElementType = TRIANGLE;
QuadratureCase_S.NumberOfPoints = 4;
QuadratureCase_S.MaxNumberOfPoints = 4;
QuadratureCase_S.NumberOfDivisions = 1;
QuadratureCase_S.MaxNumberOfDivisions = 1;
QuadratureCase_S.StoppingCriterion = 1.E-4;
QuadratureCase_S.Function = 0; //FIXME(void (*)())Gauss_Triangle;
;}
break;
case 200:
#line 2123 "ProParser.y"
{ QuadratureCase_S.ElementType = Get_DefineForString(Element_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), Element_Type);
vyyerror(0, "Unknown type of Element: %s", (yyvsp[(2) - (3)].c));
}
switch(IntegrationCase_S.SubType) {
case STANDARD :
switch (IntegrationCase_S.Type) {
case GAUSS :
Get_FunctionForDefine
(FunctionForGauss, QuadratureCase_S.ElementType,
&FlagError, (void (**)())&QuadratureCase_S.Function);
break;
case GAUSSLEGENDRE :
Get_FunctionForDefine
(FunctionForGaussLegendre, QuadratureCase_S.ElementType,
&FlagError, (void (**)())&QuadratureCase_S.Function);
break;
default :
vyyerror(0, "Incompatible type of Integration method");
break;
}
break;
case SINGULAR :
switch (IntegrationCase_S.Type) {
case GAUSS :
Get_FunctionForDefine
(FunctionForSingularGauss, QuadratureCase_S.ElementType,
&FlagError, (void (**)())&QuadratureCase_S.Function);
break;
default :
vyyerror(0, "Incompatible type of Integration method");
break;
}
break;
default :
vyyerror(0, "Incompatible type of Integration method");
break;
}
if(FlagError) vyyerror(0, "Bad type of Integration method for Element: %s", (yyvsp[(2) - (3)].c));
Free((yyvsp[(2) - (3)].c));
;}
break;
case 201:
#line 2171 "ProParser.y"
{ QuadratureCase_S.NumberOfPoints = (int)(yyvsp[(2) - (3)].d); ;}
break;
case 202:
#line 2174 "ProParser.y"
{ QuadratureCase_S.MaxNumberOfPoints = (int)(yyvsp[(2) - (3)].d); ;}
break;
case 203:
#line 2177 "ProParser.y"
{ QuadratureCase_S.NumberOfDivisions = (int)(yyvsp[(2) - (3)].d); ;}
break;
case 204:
#line 2180 "ProParser.y"
{ QuadratureCase_S.MaxNumberOfDivisions = (int)(yyvsp[(2) - (3)].d); ;}
break;
case 205:
#line 2183 "ProParser.y"
{ QuadratureCase_S.StoppingCriterion = (yyvsp[(2) - (3)].d); ;}
break;
case 206:
#line 2194 "ProParser.y"
{ if(!Problem_S.Constraint)
Problem_S.Constraint = List_Create(20, 20, sizeof (struct Constraint));
;}
break;
case 208:
#line 2204 "ProParser.y"
{
if (level_Append && index_Append>=0)
List_Write(Problem_S.Constraint, index_Append, &Constraint_S);
else
List_Add(Problem_S.Constraint, &Constraint_S);
;}
break;
case 210:
#line 2217 "ProParser.y"
{ Constraint_S.Name = NULL;
Constraint_S.Type = ASSIGN;
Constraint_S.ConstraintPerRegion = NULL;
Constraint_S.MultiConstraintPerRegion = NULL;
level_Append = 0;
;}
break;
case 212:
#line 2231 "ProParser.y"
{ level_Append = (yyvsp[(1) - (2)].i); index_Append = -1; ;}
break;
case 213:
#line 2234 "ProParser.y"
{
index_Append =
Check_NameOfStructExist("Constraint", Problem_S.Constraint,
(yyvsp[(2) - (3)].c), fcmp_Constraint_Name, level_Append);
if (index_Append<0)
Constraint_S.Name = (yyvsp[(2) - (3)].c);
else{
List_Read(Problem_S.Constraint, index_Append, &Constraint_S);
Free((yyvsp[(2) - (3)].c));
}
;}
break;
case 214:
#line 2247 "ProParser.y"
{ Constraint_S.Type = Get_DefineForString(Constraint_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), Constraint_Type);
vyyerror(0, "Unknown type of Constraint: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 215:
#line 2256 "ProParser.y"
{
if (Constraint_S.Type == NETWORK)
vyyerror(0, "Unnamed Case incompatible with Network Type");
Constraint_S.ConstraintPerRegion = (yyvsp[(3) - (4)].l);
;}
break;
case 216:
#line 2263 "ProParser.y"
{
if (Constraint_S.Type != NETWORK)
vyyerror(0, "Named Case incompatible with Type (only with Network type)");
if(!Constraint_S.MultiConstraintPerRegion)
Constraint_S.MultiConstraintPerRegion =
List_Create(5, 5, sizeof(struct MultiConstraintPerRegion));
MultiConstraintPerRegion_S.Name = (yyvsp[(2) - (5)].c);
MultiConstraintPerRegion_S.ConstraintPerRegion = (yyvsp[(4) - (5)].l);
MultiConstraintPerRegion_S.Active = NULL;
List_Add(Constraint_S.MultiConstraintPerRegion,
&MultiConstraintPerRegion_S);
;}
break;
case 218:
#line 2286 "ProParser.y"
{
(yyval.l) = (Constraint_S.Type != NETWORK && Constraint_S.ConstraintPerRegion)?
Constraint_S.ConstraintPerRegion :
List_Create(6, 6, sizeof (struct ConstraintPerRegion));
;}
break;
case 219:
#line 2293 "ProParser.y"
{
List_Add((yyval.l) = (yyvsp[(1) - (4)].l), &ConstraintPerRegion_S);
;}
break;
case 220:
#line 2298 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (2)].l);
;}
break;
case 221:
#line 2307 "ProParser.y"
{
ConstraintPerRegion_S.Type = Constraint_S.Type;
ConstraintPerRegion_S.RegionIndex = -1;
ConstraintPerRegion_S.SubRegionIndex = -1;
ConstraintPerRegion_S.SubRegion2Index = -1;
ConstraintPerRegion_S.TimeFunctionIndex = -1;
;}
break;
case 223:
#line 2322 "ProParser.y"
{ ConstraintPerRegion_S.Type =
Get_DefineForString(Constraint_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), Constraint_Type);
vyyerror(0, "Unknown type of Constraint: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 224:
#line 2332 "ProParser.y"
{
ConstraintPerRegion_S.RegionIndex = Num_Group(&Group_S, (char*)"CO_Region", (yyvsp[(2) - (3)].i));
;}
break;
case 225:
#line 2337 "ProParser.y"
{
ConstraintPerRegion_S.SubRegionIndex =
Num_Group(&Group_S, (char*)"CO_SubRegion", (yyvsp[(2) - (3)].i));
;}
break;
case 226:
#line 2343 "ProParser.y"
{
ConstraintPerRegion_S.SubRegion2Index =
Num_Group(&Group_S, (char*)"CO_SubRegion2", (yyvsp[(2) - (3)].i));
;}
break;
case 227:
#line 2349 "ProParser.y"
{
ConstraintPerRegion_S.TimeFunctionIndex = (yyvsp[(2) - (3)].i);
if(Is_ExpressionPieceWiseDefined((yyvsp[(2) - (3)].i)))
vyyerror(0, "TimeFunction should never be piece-wise defined");
;}
break;
case 228:
#line 2356 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == ASSIGN ||
ConstraintPerRegion_S.Type == INIT){
ConstraintPerRegion_S.Case.Fixed.ExpressionIndex = (yyvsp[(2) - (3)].i);
ConstraintPerRegion_S.Case.Fixed.ExpressionIndex2 = -1;
}
else vyyerror(0, "Value incompatible with Type");
;}
break;
case 229:
#line 2366 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == ASSIGN ||
ConstraintPerRegion_S.Type == INIT){
ConstraintPerRegion_S.Case.Fixed.ExpressionIndex = (yyvsp[(5) - (7)].i);
ConstraintPerRegion_S.Case.Fixed.ExpressionIndex2 = (yyvsp[(3) - (7)].i);
}
else vyyerror(0, "Value incompatible with Type");
;}
break;
case 230:
#line 2376 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == ASSIGNFROMRESOLUTION ||
ConstraintPerRegion_S.Type == INITFROMRESOLUTION)
ConstraintPerRegion_S.Case.Solve.ResolutionName = (yyvsp[(2) - (3)].c);
else vyyerror(0, "NameOfResolution incompatible with Type");
;}
break;
case 231:
#line 2384 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == NETWORK) {
ConstraintPerRegion_S.Case.Network.Node1 = (int)(yyvsp[(3) - (7)].d);
ConstraintPerRegion_S.Case.Network.Node2 = (int)(yyvsp[(5) - (7)].d);
}
else vyyerror(0, "Branch incompatible with Type");
;}
break;
case 232:
#line 2393 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == NETWORK) {
ConstraintPerRegion_S.Case.Network.Node1 = (int)(yyvsp[(4) - (11)].d);
ConstraintPerRegion_S.Case.Network.Node2 = (int)(yyvsp[(8) - (11)].d);
}
else vyyerror(0, "Branch incompatible with Type");
;}
break;
case 233:
#line 2402 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == CST_LINK ||
ConstraintPerRegion_S.Type == CST_LINKCPLX) {
ConstraintPerRegion_S.Case.Link.RegionRefIndex =
Num_Group(&Group_S, (char*)"CO_RegionRef", (yyvsp[(2) - (3)].i));
ConstraintPerRegion_S.Case.Link.SubRegionRefIndex = -1;
ConstraintPerRegion_S.Case.Link.FilterIndex = -1;
ConstraintPerRegion_S.Case.Link.FunctionIndex = -1;
ConstraintPerRegion_S.Case.Link.CoefIndex = -1;
ConstraintPerRegion_S.Case.Link.FilterIndex2 = -1;
ConstraintPerRegion_S.Case.Link.FunctionIndex2 = -1;
ConstraintPerRegion_S.Case.Link.CoefIndex2 = -1;
ConstraintPerRegion_S.Case.Link.ToleranceFactor = 1.e-8;
}
else vyyerror(0, "RegionRef incompatible with Type");
;}
break;
case 234:
#line 2421 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == CST_LINK ||
ConstraintPerRegion_S.Type == CST_LINKCPLX)
ConstraintPerRegion_S.Case.Link.SubRegionRefIndex =
Num_Group(&Group_S, (char*)"CO_RegionRef", (yyvsp[(2) - (3)].i));
else vyyerror(0, "SubRegionRef incompatible with Type");
;}
break;
case 235:
#line 2430 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == CST_LINK ||
ConstraintPerRegion_S.Type == CST_LINKCPLX)
ConstraintPerRegion_S.Case.Link.FunctionIndex = (yyvsp[(2) - (3)].i);
else vyyerror(0, "Function incompatible with Type");
;}
break;
case 236:
#line 2438 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == CST_LINK ||
ConstraintPerRegion_S.Type == CST_LINKCPLX)
ConstraintPerRegion_S.Case.Link.CoefIndex = (yyvsp[(2) - (3)].i);
else vyyerror(0, "Coefficient incompatible with Type");
;}
break;
case 237:
#line 2446 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == CST_LINK ||
ConstraintPerRegion_S.Type == CST_LINKCPLX) {
ConstraintPerRegion_S.Case.Link.FilterIndex = (yyvsp[(2) - (3)].i);
ConstraintPerRegion_S.Case.Link.FilterIndex2 = -1;
}
else vyyerror(0, "Filter incompatible with Type");
;}
break;
case 238:
#line 2456 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == CST_LINK ||
ConstraintPerRegion_S.Type == CST_LINKCPLX) {
ConstraintPerRegion_S.Case.Link.FunctionIndex = (yyvsp[(3) - (7)].i);
ConstraintPerRegion_S.Case.Link.FunctionIndex2 = (yyvsp[(5) - (7)].i);
}
else vyyerror(0, "Function incompatible with Type");
;}
break;
case 239:
#line 2466 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == CST_LINK ||
ConstraintPerRegion_S.Type == CST_LINKCPLX) {
ConstraintPerRegion_S.Case.Link.ToleranceFactor = (yyvsp[(2) - (3)].d);
}
else vyyerror(0, "ToleranceFactor incompatible with Type");
;}
break;
case 240:
#line 2475 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == CST_LINK ||
ConstraintPerRegion_S.Type == CST_LINKCPLX) {
ConstraintPerRegion_S.Case.Link.CoefIndex = (yyvsp[(3) - (7)].i);
ConstraintPerRegion_S.Case.Link.CoefIndex2 = (yyvsp[(5) - (7)].i);
}
else vyyerror(0, "Coefficient incompatible with Type");
;}
break;
case 241:
#line 2485 "ProParser.y"
{
if(ConstraintPerRegion_S.Type == CST_LINK ||
ConstraintPerRegion_S.Type == CST_LINKCPLX) {
ConstraintPerRegion_S.Case.Link.FilterIndex = (yyvsp[(3) - (7)].i);
ConstraintPerRegion_S.Case.Link.FilterIndex2 = (yyvsp[(5) - (7)].i);
}
else vyyerror(0, "Filter incompatible with Type");
;}
break;
case 242:
#line 2505 "ProParser.y"
{ if(!Problem_S.FunctionSpace)
Problem_S.FunctionSpace =
List_Create(10, 5, sizeof (struct FunctionSpace));
;}
break;
case 244:
#line 2516 "ProParser.y"
{
if (level_Append && index_Append>=0)
List_Write(Problem_S.FunctionSpace, index_Append, &FunctionSpace_S);
else
List_Add(Problem_S.FunctionSpace, &FunctionSpace_S);
;}
break;
case 246:
#line 2530 "ProParser.y"
{ FunctionSpace_S.Name = NULL; FunctionSpace_S.Type = FORM0;
FunctionSpace_S.BasisFunction = FunctionSpace_S.SubSpace =
FunctionSpace_S.GlobalQuantity = FunctionSpace_S.Constraint = NULL;
level_Append = 0;
;}
break;
case 249:
#line 2545 "ProParser.y"
{ level_Append = (yyvsp[(1) - (2)].i); index_Append = -1; ;}
break;
case 250:
#line 2548 "ProParser.y"
{
index_Append =
Check_NameOfStructExist("FunctionSpace", Problem_S.FunctionSpace,
(yyvsp[(2) - (3)].c), fcmp_FunctionSpace_Name, level_Append);
if (index_Append<0)
FunctionSpace_S.Name = (yyvsp[(2) - (3)].c);
else{
List_Read(Problem_S.FunctionSpace, index_Append, &FunctionSpace_S);
Free((yyvsp[(2) - (3)].c));
}
;}
break;
case 251:
#line 2561 "ProParser.y"
{ FunctionSpace_S.Type = Get_DefineForString(Field_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), Field_Type);
vyyerror(0, "Unknown type of FunctionSpace: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 256:
#line 2582 "ProParser.y"
{
if (!FunctionSpace_S.BasisFunction)
FunctionSpace_S.BasisFunction =
List_Create(6, 6, sizeof (struct BasisFunction));
Current_BasisFunction_L = FunctionSpace_S.BasisFunction;
;}
break;
case 257:
#line 2590 "ProParser.y"
{
/*
int i;
if((i = List_ISearchSeq(FunctionSpace_S.BasisFunction, BasisFunction_S.Name,
fcmp_BasisFunction_Name)) < 0) {
*/
if(index_Append_2 < 0) {
BasisFunction_S.Num = Num_BasisFunction;
Num_BasisFunction += (BasisFunction_S.SubFunction)?
List_Nbr(BasisFunction_S.SubFunction) : 1;
}
else
if(!level_Append_2){
// Region-wise BasisFunction => same Num
BasisFunction_S.Num =
((struct BasisFunction *)
List_Pointer(FunctionSpace_S.BasisFunction, index_Append_2))->Num;
}
if (level_Append_2 && index_Append_2>=0)
List_Write(FunctionSpace_S.BasisFunction, index_Append_2, &BasisFunction_S);
else
List_Add(FunctionSpace_S.BasisFunction, &BasisFunction_S);
;}
break;
case 259:
#line 2622 "ProParser.y"
{
BasisFunction_S.Name = NULL;
BasisFunction_S.NameOfCoef = NULL;
BasisFunction_S.Num = 0;
BasisFunction_S.GlobalBasisFunction = NULL;
BasisFunction_S.Function = NULL;
BasisFunction_S.dFunction = NULL;
BasisFunction_S.dInvFunction = NULL;
BasisFunction_S.dPlusFunction = NULL;
BasisFunction_S.SubFunction = NULL;
BasisFunction_S.SubdFunction = NULL;
BasisFunction_S.SupportIndex = -1;
BasisFunction_S.EntityIndex = -1;
level_Append_2 = (level_Append)? level_Append-1 : 0;
index_Append_2 = -1;
;}
break;
case 261:
#line 2646 "ProParser.y"
{
level_Append_2 = (yyvsp[(1) - (2)].i); index_Append_2 = -1;
;}
break;
case 262:
#line 2651 "ProParser.y"
{
index_Append_2 =
Check_NameOfStructExist("BasisFunction", FunctionSpace_S.BasisFunction,
(yyvsp[(2) - (3)].c), fcmp_BasisFunction_Name, 1);
// 1: already defined Name always possible for Region-wise basis functions
if (index_Append_2<0 || !level_Append_2)
BasisFunction_S.Name = (yyvsp[(2) - (3)].c);
else{
List_Read(FunctionSpace_S.BasisFunction, index_Append_2, &BasisFunction_S);
Free((yyvsp[(2) - (3)].c));
}
;}
break;
case 263:
#line 2665 "ProParser.y"
{
Check_NameOfStructExist("NameOfCoef", Current_BasisFunction_L,
(yyvsp[(2) - (3)].c), fcmp_BasisFunction_NameOfCoef, 0);
BasisFunction_S.NameOfCoef = (yyvsp[(2) - (3)].c); BasisFunction_S.Dimension = 1;
;}
break;
case 264:
#line 2672 "ProParser.y"
{
Get_3Function3NbrForString
(BF_Function, (yyvsp[(2) - (4)].c), &FlagError,
&BasisFunction_S.Function, &BasisFunction_S.dFunction,
&BasisFunction_S.dInvFunction, &BasisFunction_S.Order,
&BasisFunction_S.ElementType, &BasisFunction_S.Orient);
if(FlagError){
Get_Valid_SX3F3N((yyvsp[(2) - (4)].c), BF_Function);
vyyerror(0, "Unknown Function for BasisFunction: %s", (yyvsp[(2) - (4)].c));
}
Free((yyvsp[(2) - (4)].c));
;}
break;
case 265:
#line 2686 "ProParser.y"
{
void (*FunctionDummy)();
int i, j;
double d;
Get_3Function3NbrForString
(BF_Function, (yyvsp[(3) - (7)].c), &FlagError,
&BasisFunction_S.dFunction, &FunctionDummy, &FunctionDummy, &d, &i, &j);
if(FlagError){
Get_Valid_SX3F3N((yyvsp[(3) - (7)].c), BF_Function);
vyyerror(0, "Unknown dFunction (1) for BasisFunction: %s", (yyvsp[(3) - (7)].c));
}
Free((yyvsp[(3) - (7)].c));
Get_3Function3NbrForString
(BF_Function, (yyvsp[(5) - (7)].c), &FlagError,
&BasisFunction_S.dInvFunction, &FunctionDummy, &FunctionDummy, &d, &i, &j);
if(FlagError){
Get_Valid_SX3F3N((yyvsp[(5) - (7)].c), BF_Function);
vyyerror(0, "Unknown dFunction (2) for BasisFunction: %s", (yyvsp[(5) - (7)].c));
}
Free((yyvsp[(5) - (7)].c));
;}
break;
case 266:
#line 2709 "ProParser.y"
{
void (*FunctionDummy)();
int i, j;
double d;
Get_3Function3NbrForString
(BF_Function, (yyvsp[(3) - (9)].c), &FlagError,
&BasisFunction_S.dFunction, &FunctionDummy, &FunctionDummy, &d, &i, &j);
if(FlagError){
Get_Valid_SX3F3N((yyvsp[(3) - (9)].c), BF_Function);
vyyerror(0, "Unknown dFunction (1) for BasisFunction: %s", (yyvsp[(3) - (9)].c));
}
Free((yyvsp[(3) - (9)].c));
Get_3Function3NbrForString
(BF_Function, (yyvsp[(5) - (9)].c), &FlagError,
&BasisFunction_S.dInvFunction, &FunctionDummy, &FunctionDummy, &d, &i, &j);
if(FlagError){
Get_Valid_SX3F3N((yyvsp[(5) - (9)].c), BF_Function);
vyyerror(0, "Unknown dFunction (2) for BasisFunction: %s", (yyvsp[(5) - (9)].c));
}
Free((yyvsp[(5) - (9)].c));
Get_3Function3NbrForString
(BF_Function, (yyvsp[(7) - (9)].c), &FlagError,
&BasisFunction_S.dPlusFunction, &FunctionDummy, &FunctionDummy, &d, &i, &j);
if(FlagError){
Get_Valid_SX3F3N((yyvsp[(7) - (9)].c), BF_Function);
vyyerror(0, "Unknown dFunction (3) for BasisFunction: %s", (yyvsp[(7) - (9)].c));
}
Free((yyvsp[(7) - (9)].c));
;}
break;
case 267:
#line 2740 "ProParser.y"
{
BasisFunction_S.SubFunction = List_Copy(ListOfInt_L);
;}
break;
case 268:
#line 2745 "ProParser.y"
{
BasisFunction_S.SubdFunction = List_Copy(ListOfInt_L);
;}
break;
case 269:
#line 2750 "ProParser.y"
{
BasisFunction_S.SupportIndex = Num_Group(&Group_S, (char*)"BF_Support", (yyvsp[(2) - (3)].i));
;}
break;
case 270:
#line 2755 "ProParser.y"
{
BasisFunction_S.EntityIndex = Num_Group(&Group_S, (char*)"BF_Entity", (yyvsp[(2) - (3)].i));
if(Group_S.InitialList)
List_Sort(Group_S.InitialList, fcmp_Integer); /* Needed for Global Region */
if(BasisFunction_S.GlobalBasisFunction) { /* Function to be defined before Entity */
if(Group_S.FunctionType == GLOBAL) {
if(List_Nbr(BasisFunction_S.GlobalBasisFunction) ==
List_Nbr(Group_S.InitialList)) {
for(int k = 0; k < List_Nbr(Group_S.InitialList); k++)
if(*((int*)List_Pointer(Group_S.InitialList, k)) !=
*((int*)List_Pointer(BasisFunction_S.GlobalBasisFunction, k))) {
vyyerror(0, "Bad correspondance between Group and Entity (elements differ)");
break;
}
}
else if(List_Nbr(Group_S.InitialList) != 0 ||
GlobalBasisFunction_S.EntityIndex != -1)
vyyerror(0, "Bad correspondance between Group and Entity (#BF %d, #Global %d)",
List_Nbr(BasisFunction_S.GlobalBasisFunction),
List_Nbr(Group_S.InitialList));
}
else vyyerror(0, "Bad correspondance between Group and Entity (Entity must be Global)");
}
;}
break;
case 272:
#line 2791 "ProParser.y"
{
int dim = (yyvsp[(8) - (20)].d);
if(dim != (yyvsp[(17) - (20)].d))
vyyerror(0, "Number of formulations different from number of resolutions");
if(List_Nbr(Group_S.InitialList) != dim)
vyyerror(0, "Group sould have %d single regions", dim);
BasisFunction_S.GlobalBasisFunction =
List_Create(dim, 1, sizeof(struct GlobalBasisFunction));
for(int k = 0; k < dim; k++) {
int i;
List_Read(Group_S.InitialList, k, &i);
GlobalBasisFunction_S.EntityIndex = i;
char tmpstr[256];
sprintf(tmpstr, "%s_%d", (yyvsp[(6) - (20)].c), k+1);
if((i = List_ISearchSeq(Problem_S.Formulation, tmpstr,
fcmp_Formulation_Name)) >= 0) {
GlobalBasisFunction_S.FormulationIndex = i;
List_Read(Problem_S.Formulation, i, &Formulation_S);
if((i = List_ISearchSeq(Formulation_S.DefineQuantity, (yyvsp[(3) - (20)].c),
fcmp_DefineQuantity_Name)) >= 0)
GlobalBasisFunction_S.DefineQuantityIndex = i;
else {
vyyerror(0, "Unknown Quantity '%s' in Formulation '%s'", (yyvsp[(3) - (20)].c),
Formulation_S.Name);
break;
}
}
else
vyyerror(0, "Unknown Formulation: %s", tmpstr);
sprintf(tmpstr, "%s_%d", (yyvsp[(15) - (20)].c), k+1);
if((i = List_ISearchSeq(Problem_S.Resolution, tmpstr,
fcmp_Resolution_Name)) >= 0)
GlobalBasisFunction_S.ResolutionIndex = i;
else
vyyerror(0, "Unknown Resolution: %s", tmpstr);
GlobalBasisFunction_S.QuantityStorage = NULL;
List_Add(BasisFunction_S.GlobalBasisFunction, &GlobalBasisFunction_S);
}
List_Sort(BasisFunction_S.GlobalBasisFunction, fcmp_Integer);
Free((yyvsp[(3) - (20)].c)); Free((yyvsp[(6) - (20)].c)); Free((yyvsp[(15) - (20)].c));
;}
break;
case 273:
#line 2844 "ProParser.y"
{
if (!FunctionSpace_S.SubSpace)
FunctionSpace_S.SubSpace =
List_Create(6, 6, sizeof (struct SubSpace));
;}
break;
case 274:
#line 2851 "ProParser.y"
{
if (level_Append_2 && index_Append_2>=0)
List_Write(FunctionSpace_S.SubSpace, index_Append_2, &SubSpace_S);
else
List_Add(FunctionSpace_S.SubSpace, &SubSpace_S);
;}
break;
case 276:
#line 2865 "ProParser.y"
{
SubSpace_S.Name = NULL; SubSpace_S.BasisFunction = NULL;
level_Append_2 = (level_Append)? level_Append-1 : 0;
index_Append_2 = -1;
;}
break;
case 278:
#line 2878 "ProParser.y"
{
level_Append_2 = (yyvsp[(1) - (2)].i); index_Append_2 = -1;
;}
break;
case 279:
#line 2883 "ProParser.y"
{
index_Append_2 =
Check_NameOfStructExist("SubSpace", FunctionSpace_S.SubSpace,
(yyvsp[(2) - (3)].c), fcmp_SubSpace_Name, level_Append_2);
if (index_Append_2<0)
SubSpace_S.Name = (yyvsp[(2) - (3)].c);
else{
List_Read(FunctionSpace_S.SubSpace, index_Append_2, &SubSpace_S);
Free((yyvsp[(2) - (3)].c));
}
;}
break;
case 280:
#line 2896 "ProParser.y"
{ SubSpace_S.BasisFunction = (yyvsp[(2) - (3)].l); ;}
break;
case 281:
#line 2899 "ProParser.y"
{ SubSpace_S.BasisFunction = (yyvsp[(2) - (3)].l); ;}
break;
case 282:
#line 2906 "ProParser.y"
{
(yyval.l) = SubSpace_S.BasisFunction?
SubSpace_S.BasisFunction : List_Create(1, 5, sizeof(int));
int i;
if((i = List_ISearchSeq(Current_BasisFunction_L,
(yyvsp[(1) - (1)].c), fcmp_BasisFunction_Name)) < 0)
vyyerror(0, "Unknown BasisFunction: %s", (yyvsp[(1) - (1)].c));
else {
List_Add((yyval.l), &i);
int j = i+1;
while((i = List_ISearchSeqPartial(Current_BasisFunction_L,
(yyvsp[(1) - (1)].c), j, fcmp_BasisFunction_Name)) >= 0) {
List_Add((yyval.l), &i); j = i+1; /* for piecewise defined basis functions */
}
}
Free((yyvsp[(1) - (1)].c));
;}
break;
case 283:
#line 2925 "ProParser.y"
{ (yyval.l) = (yyvsp[(2) - (3)].l); ;}
break;
case 284:
#line 2932 "ProParser.y"
{
(yyval.l) = SubSpace_S.BasisFunction?
SubSpace_S.BasisFunction : List_Create(5, 5, sizeof(int));
;}
break;
case 285:
#line 2938 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Current_BasisFunction_L,
(yyvsp[(3) - (3)].c), fcmp_BasisFunction_Name)) < 0)
vyyerror(0, "Unknown BasisFunction: %s", (yyvsp[(3) - (3)].c));
else {
List_Add((yyvsp[(1) - (3)].l), &i);
int j = i+1;
while((i = List_ISearchSeqPartial(Current_BasisFunction_L,
(yyvsp[(3) - (3)].c), j, fcmp_BasisFunction_Name)) >= 0) {
List_Add((yyvsp[(1) - (3)].l), &i); j = i+1; /* for piecewise defined basis functions */
}
}
(yyval.l) = (yyvsp[(1) - (3)].l); Free((yyvsp[(3) - (3)].c));
;}
break;
case 286:
#line 2959 "ProParser.y"
{
(yyval.l) = SubSpace_S.BasisFunction?
SubSpace_S.BasisFunction : List_Create(1, 5, sizeof(int));
int i;
if((i = List_ISearchSeq(Current_BasisFunction_L,
(yyvsp[(1) - (1)].c), fcmp_BasisFunction_NameOfCoef)) < 0)
vyyerror(0, "Unknown BasisFunctionCoef: %s", (yyvsp[(1) - (1)].c));
else {
List_Add((yyval.l), &i);
}
Free((yyvsp[(1) - (1)].c));
;}
break;
case 287:
#line 2973 "ProParser.y"
{ (yyval.l) = (yyvsp[(2) - (3)].l); ;}
break;
case 288:
#line 2980 "ProParser.y"
{
(yyval.l) = SubSpace_S.BasisFunction?
SubSpace_S.BasisFunction : List_Create(5, 5, sizeof(int));
;}
break;
case 289:
#line 2986 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Current_BasisFunction_L,
(yyvsp[(3) - (3)].c), fcmp_BasisFunction_NameOfCoef)) < 0)
vyyerror(0, "Unknown BasisFunctionCoef: %s", (yyvsp[(3) - (3)].c));
else {
List_Add((yyvsp[(1) - (3)].l), &i);
}
(yyval.l) = (yyvsp[(1) - (3)].l); Free((yyvsp[(3) - (3)].c));
;}
break;
case 290:
#line 3002 "ProParser.y"
{
if (!FunctionSpace_S.GlobalQuantity)
FunctionSpace_S.GlobalQuantity =
List_Create(6, 6, sizeof (struct GlobalQuantity));
;}
break;
case 291:
#line 3009 "ProParser.y"
{
GlobalQuantity_S.Num = Num_BasisFunction++;
List_Add(FunctionSpace_S.GlobalQuantity, &GlobalQuantity_S);
;}
break;
case 293:
#line 3021 "ProParser.y"
{
GlobalQuantity_S.Name = NULL; GlobalQuantity_S.Num = 0;
GlobalQuantity_S.Type = ALIASOF; GlobalQuantity_S.ReferenceIndex = -1;
;}
break;
case 295:
#line 3033 "ProParser.y"
{
Check_NameOfStructExist("GlobalQuantity", FunctionSpace_S.GlobalQuantity,
(yyvsp[(2) - (3)].c), fcmp_GlobalQuantity_Name, 0);
GlobalQuantity_S.Name = (yyvsp[(2) - (3)].c);
;}
break;
case 296:
#line 3040 "ProParser.y"
{
GlobalQuantity_S.Type =
Get_DefineForString(GlobalQuantity_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), GlobalQuantity_Type);
vyyerror(0, "Unknown type of GlobalQuantity: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 297:
#line 3051 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(FunctionSpace_S.BasisFunction, (yyvsp[(2) - (3)].c),
fcmp_BasisFunction_NameOfCoef)) < 0)
vyyerror(0, "Unknown NameOfCoef: %s", (yyvsp[(2) - (3)].c));
else
GlobalQuantity_S.ReferenceIndex = i;
Free((yyvsp[(2) - (3)].c));
;}
break;
case 298:
#line 3066 "ProParser.y"
{
if (!FunctionSpace_S.Constraint)
FunctionSpace_S.Constraint =
List_Create(6, 6, sizeof (struct ConstraintInFS));
;}
break;
case 299:
#line 3073 "ProParser.y"
{
Group_S.FunctionType = Type_Function;
Group_S.SuppListType = Type_SuppList;
Group_S.SuppListType2 = Type_SuppList2;
switch (Group_S.FunctionType) {
case ELEMENTSOF : Group_S.Type = ELEMENTLIST; break;
default : Group_S.Type = REGIONLIST ; break;
}
if(Constraint_Index >= 0) {
Constraint_P = (struct Constraint *)
List_Pointer(Problem_S.Constraint, Constraint_Index);
for(int i = 0; i < List_Nbr(Constraint_P->ConstraintPerRegion); i++) {
ConstraintPerRegion_P = (struct ConstraintPerRegion *)
List_Pointer(Constraint_P->ConstraintPerRegion, i);
if(ConstraintPerRegion_P->RegionIndex >= 0) {
Group_S.InitialList =
((struct Group *)
List_Pointer(Problem_S.Group, ConstraintPerRegion_P->RegionIndex))
->InitialList;
Group_S.InitialSuppList =
(ConstraintPerRegion_P->SubRegionIndex >= 0)?
((struct Group *)
List_Pointer(Problem_S.Group,
ConstraintPerRegion_P->SubRegionIndex))
->InitialList : NULL;
Group_S.InitialSuppList2 =
(ConstraintPerRegion_P->SubRegion2Index >= 0)?
((struct Group *)
List_Pointer(Problem_S.Group,
ConstraintPerRegion_P->SubRegion2Index))
->InitialList : NULL;
ConstraintInFS_S.EntityIndex = Add_Group(&Group_S, (char*)"CO_Entity",
false, 1, 0);
ConstraintInFS_S.ConstraintPerRegion = ConstraintPerRegion_P;
List_Add(FunctionSpace_S.Constraint, &ConstraintInFS_S);
}
}
}
;}
break;
case 301:
#line 3124 "ProParser.y"
{
ConstraintInFS_S.QuantityType = LOCALQUANTITY;
ConstraintInFS_S.ReferenceIndex = -1; ConstraintInFS_S.EntityIndex = -1;
ConstraintInFS_S.ConstraintPerRegion = NULL;
ConstraintInFS_S.Active.ResolutionIndex = -1;
ConstraintInFS_S.Active.Active = NULL;
Constraint_Index = -1;
Type_Function = 0;
;}
break;
case 303:
#line 3141 "ProParser.y"
{
int i, index_BF = -1;
if((i = List_ISearchSeq(FunctionSpace_S.BasisFunction, (yyvsp[(2) - (3)].c),
fcmp_BasisFunction_NameOfCoef)) < 0) {
if((i = List_ISearchSeq(FunctionSpace_S.GlobalQuantity, (yyvsp[(2) - (3)].c),
fcmp_GlobalQuantity_Name)) < 0)
vyyerror(0, "Unknown NameOfCoef: %s", (yyvsp[(2) - (3)].c));
else {
ConstraintInFS_S.QuantityType = GLOBALQUANTITY;
ConstraintInFS_S.ReferenceIndex = i;
index_BF =
((struct GlobalQuantity *)
List_Pointer(FunctionSpace_S.GlobalQuantity, i))->ReferenceIndex;
}
}
else {
ConstraintInFS_S.QuantityType = LOCALQUANTITY;
ConstraintInFS_S.ReferenceIndex = i;
index_BF = i;
}
// Auto selection of Type_Function
int entity_index =
((struct BasisFunction *)
List_Pointer(FunctionSpace_S.BasisFunction, index_BF))->EntityIndex;
if(entity_index<0)
vyyerror(0, "Undefined Entity for NameOfCoef %s", (yyvsp[(2) - (3)].c));
Type_Function =
((struct Group *)List_Pointer(Problem_S.Group, entity_index))->FunctionType;
Free((yyvsp[(2) - (3)].c));
;}
break;
case 304:
#line 3176 "ProParser.y"
{ Type_Function = (yyvsp[(2) - (3)].i); ;}
break;
case 305:
#line 3179 "ProParser.y"
{
// Auto selection already done
;}
break;
case 306:
#line 3184 "ProParser.y"
{ Type_SuppList = (yyvsp[(2) - (3)].i); Type_SuppList2 = (yyvsp[(2) - (3)].i); ;}
break;
case 307:
#line 3187 "ProParser.y"
{
Constraint_Index =
List_ISearchSeq(Problem_S.Constraint, (yyvsp[(2) - (3)].c), fcmp_Constraint_Name);
if(Constraint_Index < 0)
vyyerror(1, "Constraint '%s' is not provided", (yyvsp[(2) - (3)].c));
Free((yyvsp[(2) - (3)].c));
;}
break;
case 308:
#line 3204 "ProParser.y"
{ if(!Problem_S.Formulation)
Problem_S.Formulation = List_Create(10, 5, sizeof (struct Formulation));
;}
break;
case 310:
#line 3214 "ProParser.y"
{
if (level_Append && index_Append>=0)
List_Write(Problem_S.Formulation, index_Append, &Formulation_S);
else
List_Add(Problem_S.Formulation, &Formulation_S);
;}
break;
case 312:
#line 3228 "ProParser.y"
{
Formulation_S.Name = NULL; Formulation_S.Type = FEMEQUATION;
Formulation_S.DefineQuantity = NULL; Formulation_S.Equation = NULL;
level_Append = 0;
;}
break;
case 315:
#line 3243 "ProParser.y"
{ level_Append = (yyvsp[(1) - (2)].i); index_Append = -1; ;}
break;
case 316:
#line 3246 "ProParser.y"
{
index_Append =
Check_NameOfStructExist("Formulation", Problem_S.Formulation,
(yyvsp[(2) - (3)].c), fcmp_Formulation_Name, level_Append);
if (index_Append<0)
Formulation_S.Name = (yyvsp[(2) - (3)].c);
else{
List_Read(Problem_S.Formulation, index_Append, &Formulation_S);
Free((yyvsp[(2) - (3)].c));
}
;}
break;
case 317:
#line 3259 "ProParser.y"
{ Formulation_S.Type =
Get_DefineForString(Formulation_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), Formulation_Type);
vyyerror(0, "Unknown type of Formulation: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 319:
#line 3271 "ProParser.y"
{
if(!Formulation_S.Equation) Formulation_S.Equation = (yyvsp[(3) - (4)].l);
Free((yyvsp[(1) - (4)].c));
;}
break;
case 320:
#line 3280 "ProParser.y"
{
if (!Formulation_S.DefineQuantity)
Formulation_S.DefineQuantity =
List_Create(6, 6, sizeof (struct DefineQuantity));
;}
break;
case 321:
#line 3287 "ProParser.y"
{
List_Add(Formulation_S.DefineQuantity, &DefineQuantity_S);
;}
break;
case 323:
#line 3298 "ProParser.y"
{ DefineQuantity_S.Name = NULL;
DefineQuantity_S.Type = LOCALQUANTITY;
DefineQuantity_S.IndexInFunctionSpace = NULL;
DefineQuantity_S.FunctionSpaceIndex = -1;
DefineQuantity_S.DofDataIndex = -1;
DefineQuantity_S.DofData = NULL;
DefineQuantity_S.FrequencySpectrum = NULL;
DefineQuantity_S.IntegralQuantity.InIndex = -1;
DefineQuantity_S.IntegralQuantity.IntegrationMethodIndex = -1;
DefineQuantity_S.IntegralQuantity.JacobianMethodIndex = -1;
DefineQuantity_S.IntegralQuantity.Symmetry = 0;
DefineQuantity_S.IntegralQuantity.WholeQuantity = NULL;
;}
break;
case 325:
#line 3320 "ProParser.y"
{ DefineQuantity_S.Name = (yyvsp[(2) - (3)].c); ;}
break;
case 326:
#line 3323 "ProParser.y"
{ DefineQuantity_S.Type = GLOBALQUANTITY; ;}
break;
case 327:
#line 3327 "ProParser.y"
{ DefineQuantity_S.Type = INTEGRALQUANTITY; ;}
break;
case 328:
#line 3330 "ProParser.y"
{ DefineQuantity_S.Type =
Get_DefineForString(DefineQuantity_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), DefineQuantity_Type);
vyyerror(0, "Unknown type of Quantity: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 329:
#line 3340 "ProParser.y"
{ DefineQuantity_S.FrequencySpectrum = (yyvsp[(2) - (3)].l);
;}
break;
case 330:
#line 3344 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.FunctionSpace, (yyvsp[(2) - (2)].c),
fcmp_FunctionSpace_Name)) < 0)
vyyerror(0, "Unknown FunctionSpace: %s", (yyvsp[(2) - (2)].c));
else
DefineQuantity_S.FunctionSpaceIndex = i;
;}
break;
case 331:
#line 3353 "ProParser.y"
{
if(DefineQuantity_S.FunctionSpaceIndex >= 0) {
if(DefineQuantity_S.Type == GLOBALQUANTITY &&
!DefineQuantity_S.IndexInFunctionSpace) {
if(DefineQuantity_S.Name) {
List_Read(Problem_S.FunctionSpace,
DefineQuantity_S.FunctionSpaceIndex, &FunctionSpace_S);
int i;
if((i = List_ISearchSeq(FunctionSpace_S.GlobalQuantity,
DefineQuantity_S.Name,
fcmp_GlobalQuantity_Name)) < 0) {
vyyerror(0, "Unknown GlobalQuantity: %s", DefineQuantity_S.Name);
}
else {
DefineQuantity_S.IndexInFunctionSpace = List_Create(1, 1, sizeof(int));
List_Add(DefineQuantity_S.IndexInFunctionSpace, &i);
}
}
else vyyerror(0, "No Name pre-defined for GlobalQuantity");
}
}
;}
break;
case 332:
#line 3378 "ProParser.y"
{
DefineQuantity_S.DofDataIndex = (int)(yyvsp[(2) - (3)].d);
;}
break;
case 333:
#line 3383 "ProParser.y"
{
Current_DofIndexInWholeQuantity = -1;
Current_NoDofIndexInWholeQuantity = -1;
List_Reset(ListOfPointer_L);
;}
break;
case 334:
#line 3389 "ProParser.y"
{
DefineQuantity_S.IntegralQuantity.WholeQuantity = (yyvsp[(3) - (5)].l);
DefineQuantity_S.IntegralQuantity.DofIndexInWholeQuantity =
Current_DofIndexInWholeQuantity;
WholeQuantity_P = (struct WholeQuantity*)
List_Pointer(DefineQuantity_S.IntegralQuantity.WholeQuantity, 0);
/* Ce qui suit ne suffit pas : il faudrait aussi gerer des
Quantity_def sans Dof */
if(Current_DofIndexInWholeQuantity >= 0) {
DefineQuantity_S.IntegralQuantity.TypeOperatorDof =
(WholeQuantity_P+Current_DofIndexInWholeQuantity)->
Case.OperatorAndQuantity.TypeOperator;
DefineQuantity_S.IntegralQuantity.DefineQuantityIndexDof =
(WholeQuantity_P+Current_DofIndexInWholeQuantity)->
Case.OperatorAndQuantity.Index;
DefineQuantity_S.FunctionSpaceIndex =
((struct DefineQuantity*)
List_Pointer(Formulation_S.DefineQuantity,
DefineQuantity_S.IntegralQuantity.DefineQuantityIndexDof))->
FunctionSpaceIndex;
}
else { /* No Dof{} */
DefineQuantity_S.IntegralQuantity.TypeOperatorDof = NOOP;
DefineQuantity_S.IntegralQuantity.DefineQuantityIndexDof = -1;
}
if(Current_NoDofIndexInWholeQuantity >= 0) {
DefineQuantity_S.IntegralQuantity.DefineQuantityIndexNoDof =
(WholeQuantity_P+Current_NoDofIndexInWholeQuantity)->
Case.OperatorAndQuantity.Index;
}
else { /* No NoDof{} */
DefineQuantity_S.IntegralQuantity.DefineQuantityIndexNoDof = -1;
}
/* Check if the WholeQuantity is a Canonical Form */
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_NONE;
if(List_Nbr(DefineQuantity_S.IntegralQuantity.WholeQuantity) == 1){
/* GF_FUNCTION */
if((WholeQuantity_P+0)->Type == WQ_BUILTINFUNCTION) {
Get_FunctionForFunction(GF_Function,
(WholeQuantity_P+0)->Case.Function.Fct,
&FlagError,
&DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Fct);
if(!FlagError){
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.NbrParameters =
(WholeQuantity_P+0)->Case.Function.NbrParameters;
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Para =
(WholeQuantity_P+0)->Case.Function.Para;
}
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_GF;
}
}
else if(List_Nbr(DefineQuantity_S.IntegralQuantity.WholeQuantity) == 3){
/* GF_FUNCTION OPER DOF */
if ((WholeQuantity_P+0)->Type == WQ_BUILTINFUNCTION &&
(WholeQuantity_P+1)->Type == WQ_OPERATORANDQUANTITY &&
(WholeQuantity_P+2)->Type == WQ_BINARYOPERATOR &&
Current_DofIndexInWholeQuantity == 1) {
Get_FunctionForFunction(GF_Function,
(WholeQuantity_P+0)->Case.Function.Fct,
&FlagError,
&DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Fct);
if(!FlagError){
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.NbrParameters =
(WholeQuantity_P+0)->Case.Function.NbrParameters;
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Para =
(WholeQuantity_P+0)->Case.Function.Para;
}
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_TIME)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_GF_PSCA_DOF;
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_CROSSPRODUCT)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_GF_PVEC_DOF;
}
/* DOF OPER GF_FUNCTION */
else if((WholeQuantity_P+0)->Type == WQ_OPERATORANDQUANTITY &&
(WholeQuantity_P+1)->Type == WQ_BUILTINFUNCTION &&
(WholeQuantity_P+2)->Type == WQ_BINARYOPERATOR &&
Current_DofIndexInWholeQuantity == 0) {
Get_FunctionForFunction(GF_Function,
(WholeQuantity_P+1)->Case.Function.Fct,
&FlagError,
&DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Fct);
if(!FlagError){
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.NbrParameters =
(WholeQuantity_P+1)->Case.Function.NbrParameters;
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Para =
(WholeQuantity_P+1)->Case.Function.Para;
}
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_TIME)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_GF_PSCA_DOF;/* Scalar Prod Transitive */
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_CROSSPRODUCT)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_DOF_PVEC_GF;
}
/* GF_FUNCTION OPER EXPR */
else if((WholeQuantity_P+0)->Type == WQ_BUILTINFUNCTION &&
(WholeQuantity_P+1)->Type == WQ_EXPRESSION &&
(WholeQuantity_P+2)->Type == WQ_BINARYOPERATOR ) {
Get_FunctionForFunction(GF_Function,
(WholeQuantity_P+0)->Case.Function.Fct,
&FlagError,
&DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Fct);
if(!FlagError){
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.NbrParameters =
(WholeQuantity_P+0)->Case.Function.NbrParameters;
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Para =
(WholeQuantity_P+0)->Case.Function.Para;
}
DefineQuantity_S.IntegralQuantity.ExpressionIndexForCanonical =
(WholeQuantity_P+1)->Case.Expression.Index;
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_TIME)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_GF_PSCA_EXP;
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_CROSSPRODUCT)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_GF_PVEC_EXP;
/*
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.NbrParameters =
(WholeQuantity_P+0)->Case.Function.NbrParameters;
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Para =
(WholeQuantity_P+0)->Case.Function.Para;
*/
}
/* EXPR OPER GF_FUNCTION */
else if((WholeQuantity_P+0)->Type == WQ_EXPRESSION &&
(WholeQuantity_P+1)->Type == WQ_BUILTINFUNCTION &&
(WholeQuantity_P+2)->Type == WQ_BINARYOPERATOR ) {
Get_FunctionForFunction(GF_Function,
(WholeQuantity_P+1)->Case.Function.Fct,
&FlagError,
&DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Fct);
if(!FlagError){
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.NbrParameters =
(WholeQuantity_P+1)->Case.Function.NbrParameters;
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Para =
(WholeQuantity_P+1)->Case.Function.Para;
}
DefineQuantity_S.IntegralQuantity.ExpressionIndexForCanonical =
(WholeQuantity_P+0)->Case.Expression.Index;
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_TIME)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_GF_PSCA_EXP;/* Transitive product */
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_CROSSPRODUCT)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_EXP_PVEC_GF;
}
}
else if(List_Nbr(DefineQuantity_S.IntegralQuantity.WholeQuantity) == 5){
/* EXPR OPER GF_FUNCTION OPER DOF */
if ((WholeQuantity_P+0)->Type == WQ_EXPRESSION &&
(WholeQuantity_P+1)->Type == WQ_BUILTINFUNCTION &&
(WholeQuantity_P+2)->Type == WQ_BINARYOPERATOR &&
(WholeQuantity_P+3)->Type == WQ_OPERATORANDQUANTITY &&
(WholeQuantity_P+4)->Type == WQ_BINARYOPERATOR &&
Current_DofIndexInWholeQuantity == 3) {
Get_FunctionForFunction(GF_Function,
(WholeQuantity_P+1)->Case.Function.Fct,
&FlagError,
&DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Fct);
if(!FlagError){
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.NbrParameters =
(WholeQuantity_P+1)->Case.Function.NbrParameters;
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Para =
(WholeQuantity_P+1)->Case.Function.Para;
}
DefineQuantity_S.IntegralQuantity.ExpressionIndexForCanonical =
(WholeQuantity_P+0)->Case.Expression.Index;
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_TIME){
if((WholeQuantity_P+4)->Case.Operator.TypeOperator == OP_TIME)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_EXP_TIME_GF_PSCA_DOF;
if((WholeQuantity_P+4)->Case.Operator.TypeOperator == OP_CROSSPRODUCT)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_EXP_TIME_GF_PVEC_DOF;
}
else if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_CROSSPRODUCT){
if((WholeQuantity_P+4)->Case.Operator.TypeOperator == OP_TIME)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_EXP_PVEC_GF_PSCA_DOF;
if((WholeQuantity_P+4)->Case.Operator.TypeOperator == OP_CROSSPRODUCT)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_EXP_PVEC_GF_PVEC_DOF;
}
}
/* FCT OPER GF_FUNCTION OPER DOF */
else if((WholeQuantity_P+0)->Type == WQ_BUILTINFUNCTION &&
(WholeQuantity_P+1)->Type == WQ_BUILTINFUNCTION &&
(WholeQuantity_P+2)->Type == WQ_BINARYOPERATOR &&
(WholeQuantity_P+3)->Type == WQ_OPERATORANDQUANTITY &&
(WholeQuantity_P+4)->Type == WQ_BINARYOPERATOR &&
Current_DofIndexInWholeQuantity == 3) {
Get_FunctionForFunction(GF_Function,
(WholeQuantity_P+1)->Case.Function.Fct,
&FlagError,
&DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Fct);
if(!FlagError){
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.NbrParameters =
(WholeQuantity_P+1)->Case.Function.NbrParameters;
DefineQuantity_S.IntegralQuantity.FunctionForCanonical.Para =
(WholeQuantity_P+1)->Case.Function.Para;
}
DefineQuantity_S.IntegralQuantity.AnyFunction.Fct =
(WholeQuantity_P+0)->Case.Function.Fct;
DefineQuantity_S.IntegralQuantity.AnyFunction.NbrParameters =
(WholeQuantity_P+0)->Case.Function.NbrParameters;
DefineQuantity_S.IntegralQuantity.AnyFunction.Para =
(WholeQuantity_P+0)->Case.Function.Para;
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_TIME){
if((WholeQuantity_P+4)->Case.Operator.TypeOperator == OP_TIME)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_FCT_TIME_GF_PSCA_DOF;
if((WholeQuantity_P+4)->Case.Operator.TypeOperator == OP_CROSSPRODUCT)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_FCT_TIME_GF_PVEC_DOF;
}
else if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_CROSSPRODUCT){
if((WholeQuantity_P+4)->Case.Operator.TypeOperator == OP_TIME)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_FCT_PVEC_GF_PSCA_DOF;
if((WholeQuantity_P+4)->Case.Operator.TypeOperator == OP_CROSSPRODUCT)
DefineQuantity_S.IntegralQuantity.CanonicalWholeQuantity = CWQ_FCT_PVEC_GF_PVEC_DOF;
}
}
}
Pro_DefineQuantityIndex
(DefineQuantity_S.IntegralQuantity.WholeQuantity,
-1,
&DefineQuantity_S.IntegralQuantity.NbrQuantityIndex,
&DefineQuantity_S.IntegralQuantity.QuantityIndexTable,
&DefineQuantity_S.IntegralQuantity.QuantityTraceGroupIndexTable);
if(DefineQuantity_S.IntegralQuantity.NbrQuantityIndex > 1)
vyyerror(0, "More than one LocalQuantity in IntegralQuantity");
;}
break;
case 335:
#line 3651 "ProParser.y"
{
DefineQuantity_S.IntegralQuantity.InIndex = Num_Group(&Group_S, (char*)"IQ_In", (yyvsp[(2) - (3)].i));
;}
break;
case 336:
#line 3656 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.IntegrationMethod, (yyvsp[(2) - (3)].c),
fcmp_IntegrationMethod_Name)) < 0)
vyyerror(0, "Unknown Integration method: %s", (yyvsp[(2) - (3)].c));
else
DefineQuantity_S.IntegralQuantity.IntegrationMethodIndex = i;
Free((yyvsp[(2) - (3)].c));
;}
break;
case 337:
#line 3667 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.JacobianMethod, (yyvsp[(2) - (3)].c),
fcmp_JacobianMethod_Name)) < 0)
vyyerror(0, "Unknown Jacobian method: %s", (yyvsp[(2) - (3)].c));
else
DefineQuantity_S.IntegralQuantity.JacobianMethodIndex = i;
Free((yyvsp[(2) - (3)].c));
;}
break;
case 338:
#line 3678 "ProParser.y"
{ DefineQuantity_S.IntegralQuantity.Symmetry = (yyvsp[(2) - (3)].i); ;}
break;
case 340:
#line 3686 "ProParser.y"
{
if(DefineQuantity_S.FunctionSpaceIndex >= 0) {
if(DefineQuantity_S.Type == LOCALQUANTITY) {
int i;
if((i = List_ISearchSeq
(((struct FunctionSpace *)
List_Pointer(Problem_S.FunctionSpace,
DefineQuantity_S.FunctionSpaceIndex))->SubSpace, (yyvsp[(2) - (3)].c),
fcmp_SubSpace_Name)) < 0)
vyyerror(0, "Unknown SubSpace: %s", (yyvsp[(2) - (3)].c));
else {
DefineQuantity_S.IndexInFunctionSpace =
((struct SubSpace *)
List_Pointer
(((struct FunctionSpace *)
List_Pointer(Problem_S.FunctionSpace,
DefineQuantity_S.FunctionSpaceIndex))->SubSpace, i))
->BasisFunction;
}
}
else if(DefineQuantity_S.Type == GLOBALQUANTITY) {
List_Read(Problem_S.FunctionSpace,
DefineQuantity_S.FunctionSpaceIndex, &FunctionSpace_S);
int i;
if((i = List_ISearchSeq(FunctionSpace_S.GlobalQuantity,
(yyvsp[(2) - (3)].c), fcmp_GlobalQuantity_Name)) < 0) {
vyyerror(0, "Unknown GlobalQuantity: %s", (yyvsp[(2) - (3)].c));
}
else {
DefineQuantity_S.IndexInFunctionSpace = List_Create(1, 1, sizeof(int));
List_Add(DefineQuantity_S.IndexInFunctionSpace, &i);
}
}
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 341:
#line 3728 "ProParser.y"
{
(yyval.l) = Formulation_S.Equation?
Formulation_S.Equation :
List_Create(6, 6, sizeof(struct EquationTerm));
;}
break;
case 342:
#line 3735 "ProParser.y"
{
List_Add((yyval.l) = (yyvsp[(1) - (2)].l), &EquationTerm_S);
;}
break;
case 343:
#line 3740 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (2)].l);
;}
break;
case 344:
#line 3749 "ProParser.y"
{ EquationTerm_S.Type = GALERKIN; ;}
break;
case 345:
#line 3752 "ProParser.y"
{ EquationTerm_S.Type = DERHAM; ;}
break;
case 346:
#line 3755 "ProParser.y"
{ EquationTerm_S.Type = GLOBALTERM; ;}
break;
case 347:
#line 3758 "ProParser.y"
{ EquationTerm_S.Type = GLOBALEQUATION; ;}
break;
case 348:
#line 3765 "ProParser.y"
{
EquationTerm_S.Case.GlobalEquation.Type = NETWORK;
EquationTerm_S.Case.GlobalEquation.ConstraintIndex = -1;
EquationTerm_S.Case.GlobalEquation.GlobalEquationTerm = NULL;
;}
break;
case 351:
#line 3777 "ProParser.y"
{ EquationTerm_S.Case.GlobalEquation.Type =
Get_DefineForString(Constraint_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), Constraint_Type);
vyyerror(0, "Unknown type of GlobalEquation: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 352:
#line 3787 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.Constraint, (yyvsp[(2) - (3)].c),
fcmp_Constraint_Name)) >= 0)
EquationTerm_S.Case.GlobalEquation.ConstraintIndex = i;
else
EquationTerm_S.Case.GlobalEquation.ConstraintIndex = -1;
Free((yyvsp[(2) - (3)].c));
;}
break;
case 353:
#line 3798 "ProParser.y"
{
if(!EquationTerm_S.Case.GlobalEquation.GlobalEquationTerm)
EquationTerm_S.Case.GlobalEquation.GlobalEquationTerm =
List_Create(3, 3, sizeof(struct GlobalEquationTerm));
List_Add(EquationTerm_S.Case.GlobalEquation.GlobalEquationTerm,
&GlobalEquationTerm_S);
;}
break;
case 354:
#line 3812 "ProParser.y"
{
GlobalEquationTerm_S.DefineQuantityIndexNode = -1;
GlobalEquationTerm_S.DefineQuantityIndexLoop = -1;
GlobalEquationTerm_S.DefineQuantityIndexEqu = -1;
GlobalEquationTerm_S.InIndex = -1;
;}
break;
case 356:
#line 3823 "ProParser.y"
{
if(!strcmp((yyvsp[(1) - (3)].c), "Node"))
GlobalEquationTerm_S.DefineQuantityIndexNode = (yyvsp[(2) - (3)].t).Int2;
else if(!strcmp((yyvsp[(1) - (3)].c), "Loop"))
GlobalEquationTerm_S.DefineQuantityIndexLoop = (yyvsp[(2) - (3)].t).Int2;
else if(!strcmp((yyvsp[(1) - (3)].c), "Equation"))
GlobalEquationTerm_S.DefineQuantityIndexEqu = (yyvsp[(2) - (3)].t).Int2;
else
vyyerror(0, "Unknown global equation term: %s", (yyvsp[(1) - (3)].c));
Free((yyvsp[(1) - (3)].c));
;}
break;
case 357:
#line 3835 "ProParser.y"
{ GlobalEquationTerm_S.InIndex = Num_Group(&Group_S, (char*)"FO_In", (yyvsp[(2) - (3)].i)); ;}
break;
case 358:
#line 3843 "ProParser.y"
{ EquationTerm_S.Case.LocalTerm.Term.TypeTimeDerivative = NODT_;
EquationTerm_S.Case.LocalTerm.Term.TypeOperatorEqu = NOOP;
EquationTerm_S.Case.LocalTerm.Term.TypeOperatorDof = NOOP;
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexEqu = -1;
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexDof = -1;
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexNoDof = -1;
EquationTerm_S.Case.LocalTerm.Term.WholeQuantity = NULL;
EquationTerm_S.Case.LocalTerm.Term.DofIndexInWholeQuantity = -1;
EquationTerm_S.Case.LocalTerm.Term.DofInTrace = 0;
EquationTerm_S.Case.LocalTerm.InIndex = -1;
EquationTerm_S.Case.LocalTerm.SubRegion = -1;
EquationTerm_S.Case.LocalTerm.IntegrationMethodIndex = -1;
EquationTerm_S.Case.LocalTerm.MatrixIndex = -1;
EquationTerm_S.Case.LocalTerm.JacobianMethodIndex = -1;
EquationTerm_S.Case.LocalTerm.ExpressionIndexForMetricTensor = -1;
EquationTerm_S.Case.LocalTerm.Active = NULL;
EquationTerm_S.Case.LocalTerm.Full_Matrix = 0;
;}
break;
case 360:
#line 3869 "ProParser.y"
{
EquationTerm_S.Case.LocalTerm.Term.TypeTimeDerivative = Type_TermOperator;
Current_DofIndexInWholeQuantity = -1;
Current_NoDofIndexInWholeQuantity = -1;
List_Reset(ListOfPointer_L);
;}
break;
case 361:
#line 3877 "ProParser.y"
{ EquationTerm_S.Case.LocalTerm.Term.WholeQuantity = (yyvsp[(4) - (4)].l);
EquationTerm_S.Case.LocalTerm.Term.DofIndexInWholeQuantity =
Current_DofIndexInWholeQuantity;
WholeQuantity_P = (struct WholeQuantity*)
List_Pointer(EquationTerm_S.Case.LocalTerm.Term.WholeQuantity, 0);
if(Current_DofIndexInWholeQuantity == -4){
EquationTerm_S.Case.LocalTerm.Term.DofInTrace = 1;
EquationTerm_S.Case.LocalTerm.Term.TypeOperatorDof =
TypeOperatorDofInTrace;
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexDof =
DefineQuantityIndexDofInTrace;
}
else if(Current_DofIndexInWholeQuantity >= 0) {
EquationTerm_S.Case.LocalTerm.Term.TypeOperatorDof =
(WholeQuantity_P+Current_DofIndexInWholeQuantity)->
Case.OperatorAndQuantity.TypeOperator;
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexDof =
(WholeQuantity_P+Current_DofIndexInWholeQuantity)->
Case.OperatorAndQuantity.Index;
}
else { /* No Dof{} */
EquationTerm_S.Case.LocalTerm.Term.TypeOperatorDof = NOOP;
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexDof = -1;
}
if(Current_NoDofIndexInWholeQuantity >= 0) {
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexNoDof =
(WholeQuantity_P+Current_NoDofIndexInWholeQuantity)->
Case.OperatorAndQuantity.Index;
}
else { /* No NoDof{} */
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexNoDof = -1;
}
/* Check if the WholeQuantity is a Canonical Form of type 'expr[] * Dof{}'*/
if((List_Nbr(EquationTerm_S.Case.LocalTerm.Term.WholeQuantity) == 3) &&
((WholeQuantity_P+0)->Type == WQ_EXPRESSION) &&
((WholeQuantity_P+1)->Type == WQ_OPERATORANDQUANTITY) &&
((WholeQuantity_P+2)->Type == WQ_BINARYOPERATOR) &&
((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_TIME) &&
(Current_DofIndexInWholeQuantity == 1)) {
EquationTerm_S.Case.LocalTerm.Term.CanonicalWholeQuantity =
CWQ_EXP_TIME_DOF;
EquationTerm_S.Case.LocalTerm.Term.ExpressionIndexForCanonical =
(WholeQuantity_P+0)->Case.Expression.Index;
}
else if((List_Nbr(EquationTerm_S.Case.LocalTerm.Term.WholeQuantity) == 3) &&
((WholeQuantity_P+0)->Type == WQ_BUILTINFUNCTION) &&
((WholeQuantity_P+1)->Type == WQ_OPERATORANDQUANTITY) &&
((WholeQuantity_P+2)->Type == WQ_BINARYOPERATOR) &&
(Current_DofIndexInWholeQuantity == 1)) {
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_TIME)
EquationTerm_S.Case.LocalTerm.Term.CanonicalWholeQuantity = CWQ_FCT_TIME_DOF;
if((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_CROSSPRODUCT)
EquationTerm_S.Case.LocalTerm.Term.CanonicalWholeQuantity = CWQ_FCT_PVEC_DOF;
EquationTerm_S.Case.LocalTerm.Term.FunctionForCanonical.Fct =
(WholeQuantity_P+0)->Case.Function.Fct;
EquationTerm_S.Case.LocalTerm.Term.FunctionForCanonical.NbrParameters =
(WholeQuantity_P+0)->Case.Function.NbrParameters;
EquationTerm_S.Case.LocalTerm.Term.FunctionForCanonical.Para =
(WholeQuantity_P+0)->Case.Function.Para;
}
else if((List_Nbr(EquationTerm_S.Case.LocalTerm.Term.WholeQuantity) == 1) &&
((WholeQuantity_P+0)->Type == WQ_OPERATORANDQUANTITY) &&
(Current_DofIndexInWholeQuantity == 0)) {
EquationTerm_S.Case.LocalTerm.Term.CanonicalWholeQuantity = CWQ_DOF;
}
else {
EquationTerm_S.Case.LocalTerm.Term.CanonicalWholeQuantity = CWQ_NONE;
}
;}
break;
case 362:
#line 3956 "ProParser.y"
{
EquationTerm_S.Case.LocalTerm.Term.TypeOperatorEqu = Quantity_TypeOperator;
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexEqu = Quantity_Index;
EquationTerm_S.Case.LocalTerm.Term.CanonicalWholeQuantity_Equ = CWQ_NONE;
WholeQuantity_P = (struct WholeQuantity*) List_Pointer((yyvsp[(7) - (9)].l), 0);
if(List_Nbr((yyvsp[(7) - (9)].l)) == 1){
if((WholeQuantity_P+0)->Type != WQ_OPERATORANDQUANTITY)
vyyerror(0, "Missing Quantity in Equation");
}
else if(List_Nbr((yyvsp[(7) - (9)].l)) == 3 &&
((WholeQuantity_P+0)->Type == WQ_EXPRESSION &&
(WholeQuantity_P+1)->Type == WQ_OPERATORANDQUANTITY &&
(WholeQuantity_P+2)->Type == WQ_BINARYOPERATOR)) {
// FIXME: should also add the case (BUILTINFUNCTION OPERATORANDQUANTITY BINARYOPERATOR)
EquationTerm_S.Case.LocalTerm.Term.CanonicalWholeQuantity_Equ =
CWQ_EXP_TIME_DOF;
EquationTerm_S.Case.LocalTerm.Term.ExpressionIndexForCanonical_Equ =
(WholeQuantity_P+0)->Case.Expression.Index;
EquationTerm_S.Case.LocalTerm.Term.OperatorTypeForCanonical_Equ =
(WholeQuantity_P+2)->Case.Operator.TypeOperator;
}
else if(List_Nbr((yyvsp[(7) - (9)].l)) == 2 &&
((WholeQuantity_P+0)->Type == WQ_OPERATORANDQUANTITY &&
(WholeQuantity_P+1)->Type == WQ_BUILTINFUNCTION)) {
EquationTerm_S.Case.LocalTerm.Term.CanonicalWholeQuantity_Equ =
CWQ_FCT_DOF;
EquationTerm_S.Case.LocalTerm.Term.BuiltInFunction_Equ =
(WholeQuantity_P+1)->Case.Function.Fct;
}
else{
vyyerror(0, "Unrecognized quantity structure in Equation");
}
Pro_DefineQuantityIndex
(EquationTerm_S.Case.LocalTerm.Term.WholeQuantity,
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexEqu,
&EquationTerm_S.Case.LocalTerm.Term.NbrQuantityIndex,
&EquationTerm_S.Case.LocalTerm.Term.QuantityIndexTable,
&EquationTerm_S.Case.LocalTerm.Term.QuantityTraceGroupIndexTable);
EquationTerm_S.Case.LocalTerm.Term.QuantityIndexPost = 0;
for(int i = 0; i < EquationTerm_S.Case.LocalTerm.Term.NbrQuantityIndex; i++) {
if((EquationTerm_S.Case.LocalTerm.Term.QuantityIndexTable[i] !=
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexEqu) &&
(EquationTerm_S.Case.LocalTerm.Term.QuantityIndexTable[i] !=
EquationTerm_S.Case.LocalTerm.Term.DefineQuantityIndexDof)) {
EquationTerm_S.Case.LocalTerm.Term.QuantityIndexPost = 1;
break;
}
}
;}
break;
case 363:
#line 4011 "ProParser.y"
{
EquationTerm_S.Case.LocalTerm.InIndex = Num_Group(&Group_S, (char*)"FO_In", (yyvsp[(2) - (3)].i));
;}
break;
case 364:
#line 4016 "ProParser.y"
{
EquationTerm_S.Case.LocalTerm.SubRegion = Num_Group(&Group_S, (char*)"FO_In", (yyvsp[(2) - (3)].i));
;}
break;
case 365:
#line 4021 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.JacobianMethod, (yyvsp[(2) - (3)].c),
fcmp_JacobianMethod_Name)) < 0)
vyyerror(0, "Unknown Jacobian method: %s",(yyvsp[(2) - (3)].c));
else
EquationTerm_S.Case.LocalTerm.JacobianMethodIndex = i;
Free((yyvsp[(2) - (3)].c));
;}
break;
case 366:
#line 4032 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.IntegrationMethod, (yyvsp[(2) - (3)].c),
fcmp_IntegrationMethod_Name)) < 0)
vyyerror(0, "Unknown Integration method: %s", (yyvsp[(2) - (3)].c));
else
EquationTerm_S.Case.LocalTerm.IntegrationMethodIndex = i;
Free((yyvsp[(2) - (3)].c));
;}
break;
case 367:
#line 4043 "ProParser.y"
{
EquationTerm_S.Case.LocalTerm.Full_Matrix = 1;
;}
break;
case 368:
#line 4048 "ProParser.y"
{ if((yyvsp[(3) - (5)].i) == 1 || (yyvsp[(3) - (5)].i) == 2 || (yyvsp[(3) - (5)].i) == 3)
EquationTerm_S.Case.LocalTerm.MatrixIndex = (yyvsp[(3) - (5)].i);
else
vyyerror(0, "Unknown Matrix123: %d", (yyvsp[(3) - (5)].i));
;}
break;
case 369:
#line 4055 "ProParser.y"
{
EquationTerm_S.Case.LocalTerm.ExpressionIndexForMetricTensor = (yyvsp[(2) - (3)].i);
;}
break;
case 370:
#line 4064 "ProParser.y"
{ EquationTerm_S.Case.GlobalTerm.TypeTimeDerivative = NODT_;
EquationTerm_S.Case.GlobalTerm.DefineQuantityIndex = -1;
EquationTerm_S.Case.GlobalTerm.Term.TypeTimeDerivative = NODT_;
EquationTerm_S.Case.GlobalTerm.Term.TypeOperatorEqu = NOOP;
EquationTerm_S.Case.GlobalTerm.Term.TypeOperatorDof = NOOP;
EquationTerm_S.Case.GlobalTerm.Term.DefineQuantityIndexEqu = -1;
EquationTerm_S.Case.GlobalTerm.Term.DefineQuantityIndexDof = -1;
EquationTerm_S.Case.GlobalTerm.Term.DefineQuantityIndexNoDof = -1;
EquationTerm_S.Case.GlobalTerm.Term.WholeQuantity = NULL;
EquationTerm_S.Case.GlobalTerm.Term.DofIndexInWholeQuantity = -1;
EquationTerm_S.Case.GlobalTerm.InIndex = -1;
EquationTerm_S.Case.GlobalTerm.SubType = EQ_ST_SELF;
;}
break;
case 372:
#line 4085 "ProParser.y"
{
EquationTerm_S.Case.GlobalTerm.InIndex = Num_Group(&Group_S, (char*)"FO_In", (yyvsp[(2) - (3)].i));
;}
break;
case 373:
#line 4090 "ProParser.y"
{
EquationTerm_S.Case.GlobalTerm.SubType =
Get_DefineForString(Equation_SubType, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), Equation_SubType);
vyyerror(0, "Unknown sub-type of Equation: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 374:
#line 4101 "ProParser.y"
{
EquationTerm_S.Case.GlobalTerm.Term.TypeTimeDerivative = Type_TermOperator;
Current_DofIndexInWholeQuantity = -1;
Current_NoDofIndexInWholeQuantity = -1;
List_Reset(ListOfPointer_L);
;}
break;
case 375:
#line 4109 "ProParser.y"
{ EquationTerm_S.Case.GlobalTerm.Term.WholeQuantity = (yyvsp[(4) - (4)].l);
EquationTerm_S.Case.GlobalTerm.Term.DofIndexInWholeQuantity =
Current_DofIndexInWholeQuantity;
WholeQuantity_P = (struct WholeQuantity*)
List_Pointer(EquationTerm_S.Case.GlobalTerm.Term.WholeQuantity, 0);
if(Current_DofIndexInWholeQuantity >= 0) {
EquationTerm_S.Case.GlobalTerm.Term.TypeOperatorDof =
(WholeQuantity_P+Current_DofIndexInWholeQuantity)->
Case.OperatorAndQuantity.TypeOperator;
EquationTerm_S.Case.GlobalTerm.Term.DefineQuantityIndexDof =
(WholeQuantity_P+Current_DofIndexInWholeQuantity)->
Case.OperatorAndQuantity.Index;
}
else { /* No Dof{} */
EquationTerm_S.Case.GlobalTerm.Term.TypeOperatorDof = NOOP;
EquationTerm_S.Case.GlobalTerm.Term.DefineQuantityIndexDof = -1;
}
if(Current_NoDofIndexInWholeQuantity >= 0) {
EquationTerm_S.Case.GlobalTerm.Term.DefineQuantityIndexNoDof =
(WholeQuantity_P+Current_NoDofIndexInWholeQuantity)->
Case.OperatorAndQuantity.Index;
}
else { /* No NoDof{} */
EquationTerm_S.Case.GlobalTerm.Term.DefineQuantityIndexNoDof = -1;
}
/* Check if the WholeQuantity is a Canonical Form of type 'expr[] * Dof{}'*/
if((List_Nbr(EquationTerm_S.Case.GlobalTerm.Term.WholeQuantity) == 3) &&
((WholeQuantity_P+0)->Type == WQ_EXPRESSION) &&
((WholeQuantity_P+1)->Type == WQ_OPERATORANDQUANTITY) &&
((WholeQuantity_P+2)->Type == WQ_BINARYOPERATOR) &&
((WholeQuantity_P+2)->Case.Operator.TypeOperator == OP_TIME) &&
(Current_DofIndexInWholeQuantity == 1)) {
EquationTerm_S.Case.GlobalTerm.Term.CanonicalWholeQuantity =
CWQ_EXP_TIME_DOF;
EquationTerm_S.Case.GlobalTerm.Term.ExpressionIndexForCanonical =
(WholeQuantity_P+0)->Case.Expression.Index;
}
else if((List_Nbr(EquationTerm_S.Case.GlobalTerm.Term.WholeQuantity) == 1) &&
((WholeQuantity_P+0)->Type == WQ_OPERATORANDQUANTITY) &&
(Current_DofIndexInWholeQuantity == 0)) {
EquationTerm_S.Case.GlobalTerm.Term.CanonicalWholeQuantity = CWQ_DOF;
}
else {
EquationTerm_S.Case.GlobalTerm.Term.CanonicalWholeQuantity = CWQ_NONE;
}
;}
break;
case 376:
#line 4164 "ProParser.y"
{ EquationTerm_S.Case.GlobalTerm.Term.TypeOperatorEqu = (yyvsp[(7) - (9)].t).Int1;
EquationTerm_S.Case.GlobalTerm.Term.DefineQuantityIndexEqu = (yyvsp[(7) - (9)].t).Int2;
Pro_DefineQuantityIndex
(EquationTerm_S.Case.GlobalTerm.Term.WholeQuantity,
EquationTerm_S.Case.GlobalTerm.Term.DefineQuantityIndexEqu,
&EquationTerm_S.Case.GlobalTerm.Term.NbrQuantityIndex,
&EquationTerm_S.Case.GlobalTerm.Term.QuantityIndexTable,
&EquationTerm_S.Case.GlobalTerm.Term.QuantityTraceGroupIndexTable);
;}
break;
case 377:
#line 4181 "ProParser.y"
{ Type_TermOperator = NODT_ ; ;}
break;
case 378:
#line 4182 "ProParser.y"
{ Type_TermOperator = DT_ ; ;}
break;
case 379:
#line 4183 "ProParser.y"
{ Type_TermOperator = DTDOF_ ; ;}
break;
case 380:
#line 4184 "ProParser.y"
{ Type_TermOperator = DTDT_ ; ;}
break;
case 381:
#line 4185 "ProParser.y"
{ Type_TermOperator = DTDTDOF_ ; ;}
break;
case 382:
#line 4186 "ProParser.y"
{ Type_TermOperator = DTDTDTDOF_ ; ;}
break;
case 383:
#line 4187 "ProParser.y"
{ Type_TermOperator = DTDTDTDTDOF_ ; ;}
break;
case 384:
#line 4188 "ProParser.y"
{ Type_TermOperator = DTDTDTDTDTDOF_ ; ;}
break;
case 385:
#line 4189 "ProParser.y"
{ Type_TermOperator = JACNL_ ; ;}
break;
case 386:
#line 4190 "ProParser.y"
{ Type_TermOperator = DTDOFJACNL_ ; ;}
break;
case 387:
#line 4191 "ProParser.y"
{ Type_TermOperator = NEVERDT_ ; ;}
break;
case 388:
#line 4192 "ProParser.y"
{ Type_TermOperator = DTNL_ ; ;}
break;
case 389:
#line 4199 "ProParser.y"
{ (yyval.t).Int1 = Get_DefineForString(Operator_Type, (yyvsp[(2) - (4)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (4)].c), Operator_Type);
vyyerror(0, "Unknown Operator for discrete Quantity: %s", (yyvsp[(2) - (4)].c));
}
Free((yyvsp[(2) - (4)].c));
int i;
if((i = List_ISearchSeq(Formulation_S.DefineQuantity, (yyvsp[(3) - (4)].c),
fcmp_DefineQuantity_Name)) < 0)
vyyerror(0, "Unknown discrete Quantity: %s", (yyvsp[(3) - (4)].c));
(yyval.t).Int2 = i;
/* the following should be suppressed as soon as the test
function part in the formulations is correctly treated */
Quantity_TypeOperator = (yyval.t).Int1;
Quantity_Index = (yyval.t).Int2;
Free((yyvsp[(3) - (4)].c));
;}
break;
case 390:
#line 4220 "ProParser.y"
{ (yyval.t).Int1 = NOOP;
int i;
if((i = List_ISearchSeq(Formulation_S.DefineQuantity, (yyvsp[(2) - (3)].c),
fcmp_DefineQuantity_Name)) < 0)
vyyerror(0, "Unknown discrete Quantity: %s", (yyvsp[(2) - (3)].c));
(yyval.t).Int2 = i;
/* the following should be suppressed as soon as the test
function part in the formulations is correctly treated */
Quantity_TypeOperator = (yyval.t).Int1;
Quantity_Index = (yyval.t).Int2;
Free((yyvsp[(2) - (3)].c));
;}
break;
case 391:
#line 4244 "ProParser.y"
{ if(!Problem_S.Resolution)
Problem_S.Resolution = List_Create(10, 5, sizeof (struct Resolution));
;}
break;
case 393:
#line 4254 "ProParser.y"
{
if (level_Append && index_Append>=0)
List_Write(Problem_S.Resolution, index_Append, &Resolution_S);
else
List_Add(Problem_S.Resolution, &Resolution_S);
;}
break;
case 395:
#line 4268 "ProParser.y"
{
Resolution_S.Name = NULL;
Resolution_S.Hidden = false;
Resolution_S.DefineSystem = NULL;
Resolution_S.Operation = NULL;
level_Append = 0;
;}
break;
case 397:
#line 4283 "ProParser.y"
{ level_Append = (yyvsp[(1) - (2)].i); index_Append = -1; ;}
break;
case 398:
#line 4286 "ProParser.y"
{
index_Append =
Check_NameOfStructExist("Resolution", Problem_S.Resolution,
(yyvsp[(2) - (3)].c), fcmp_Resolution_Name, level_Append);
if (index_Append<0)
Resolution_S.Name = (yyvsp[(2) - (3)].c);
else{
List_Read(Problem_S.Resolution, index_Append, &Resolution_S);
Free((yyvsp[(2) - (3)].c));
}
;}
break;
case 399:
#line 4298 "ProParser.y"
{ Resolution_S.Hidden = (yyvsp[(2) - (3)].d) ? true : false; ;}
break;
case 400:
#line 4301 "ProParser.y"
{ Resolution_S.DefineSystem = (yyvsp[(3) - (4)].l); ;}
break;
case 401:
#line 4304 "ProParser.y"
{ Operation_L = List_Create(5, 5, sizeof(struct Operation)); ;}
break;
case 402:
#line 4306 "ProParser.y"
{ Resolution_S.Operation = (yyvsp[(4) - (5)].l); List_Delete(Operation_L); ;}
break;
case 404:
#line 4314 "ProParser.y"
{
(yyval.l) = Current_System_L =
Resolution_S.DefineSystem?
Resolution_S.DefineSystem :
List_Create(6, 6, sizeof (struct DefineSystem));
;}
break;
case 405:
#line 4322 "ProParser.y"
{
int i ;
if ((i = List_ISearchSeq(Current_System_L, DefineSystem_S.Name, fcmp_DefineSystem_Name)) < 0)
List_Add((yyval.l) = Current_System_L = (yyvsp[(1) - (4)].l), &DefineSystem_S) ;
else
List_Write(Current_System_L, i, &DefineSystem_S) ;
;}
break;
case 406:
#line 4331 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (2)].l);
;}
break;
case 407:
#line 4340 "ProParser.y"
{ DefineSystem_S.Name = NULL;
DefineSystem_S.Type = VAL_REAL;
DefineSystem_S.FormulationIndex = NULL;
DefineSystem_S.MeshName = NULL;
DefineSystem_S.AdaptName = NULL;
DefineSystem_S.FrequencyValue = NULL;
DefineSystem_S.SolverDataFileName = NULL;
DefineSystem_S.OriginSystemIndex = NULL;
DefineSystem_S.DestinationSystemName = NULL;
DefineSystem_S.DestinationSystemIndex = -1;
;}
break;
case 409:
#line 4359 "ProParser.y"
{
int i;
if ((i = List_ISearchSeq(Current_System_L, (yyvsp[(2) - (3)].c), fcmp_DefineSystem_Name)) < 0)
DefineSystem_S.Name = (yyvsp[(2) - (3)].c) ;
else
List_Read(Current_System_L, i, &DefineSystem_S) ;
;}
break;
case 410:
#line 4368 "ProParser.y"
{ DefineSystem_S.Type = Get_DefineForString(DefineSystem_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), DefineSystem_Type);
vyyerror(0, "Unknown type of System: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 411:
#line 4377 "ProParser.y"
{ DefineSystem_S.FormulationIndex = (yyvsp[(2) - (3)].l); ;}
break;
case 412:
#line 4380 "ProParser.y"
{
DefineSystem_S.MeshName = strSave(Fix_RelativePath((yyvsp[(2) - (3)].c)).c_str());
Free((yyvsp[(2) - (3)].c));
;}
break;
case 413:
#line 4386 "ProParser.y"
{
if (!DefineSystem_S.OriginSystemIndex) {
DefineSystem_S.OriginSystemIndex = (yyvsp[(2) - (3)].l) ;
}
else {
for (int i = 0 ; i < List_Nbr((yyvsp[(2) - (3)].l)) ; i++)
List_Add(DefineSystem_S.OriginSystemIndex, (int *)List_Pointer((yyvsp[(2) - (3)].l), i) ) ;
}
;}
break;
case 414:
#line 4397 "ProParser.y"
{
DefineSystem_S.DestinationSystemName = (yyvsp[(2) - (3)].c);
;}
break;
case 415:
#line 4402 "ProParser.y"
{ DefineSystem_S.FrequencyValue = (yyvsp[(2) - (3)].l);
DefineSystem_S.Type = VAL_COMPLEX;
;}
break;
case 416:
#line 4407 "ProParser.y"
{
DefineSystem_S.SolverDataFileName = (yyvsp[(2) - (3)].c);
;}
break;
case 418:
#line 4418 "ProParser.y"
{
(yyval.l) = List_Create(1, 1, sizeof(int));
int i;
if((i = List_ISearchSeq(Problem_S.Formulation, (yyvsp[(1) - (1)].c), fcmp_Formulation_Name)) < 0)
vyyerror(0, "Unknown Formulation: %s", (yyvsp[(1) - (1)].c));
else List_Add((yyval.l), &i);
Free((yyvsp[(1) - (1)].c));
;}
break;
case 419:
#line 4428 "ProParser.y"
{ (yyval.l) = (yyvsp[(2) - (3)].l); ;}
break;
case 420:
#line 4435 "ProParser.y"
{ (yyval.l) = List_Create(2, 2, sizeof(int)); ;}
break;
case 421:
#line 4438 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.Formulation, (yyvsp[(3) - (3)].c), fcmp_Formulation_Name)) < 0)
vyyerror(0, "Unknown Formulation: %s", (yyvsp[(3) - (3)].c));
else
List_Add((yyvsp[(1) - (3)].l), &i);
(yyval.l) = (yyvsp[(1) - (3)].l); Free((yyvsp[(3) - (3)].c));
;}
break;
case 422:
#line 4451 "ProParser.y"
{
(yyval.l) = List_Create(1, 1, sizeof(int));
int i;
if((i = List_ISearchSeq(Current_System_L, (yyvsp[(1) - (1)].c), fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(1) - (1)].c));
else
List_Add((yyval.l), &i);
Free((yyvsp[(1) - (1)].c));
;}
break;
case 423:
#line 4462 "ProParser.y"
{ (yyval.l) = (yyvsp[(2) - (3)].l); ;}
break;
case 424:
#line 4468 "ProParser.y"
{ (yyval.l) = List_Create(2, 2, sizeof(int)); ;}
break;
case 425:
#line 4471 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Current_System_L, (yyvsp[(3) - (3)].c), fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (3)].c));
else
List_Add((yyvsp[(1) - (3)].l), &i);
(yyval.l) = (yyvsp[(1) - (3)].l); Free((yyvsp[(3) - (3)].c));
;}
break;
case 426:
#line 4484 "ProParser.y"
{
(yyval.l) = Resolution_S.Operation?
Resolution_S.Operation :
List_Create(6, 6, sizeof (struct Operation));
Operation_S.Type = OPERATION_NONE;
Operation_S.DefineSystemIndex = -1;
Operation_S.Flag = -1;
List_Add(Operation_L, &Operation_S);
;}
break;
case 427:
#line 4495 "ProParser.y"
{
if(((struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1))->Type != OPERATION_NONE){
List_Add((yyval.l) = (yyvsp[(1) - (2)].l), (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1));
}
;}
break;
case 428:
#line 4505 "ProParser.y"
{ (yyval.i) = -1; ;}
break;
case 429:
#line 4507 "ProParser.y"
{ (yyval.i) = (int)(yyvsp[(2) - (2)].d); ;}
break;
case 430:
#line 4511 "ProParser.y"
{ (yyval.i) = OPERATION_GMSHREAD; ;}
break;
case 431:
#line 4512 "ProParser.y"
{ (yyval.i) = OPERATION_GMSHOPEN; ;}
break;
case 432:
#line 4513 "ProParser.y"
{ (yyval.i) = OPERATION_GMSHMERGE; ;}
break;
case 433:
#line 4514 "ProParser.y"
{ (yyval.i) = OPERATION_GMSHWRITE; ;}
break;
case 434:
#line 4517 "ProParser.y"
{ (yyval.i) = OPERATION_GENERATE; ;}
break;
case 435:
#line 4518 "ProParser.y"
{ (yyval.i) = OPERATION_GENERATEJAC; ;}
break;
case 436:
#line 4519 "ProParser.y"
{ (yyval.i) = OPERATION_GENERATERHS; ;}
break;
case 437:
#line 4520 "ProParser.y"
{ (yyval.i) = OPERATION_GENERATE_CUMULATIVE; ;}
break;
case 438:
#line 4521 "ProParser.y"
{ (yyval.i) = OPERATION_GENERATEJAC_CUMULATIVE; ;}
break;
case 439:
#line 4522 "ProParser.y"
{ (yyval.i) = OPERATION_GENERATERHS_CUMULATIVE; ;}
break;
case 440:
#line 4525 "ProParser.y"
{ (yyval.i) = OPERATION_COPYSOLUTION; ;}
break;
case 441:
#line 4526 "ProParser.y"
{ (yyval.i) = OPERATION_COPYRHS; ;}
break;
case 442:
#line 4527 "ProParser.y"
{ (yyval.i) = OPERATION_COPYRESIDUAL; ;}
break;
case 443:
#line 4528 "ProParser.y"
{ (yyval.i) = OPERATION_COPYINCREMENT; ;}
break;
case 444:
#line 4529 "ProParser.y"
{ (yyval.i) = OPERATION_COPYDOFS; ;}
break;
case 445:
#line 4532 "ProParser.y"
{ (yyval.i) = OPERATION_GETRESIDUAL; ;}
break;
case 446:
#line 4533 "ProParser.y"
{ (yyval.i) = OPERATION_GETNORMSOLUTION; ;}
break;
case 447:
#line 4534 "ProParser.y"
{ (yyval.i) = OPERATION_GETNORMRHS; ;}
break;
case 448:
#line 4535 "ProParser.y"
{ (yyval.i) = OPERATION_GETNORMRESIDUAL; ;}
break;
case 449:
#line 4536 "ProParser.y"
{ (yyval.i) = OPERATION_GETNORMINCREMENT; ;}
break;
case 450:
#line 4543 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = Get_DefineForString(Operation_Type, (yyvsp[(1) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(1) - (3)].c), Operation_Type);
vyyerror(0, "Unknown type of Operation: %s", (yyvsp[(1) - (3)].c));
}
Free((yyvsp[(1) - (3)].c));
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(2) - (3)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(2) - (3)].c));
Free((yyvsp[(2) - (3)].c));
Operation_P->DefineSystemIndex = i;
if(Operation_P->Type == OPERATION_GENERATE ||
Operation_P->Type == OPERATION_GENERATERHS ||
Operation_P->Type == OPERATION_GENERATEJAC ||
Operation_P->Type == OPERATION_GENERATESEPARATE)
Operation_P->Case.Generate.GroupIndex = -1;
;}
break;
case 451:
#line 4567 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SETTIME;
Operation_P->Case.SetTime.ExpressionIndex = (yyvsp[(2) - (3)].i);
;}
break;
case 452:
#line 4574 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SETTIMESTEP;
Operation_P->Case.SetTime.ExpressionIndex = (yyvsp[(2) - (3)].i);
;}
break;
case 453:
#line 4581 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_TIMELOOPTHETA;
;}
break;
case 454:
#line 4587 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_TIMELOOPNEWMARK;
;}
break;
case 455:
#line 4593 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_ITERATIVELOOP;
;}
break;
case 456:
#line 4599 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_ITERATIVETIMEREDUCTION;
;}
break;
case 457:
#line 4607 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = Get_DefineForString(Operation_Type, (yyvsp[(1) - (6)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(1) - (6)].c), Operation_Type);
vyyerror(0, "Unknown type of Operation: %s", (yyvsp[(1) - (6)].c));
}
Free((yyvsp[(1) - (6)].c));
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (6)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (6)].c));
Free((yyvsp[(3) - (6)].c));
Operation_P->DefineSystemIndex = i;
if(Operation_P->Type == OPERATION_GENERATE ||
Operation_P->Type == OPERATION_GENERATERHS ||
Operation_P->Type == OPERATION_GENERATEJAC ||
Operation_P->Type == OPERATION_GENERATESEPARATE)
Operation_P->Case.Generate.GroupIndex = -1;
Operation_P->Flag = (yyvsp[(4) - (6)].i);
;}
break;
case 458:
#line 4630 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SETTIME;
Operation_P->Case.SetTime.ExpressionIndex = (yyvsp[(3) - (5)].i);
;}
break;
case 459:
#line 4637 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SETTIMESTEP;
Operation_P->Case.SetTime.ExpressionIndex = (yyvsp[(3) - (5)].i);
;}
break;
case 460:
#line 4644 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SETDTIME;
Operation_P->Case.SetTime.ExpressionIndex = (yyvsp[(3) - (5)].i);
;}
break;
case 461:
#line 4651 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SLEEP;
Operation_P->Case.Sleep.ExpressionIndex = (yyvsp[(3) - (5)].i);
;}
break;
case 462:
#line 4658 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SETCOMMSELF;
;}
break;
case 463:
#line 4664 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SETCOMMSELF;
;}
break;
case 464:
#line 4670 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SETCOMMWORLD;
;}
break;
case 465:
#line 4676 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SETCOMMWORLD;
;}
break;
case 466:
#line 4682 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_BARRIER;
;}
break;
case 467:
#line 4688 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_BARRIER;
;}
break;
case 468:
#line 4694 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_BROADCASTFIELDS;
Operation_P->Case.BroadcastFields.FieldsToSkip = (yyvsp[(3) - (5)].l);
;}
break;
case 469:
#line 4701 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_BROADCASTVARIABLES;
;}
break;
case 470:
#line 4707 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_BREAK;
;}
break;
case 471:
#line 4713 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_BREAK;
;}
break;
case 472:
#line 4719 "ProParser.y"
{
List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_TEST;
Operation_P->Case.Test.ExpressionIndex = (yyvsp[(3) - (7)].i);
Operation_P->Case.Test.Operation_True = (yyvsp[(6) - (7)].l);
Operation_P->Case.Test.Operation_False = NULL;
;}
break;
case 473:
#line 4730 "ProParser.y"
{
List_Pop(Operation_L);
List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_TEST;
Operation_P->Case.Test.ExpressionIndex = (yyvsp[(3) - (10)].i);
Operation_P->Case.Test.Operation_True = (yyvsp[(6) - (10)].l);
Operation_P->Case.Test.Operation_False = (yyvsp[(9) - (10)].l);
;}
break;
case 474:
#line 4742 "ProParser.y"
{
List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_WHILE;
Operation_P->Case.While.ExpressionIndex = (yyvsp[(3) - (7)].i);
Operation_P->Case.While.Operation = (yyvsp[(6) - (7)].l);
;}
break;
case 475:
#line 4752 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SETFREQUENCY;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c));
Free((yyvsp[(3) - (7)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.SetFrequency.ExpressionIndex = (yyvsp[(5) - (7)].i);
;}
break;
case 476:
#line 4765 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_GENERATEONLY;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c));
Free((yyvsp[(3) - (7)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.GenerateOnly.MatrixIndex_L =
List_Create(List_Nbr((yyvsp[(5) - (7)].l)),1,sizeof(int));
for(int i = 0; i < List_Nbr((yyvsp[(5) - (7)].l)); i++){
double d;
List_Read((yyvsp[(5) - (7)].l),i,&d);
int j = (int)d;
List_Add(Operation_P->Case.GenerateOnly.MatrixIndex_L, &j);
}
List_Delete((yyvsp[(5) - (7)].l));
;}
break;
case 477:
#line 4787 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_GENERATEONLYJAC;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c));
Free((yyvsp[(3) - (7)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.GenerateOnly.MatrixIndex_L =
List_Create(List_Nbr((yyvsp[(5) - (7)].l)),1,sizeof(int));
for(int i = 0; i < List_Nbr((yyvsp[(5) - (7)].l)); i++){
double d;
List_Read((yyvsp[(5) - (7)].l),i,&d);
int j = (int)d;
List_Add(Operation_P->Case.GenerateOnly.MatrixIndex_L, &j);
}
List_Delete((yyvsp[(5) - (7)].l));
;}
break;
case 478:
#line 4809 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_UPDATE;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (5)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (5)].c));
Free((yyvsp[(3) - (5)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.Update.ExpressionIndex = -1;
;}
break;
case 479:
#line 4822 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_UPDATE;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c));
Free((yyvsp[(3) - (7)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.Update.ExpressionIndex = (yyvsp[(5) - (7)].i);
;}
break;
case 480:
#line 4835 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_UPDATECONSTRAINT;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (9)].c));
Free((yyvsp[(3) - (9)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.UpdateConstraint.GroupIndex =
Num_Group(&Group_S, (char*)"OP_UpdateCst", (yyvsp[(5) - (9)].i));
Operation_P->Case.UpdateConstraint.Type =
Get_DefineForString(Constraint_Type, (yyvsp[(7) - (9)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(7) - (9)].c), Constraint_Type);
vyyerror(0, "Unknown type of Constraint: %s", (yyvsp[(7) - (9)].c));
}
Free((yyvsp[(7) - (9)].c));
;}
break;
case 481:
#line 4856 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1) ;
Operation_P->Type = OPERATION_UPDATECONSTRAINT ;
int i;
if ((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (5)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (5)].c)) ;
Free((yyvsp[(3) - (5)].c)) ;
Operation_P->DefineSystemIndex = i ;
Operation_P->Case.UpdateConstraint.GroupIndex = -1;
Operation_P->Case.UpdateConstraint.Type = ASSIGN;
;}
break;
case 482:
#line 4870 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = (yyvsp[(1) - (8)].i);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (8)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (8)].c));
Free((yyvsp[(3) - (8)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.GetNorm.VariableName = (yyvsp[(6) - (8)].c);
Operation_P->Case.GetNorm.NormType = L2NORM;
/*
NormType = Get_DefineForString(ErrorNorm_Type, $xx, &FlagError);
if(FlagError){
Get_Valid_SXD($xx, ErrorNorm_Type);
vyyerror(0, "Unknown error norm type for residual calculation");
}
*/
;}
break;
case 483:
#line 4891 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_CREATESOLUTION;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (5)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (5)].c));
Free((yyvsp[(3) - (5)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.CreateSolution.CopyFromTimeStep = -1;
;}
break;
case 484:
#line 4904 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_CREATESOLUTION;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c));
Free((yyvsp[(3) - (7)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.CreateSolution.CopyFromTimeStep = (yyvsp[(5) - (7)].d);
;}
break;
case 485:
#line 4917 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_FOURIERTRANSFORM;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (9)].c));
Free((yyvsp[(3) - (9)].c));
Operation_P->Case.FourierTransform.DefineSystemIndex[0] = i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(5) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(5) - (9)].c));
Free((yyvsp[(5) - (9)].c));
Operation_P->Case.FourierTransform.DefineSystemIndex[1] = i;
Operation_P->Case.FourierTransform.Frequency = (yyvsp[(7) - (9)].l);
;}
break;
case 486:
#line 4935 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_FOURIERTRANSFORM2;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (9)].c));
Free((yyvsp[(3) - (9)].c));
Operation_P->Case.FourierTransform2.DefineSystemIndex[0] = i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(5) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(5) - (9)].c));
Free((yyvsp[(5) - (9)].c));
Operation_P->Case.FourierTransform2.DefineSystemIndex[1] = i;
Operation_P->Case.FourierTransform2.Period = (yyvsp[(7) - (9)].d);
Operation_P->Case.FourierTransform2.Period_sofar = 0.;
Operation_P->Case.FourierTransform2.Scales = NULL;
;}
break;
case 487:
#line 4955 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_LANCZOS;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (11)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (11)].c));
Free((yyvsp[(3) - (11)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.Lanczos.Size = (int)(yyvsp[(5) - (11)].d);
Operation_P->Case.Lanczos.Save =
List_Create(List_Nbr((yyvsp[(7) - (11)].l)), 1, sizeof(int));
for(int l = 0; l < List_Nbr((yyvsp[(7) - (11)].l)); l++) {
double d;
List_Read((yyvsp[(7) - (11)].l), l, &d);
int j = (int)d;
List_Add(Operation_P->Case.Lanczos.Save, &j);
}
List_Delete((yyvsp[(7) - (11)].l));
Operation_P->Case.Lanczos.Shift = (yyvsp[(9) - (11)].d);
;}
break;
case 488:
#line 4978 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_EIGENSOLVE;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (11)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (11)].c));
Free((yyvsp[(3) - (11)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.EigenSolve.NumEigenvalues = (int)(yyvsp[(5) - (11)].d);
Operation_P->Case.EigenSolve.Shift_r = (yyvsp[(7) - (11)].d);
Operation_P->Case.EigenSolve.Shift_i = (yyvsp[(9) - (11)].d);
Operation_P->Case.EigenSolve.FilterExpressionIndex = -1;
;}
break;
case 489:
#line 4995 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_EIGENSOLVE;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (13)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (13)].c));
Free((yyvsp[(3) - (13)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.EigenSolve.NumEigenvalues = (int)(yyvsp[(5) - (13)].d);
Operation_P->Case.EigenSolve.Shift_r = (yyvsp[(7) - (13)].d);
Operation_P->Case.EigenSolve.Shift_i = (yyvsp[(9) - (13)].d);
Operation_P->Case.EigenSolve.FilterExpressionIndex = (yyvsp[(11) - (13)].i);
;}
break;
case 490:
#line 5011 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_EIGENSOLVEJAC;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (11)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (11)].c));
Free((yyvsp[(3) - (11)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.EigenSolve.NumEigenvalues = (int)(yyvsp[(5) - (11)].d);
Operation_P->Case.EigenSolve.Shift_r = (yyvsp[(7) - (11)].d);
Operation_P->Case.EigenSolve.Shift_i = (yyvsp[(9) - (11)].d);
Operation_P->Case.EigenSolve.FilterExpressionIndex = -1;
;}
break;
case 491:
#line 5027 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_EVALUATE;
Operation_P->Case.Evaluate.Expressions = List_Copy(ListOfInt_L);
;}
break;
case 492:
#line 5034 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1) ;
Operation_P->Type = OPERATION_SELECTCORRECTION;
int i;
if ((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c)) ;
Free((yyvsp[(3) - (7)].c)) ;
Operation_P->DefineSystemIndex = i ;
Operation_P->Case.SelectCorrection.Iteration = (int)(yyvsp[(5) - (7)].d) ;
;}
break;
case 493:
#line 5047 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1) ;
Operation_P->Type = OPERATION_ADDCORRECTION;
int i;
if ((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (5)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (5)].c)) ;
Free((yyvsp[(3) - (5)].c)) ;
Operation_P->DefineSystemIndex = i ;
Operation_P->Case.AddCorrection.Alpha = 1. ;
;}
break;
case 494:
#line 5060 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1) ;
Operation_P->Type = OPERATION_ADDCORRECTION;
int i;
if ((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c)) ;
Free((yyvsp[(3) - (7)].c)) ;
Operation_P->DefineSystemIndex = i ;
Operation_P->Case.AddCorrection.Alpha = (yyvsp[(5) - (7)].d) ;
;}
break;
case 495:
#line 5073 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1) ;
Operation_P->Type = OPERATION_MULTIPLYSOLUTION;
int i;
if ((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c)) ;
Free((yyvsp[(3) - (7)].c)) ;
Operation_P->DefineSystemIndex = i ;
Operation_P->Case.MultiplySolution.Alpha = (yyvsp[(5) - (7)].d) ;
;}
break;
case 496:
#line 5086 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1) ;
Operation_P->Type = OPERATION_ADDOPPOSITEFULLSOLUTION;
int i;
if ((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (5)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (5)].c)) ;
Free((yyvsp[(3) - (5)].c)) ;
Operation_P->DefineSystemIndex = i ;
;}
break;
case 497:
#line 5099 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_PERTURBATION;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (17)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (17)].c));
Free((yyvsp[(3) - (17)].c));
Operation_P->DefineSystemIndex = i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(5) - (17)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(5) - (17)].c));
Free((yyvsp[(5) - (17)].c));
Operation_P->Case.Perturbation.DefineSystemIndex2 = i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(7) - (17)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(7) - (17)].c));
Free((yyvsp[(7) - (17)].c));
Operation_P->Case.Perturbation.DefineSystemIndex3 = i;
Operation_P->Case.Perturbation.Size = (int)(yyvsp[(9) - (17)].d);
Operation_P->Case.Perturbation.Save =
List_Create(List_Nbr((yyvsp[(11) - (17)].l)), 1, sizeof(int));
for(int l = 0; l < List_Nbr((yyvsp[(11) - (17)].l)); l++) {
double d;
List_Read((yyvsp[(11) - (17)].l), l, &d);
int j = (int)d;
List_Add(Operation_P->Case.Perturbation.Save, &j);
}
List_Delete((yyvsp[(11) - (17)].l));
Operation_P->Case.Perturbation.Shift = (yyvsp[(13) - (17)].d);
Operation_P->Case.Perturbation.PertFreq = (int)(yyvsp[(15) - (17)].d);
;}
break;
case 498:
#line 5134 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_TIMELOOPTHETA;
Operation_P->Case.TimeLoopTheta.Time0 = (yyvsp[(3) - (13)].d);
Operation_P->Case.TimeLoopTheta.TimeMax = (yyvsp[(5) - (13)].d);
Operation_P->Case.TimeLoopTheta.DTimeIndex = (yyvsp[(7) - (13)].i);
Operation_P->Case.TimeLoopTheta.ThetaIndex = (yyvsp[(9) - (13)].i);
Operation_P->Case.TimeLoopTheta.Operation = (yyvsp[(12) - (13)].l);
;}
break;
case 499:
#line 5147 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_TIMELOOPNEWMARK;
Operation_P->Case.TimeLoopNewmark.Time0 = (yyvsp[(3) - (15)].d);
Operation_P->Case.TimeLoopNewmark.TimeMax = (yyvsp[(5) - (15)].d);
Operation_P->Case.TimeLoopNewmark.DTimeIndex = (yyvsp[(7) - (15)].i);
Operation_P->Case.TimeLoopNewmark.Beta = (yyvsp[(9) - (15)].d);
Operation_P->Case.TimeLoopNewmark.Gamma = (yyvsp[(11) - (15)].d);
Operation_P->Case.TimeLoopNewmark.Operation = (yyvsp[(14) - (15)].l);
;}
break;
case 500:
#line 5161 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_TIMELOOPRUNGEKUTTA;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (17)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (17)].c));
Free((yyvsp[(3) - (17)].c));
Operation_P->DefineSystemIndex = i ;
Operation_P->Case.TimeLoopRungeKutta.Time0 = (yyvsp[(5) - (17)].d);
Operation_P->Case.TimeLoopRungeKutta.TimeMax = (yyvsp[(7) - (17)].d);
Operation_P->Case.TimeLoopRungeKutta.DTimeIndex = (yyvsp[(9) - (17)].i);
Operation_P->Case.TimeLoopRungeKutta.ButcherA = (yyvsp[(11) - (17)].l);
Operation_P->Case.TimeLoopRungeKutta.ButcherB = (yyvsp[(13) - (17)].l);
Operation_P->Case.TimeLoopRungeKutta.ButcherC = (yyvsp[(15) - (17)].l);
;}
break;
case 501:
#line 5181 "ProParser.y"
{
List_Pop(Operation_L);
List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_TIMELOOPADAPTIVE;
Operation_P->Case.TimeLoopAdaptive.Time0 = (yyvsp[(3) - (25)].d);
Operation_P->Case.TimeLoopAdaptive.TimeMax = (yyvsp[(5) - (25)].d);
Operation_P->Case.TimeLoopAdaptive.DTimeInit = (yyvsp[(7) - (25)].d);
Operation_P->Case.TimeLoopAdaptive.DTimeMin = (yyvsp[(9) - (25)].d);
Operation_P->Case.TimeLoopAdaptive.DTimeMax = (yyvsp[(11) - (25)].d);
Operation_P->Case.TimeLoopAdaptive.Scheme = (yyvsp[(13) - (25)].c);
Operation_P->Case.TimeLoopAdaptive.Breakpoints_L = (yyvsp[(15) - (25)].l);
Operation_P->Case.TimeLoopAdaptive.Operation = (yyvsp[(21) - (25)].l);
Operation_P->Case.TimeLoopAdaptive.OperationEnd = (yyvsp[(24) - (25)].l);
;}
break;
case 502:
#line 5200 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_ITERATIVELOOPN;
Operation_P->Case.IterativeLoop.NbrMaxIteration = (int)(yyvsp[(3) - (11)].d);
Operation_P->Case.IterativeLoop.RelaxationFactorIndex = (yyvsp[(5) - (11)].i);
Operation_P->Case.IterativeLoop.Operation = (yyvsp[(10) - (11)].l);
;}
break;
case 503:
#line 5211 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_ITERATIVELOOP;
Operation_P->Case.IterativeLoop.NbrMaxIteration = (int)(yyvsp[(3) - (11)].d);
Operation_P->Case.IterativeLoop.Criterion = (yyvsp[(5) - (11)].d);
Operation_P->Case.IterativeLoop.RelaxationFactorIndex = (yyvsp[(7) - (11)].i);
Operation_P->Case.IterativeLoop.Flag = 0;
Operation_P->Case.IterativeLoop.Operation = (yyvsp[(10) - (11)].l);
;}
break;
case 504:
#line 5224 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_ITERATIVELOOP;
Operation_P->Case.IterativeLoop.NbrMaxIteration = (int)(yyvsp[(3) - (13)].d);
Operation_P->Case.IterativeLoop.Criterion = (yyvsp[(5) - (13)].d);
Operation_P->Case.IterativeLoop.RelaxationFactorIndex = (yyvsp[(7) - (13)].i);
Operation_P->Case.IterativeLoop.Flag = (int)(yyvsp[(9) - (13)].d);
Operation_P->Case.IterativeLoop.Operation = (yyvsp[(12) - (13)].l);
;}
break;
case 505:
#line 5238 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_ITERATIVELINEARSOLVER;
Operation_P->Case.IterativeLinearSolver.OpMatMult = (yyvsp[(3) - (21)].c);
Operation_P->Case.IterativeLinearSolver.Type = (yyvsp[(5) - (21)].c);
Operation_P->Case.IterativeLinearSolver.Tolerance = (yyvsp[(7) - (21)].d);
Operation_P->Case.IterativeLinearSolver.MaxIter = (int)(yyvsp[(9) - (21)].d);
Operation_P->Case.IterativeLinearSolver.Restart = (int)(yyvsp[(11) - (21)].d);
Operation_P->Case.IterativeLinearSolver.MyFieldTag = (yyvsp[(13) - (21)].l);
Operation_P->Case.IterativeLinearSolver.NeighborFieldTag = (yyvsp[(15) - (21)].l);
Operation_P->Case.IterativeLinearSolver.DeflationIndices = (yyvsp[(17) - (21)].l);
Operation_P->Case.IterativeLinearSolver.Operations_Ax = (yyvsp[(20) - (21)].l);
Operation_P->Case.IterativeLinearSolver.Operations_Mx = NULL;
;}
break;
case 506:
#line 5258 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_ITERATIVELINEARSOLVER;
Operation_P->Case.IterativeLinearSolver.OpMatMult = (yyvsp[(3) - (24)].c);
Operation_P->Case.IterativeLinearSolver.Type = (yyvsp[(5) - (24)].c);
Operation_P->Case.IterativeLinearSolver.Tolerance = (yyvsp[(7) - (24)].d);
Operation_P->Case.IterativeLinearSolver.MaxIter = (int)(yyvsp[(9) - (24)].d);
Operation_P->Case.IterativeLinearSolver.Restart = (int)(yyvsp[(11) - (24)].d);
Operation_P->Case.IterativeLinearSolver.MyFieldTag = (yyvsp[(13) - (24)].l);
Operation_P->Case.IterativeLinearSolver.NeighborFieldTag = (yyvsp[(15) - (24)].l);
Operation_P->Case.IterativeLinearSolver.DeflationIndices = (yyvsp[(17) - (24)].l);
Operation_P->Case.IterativeLinearSolver.Operations_Ax = (yyvsp[(20) - (24)].l);
Operation_P->Case.IterativeLinearSolver.Operations_Mx = (yyvsp[(23) - (24)].l);
;}
break;
case 507:
#line 5275 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_PRINT;
Operation_P->Case.Print.Expressions = NULL;
Operation_P->DefineSystemIndex = -1;
;}
break;
case 509:
#line 5284 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_WRITE;
Operation_P->Case.Print.Expressions = NULL;
Operation_P->DefineSystemIndex = -1;
;}
break;
case 511:
#line 5293 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_CHANGEOFCOORDINATES;
Operation_P->Case.ChangeOfCoordinates.GroupIndex =
Num_Group(&Group_S, (char*)"OP_ChgCoord", (yyvsp[(3) - (7)].i));
Operation_P->Case.ChangeOfCoordinates.ExpressionIndex = (yyvsp[(5) - (7)].i);
Operation_P->Case.ChangeOfCoordinates.ExpressionIndex2 = -1;
;}
break;
case 512:
#line 5304 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_CHANGEOFCOORDINATES;
Operation_P->Case.ChangeOfCoordinates.GroupIndex =
Num_Group(&Group_S, (char*)"OP_ChgCoord", (yyvsp[(3) - (11)].i));
Operation_P->Case.ChangeOfCoordinates.ExpressionIndex = (yyvsp[(5) - (11)].i);
Operation_P->Case.ChangeOfCoordinates.NumNode = (int)(yyvsp[(7) - (11)].d);
Operation_P->Case.ChangeOfCoordinates.ExpressionIndex2 = (yyvsp[(9) - (11)].i);
;}
break;
case 513:
#line 5316 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_POSTOPERATION;
Operation_P->Case.PostOperation.PostOperations =
List_Create(1,1,sizeof(char*));
List_Add(Operation_P->Case.PostOperation.PostOperations, &(yyvsp[(3) - (5)].c));
;}
break;
case 514:
#line 5326 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SYSTEMCOMMAND;
Operation_P->Case.SystemCommand.String = (yyvsp[(3) - (5)].c);
;}
break;
case 515:
#line 5334 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_ERROR;
Operation_P->Case.Error.String = (yyvsp[(3) - (5)].c);
;}
break;
case 516:
#line 5342 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = (yyvsp[(1) - (5)].i);
Operation_P->Case.GmshRead.FileName = strSave(Fix_RelativePath((yyvsp[(3) - (5)].c)).c_str());
Operation_P->Case.GmshRead.ViewTag = -1;
Free((yyvsp[(3) - (5)].c));
;}
break;
case 517:
#line 5352 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = (yyvsp[(1) - (7)].i);
Operation_P->Case.GmshRead.FileName = strSave(Fix_RelativePath((yyvsp[(3) - (7)].c)).c_str());
Operation_P->Case.GmshRead.ViewTag = (int)(yyvsp[(5) - (7)].d);
Free((yyvsp[(3) - (7)].c));
;}
break;
case 518:
#line 5362 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_GMSHCLEARALL;
;}
break;
case 519:
#line 5369 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_GMSHCLEARALL;
;}
break;
case 520:
#line 5376 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_DELETEFILE;
Operation_P->Case.DeleteFile.FileName = strSave(Fix_RelativePath((yyvsp[(3) - (5)].c)).c_str());
Free((yyvsp[(3) - (5)].c));
;}
break;
case 521:
#line 5385 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_RENAMEFILE;
Operation_P->Case.RenameFile.OldFileName = strSave(Fix_RelativePath((yyvsp[(3) - (7)].c)).c_str());
Operation_P->Case.RenameFile.NewFileName = strSave(Fix_RelativePath((yyvsp[(5) - (7)].c)).c_str());
Free((yyvsp[(3) - (7)].c));
Free((yyvsp[(5) - (7)].c));
;}
break;
case 522:
#line 5396 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_CREATEDIR;
Operation_P->Case.CreateDir.DirName = strSave(Fix_RelativePath((yyvsp[(3) - (5)].c)).c_str());
Free((yyvsp[(3) - (5)].c));
;}
break;
case 523:
#line 5405 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SOLVEJACADAPTRELAX;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (9)].c));
Free((yyvsp[(3) - (9)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.SolveJac_AdaptRelax.CheckAll = (int)(yyvsp[(7) - (9)].d);
Operation_P->Case.SolveJac_AdaptRelax.Factor_L = (yyvsp[(5) - (9)].l);
;}
break;
case 524:
#line 5419 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SAVESOLUTION_WITH_ENTITY_NUM;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (5)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (5)].c));
Free((yyvsp[(3) - (5)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.SaveSolutionWithEntityNum.GroupIndex = -1;
Operation_P->Case.SaveSolutionWithEntityNum.SaveFixed = -1;
;}
break;
case 525:
#line 5433 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SAVESOLUTION_WITH_ENTITY_NUM;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (8)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (8)].c));
Free((yyvsp[(3) - (8)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.SaveSolutionWithEntityNum.GroupIndex =
Num_Group(&Group_S, (char*)"OP_SaveSolutionWithEntityNum", (yyvsp[(5) - (8)].i));
Operation_P->Case.SaveSolutionWithEntityNum.SaveFixed = ((yyvsp[(6) - (8)].i) >= 0) ? (yyvsp[(6) - (8)].i) : 0;
;}
break;
case 526:
#line 5448 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SAVESOLUTIONEXTENDEDMH;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (9)].c));
Free((yyvsp[(3) - (9)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.SaveSolutionExtendedMH.NbrFreq = (int)(yyvsp[(5) - (9)].d);
Operation_P->Case.SaveSolutionExtendedMH.ResFile = (yyvsp[(7) - (9)].c);
;}
break;
case 527:
#line 5462 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SAVESOLUTIONMHTOTIME;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (9)].c));
Free((yyvsp[(3) - (9)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.SaveSolutionMHtoTime.Time = (yyvsp[(5) - (9)].l);
Operation_P->Case.SaveSolutionMHtoTime.ResFile = (yyvsp[(7) - (9)].c);
;}
break;
case 528:
#line 5476 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Problem_S.Group, (yyvsp[(3) - (5)].c), fcmp_Group_Name)) < 0)
vyyerror(0, "Unknown Group: %s", (yyvsp[(3) - (5)].c));
Operation_P->Type = OPERATION_INIT_MOVINGBAND2D;
Operation_P->Case.Init_MovingBand2D.GroupIndex = i;
Free((yyvsp[(3) - (5)].c));
;}
break;
case 529:
#line 5487 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Problem_S.Group, (yyvsp[(3) - (5)].c), fcmp_Group_Name)) < 0)
vyyerror(0, "Unknown Group: %s", (yyvsp[(3) - (5)].c));
Operation_P->Type = OPERATION_MESH_MOVINGBAND2D;
Operation_P->Case.Mesh_MovingBand2D.GroupIndex = i;
Free((yyvsp[(3) - (5)].c));
;}
break;
case 530:
#line 5498 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (11)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (11)].c));
Free((yyvsp[(3) - (11)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.SaveMesh.GroupIndex = Num_Group(&Group_S, (char*)"OP_SaveMesh", (yyvsp[(5) - (11)].i));
Operation_P->Case.SaveMesh.FileName = (yyvsp[(7) - (11)].c);
Operation_P->Case.SaveMesh.ExprIndex = (yyvsp[(9) - (11)].i);
Operation_P->Type = OPERATION_SAVEMESH;
;}
break;
case 531:
#line 5513 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (9)].c));
Free((yyvsp[(3) - (9)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.SaveMesh.GroupIndex = Num_Group(&Group_S, (char*)"OP_SaveMesh", (yyvsp[(5) - (9)].i));
Operation_P->Case.SaveMesh.FileName = (yyvsp[(7) - (9)].c);
Operation_P->Case.SaveMesh.ExprIndex = -1;
Operation_P->Type = OPERATION_SAVEMESH;
;}
break;
case 532:
#line 5529 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (13)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (13)].c));
Free((yyvsp[(3) - (13)].c));
Operation_P->DefineSystemIndex = i;
if((i = List_ISearchSeq(Problem_S.Group, (yyvsp[(5) - (13)].c), fcmp_Group_Name)) < 0)
vyyerror(0, "Unknown Group: %s", (yyvsp[(5) - (13)].c));
Free((yyvsp[(5) - (13)].c));
Operation_P->Type = OPERATION_GENERATE_MH_MOVING;
Operation_P->Case.Generate_MH_Moving.GroupIndex = i;
Operation_P->Case.Generate_MH_Moving.Period = (yyvsp[(7) - (13)].d);
Operation_P->Case.Generate_MH_Moving.NbrStep = (int)(yyvsp[(9) - (13)].d);
Operation_P->Case.Generate_MH_Moving.Operation = (yyvsp[(12) - (13)].l);
;}
break;
case 533:
#line 5549 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (13)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (13)].c));
Free((yyvsp[(3) - (13)].c));
Operation_P->DefineSystemIndex = i;
if((i = List_ISearchSeq(Problem_S.Group, (yyvsp[(5) - (13)].c), fcmp_Group_Name)) < 0)
vyyerror(0, "Unknown Group: %s", (yyvsp[(5) - (13)].c));
Free((yyvsp[(5) - (13)].c));
Operation_P->Type = OPERATION_GENERATE_MH_MOVING_S;
Operation_P->Case.Generate_MH_Moving_S.GroupIndex = i;
Operation_P->Case.Generate_MH_Moving_S.Period = (yyvsp[(7) - (13)].d);
Operation_P->Case.Generate_MH_Moving_S.NbrStep = (int)(yyvsp[(9) - (13)].d);
Operation_P->Case.Generate_MH_Moving_S.Operation = (yyvsp[(12) - (13)].l);
;}
break;
case 534:
#line 5568 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (5)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (5)].c));
Free((yyvsp[(3) - (5)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Type = OPERATION_ADDMHMOVING;
;}
break;
case 535:
#line 5581 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (14)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (14)].c));
Free((yyvsp[(3) - (14)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.DeformeMesh.Quantity = (yyvsp[(5) - (14)].c);
Operation_P->Case.DeformeMesh.Name_MshFile = (yyvsp[(8) - (14)].c);
Operation_P->Case.DeformeMesh.GeoDataIndex = -1;
Operation_P->Case.DeformeMesh.Factor = (yyvsp[(10) - (14)].d);
Operation_P->Case.DeformeMesh.GroupIndex =
Num_Group(&Group_S, (char*)"OP_DeformMesh", (yyvsp[(12) - (14)].i));
Operation_P->Type = OPERATION_DEFORMEMESH;
;}
break;
case 536:
#line 5600 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (12)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (12)].c));
Free((yyvsp[(3) - (12)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.DeformeMesh.Quantity = (yyvsp[(5) - (12)].c);
Operation_P->Case.DeformeMesh.Name_MshFile = (yyvsp[(8) - (12)].c);
Operation_P->Case.DeformeMesh.GeoDataIndex = -1;
Operation_P->Case.DeformeMesh.Factor = (yyvsp[(10) - (12)].d);
Operation_P->Case.DeformeMesh.GroupIndex = -1;
Operation_P->Type = OPERATION_DEFORMEMESH;
;}
break;
case 537:
#line 5617 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (10)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (10)].c));
Free((yyvsp[(3) - (10)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.DeformeMesh.Quantity = (yyvsp[(5) - (10)].c);
Operation_P->Case.DeformeMesh.Name_MshFile = (yyvsp[(8) - (10)].c);
Operation_P->Case.DeformeMesh.GeoDataIndex = -1;
Operation_P->Case.DeformeMesh.Factor = 1;
Operation_P->Case.DeformeMesh.GroupIndex = -1;
Operation_P->Type = OPERATION_DEFORMEMESH;
;}
break;
case 538:
#line 5634 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c));
Free((yyvsp[(3) - (7)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.DeformeMesh.Quantity = (yyvsp[(5) - (7)].c);
Operation_P->Case.DeformeMesh.Name_MshFile = NULL;
Operation_P->Case.DeformeMesh.GeoDataIndex = -1;
Operation_P->Case.DeformeMesh.Factor = 1;
Operation_P->Case.DeformeMesh.GroupIndex = -1;
Operation_P->Type = OPERATION_DEFORMEMESH;
;}
break;
case 539:
#line 5651 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (9)].c));
Free((yyvsp[(3) - (9)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.DeformeMesh.Quantity = (yyvsp[(5) - (9)].c);
Operation_P->Case.DeformeMesh.Name_MshFile = NULL;
Operation_P->Case.DeformeMesh.GeoDataIndex = -1;
Operation_P->Case.DeformeMesh.Factor = (yyvsp[(7) - (9)].d);
Operation_P->Case.DeformeMesh.GroupIndex = -1;
Operation_P->Type = OPERATION_DEFORMEMESH;
;}
break;
case 540:
#line 5668 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (11)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (11)].c));
Free((yyvsp[(3) - (11)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.DeformeMesh.Quantity = (yyvsp[(5) - (11)].c);
Operation_P->Case.DeformeMesh.Name_MshFile = NULL;
Operation_P->Case.DeformeMesh.GeoDataIndex = -1;
Operation_P->Case.DeformeMesh.Factor = (yyvsp[(7) - (11)].d);
Operation_P->Case.DeformeMesh.GroupIndex =
Num_Group(&Group_S, (char*)"OP_DeformMesh", (yyvsp[(9) - (11)].i));
Operation_P->Type = OPERATION_DEFORMEMESH;
;}
break;
case 541:
#line 5686 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c));
Free((yyvsp[(3) - (7)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Type = (yyvsp[(1) - (7)].i);
Operation_P->Case.Generate.GroupIndex =
Num_Group(&Group_S, (char*)"OP_GenerateGroup", (yyvsp[(5) - (7)].i));
;}
break;
case 542:
#line 5700 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SOLVEAGAINWITHOTHER;
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c));
Free((yyvsp[(3) - (7)].c));
Operation_P->DefineSystemIndex = i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(5) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(5) - (7)].c));
Free((yyvsp[(5) - (7)].c));
Operation_P->Case.SolveAgainWithOther.DefineSystemIndex = i;
;}
break;
case 543:
#line 5717 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = OPERATION_SETGLOBALSOLVEROPTIONS;
Operation_P->Case.SetGlobalSolverOptions.String = (yyvsp[(3) - (5)].c);
;}
break;
case 544:
#line 5724 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1) ;
Operation_P->Type = (yyvsp[(1) - (7)].i);
int i;
if ((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (7)].c)) ;
Free((yyvsp[(3) - (7)].c)) ;
Operation_P->DefineSystemIndex = i ;
Operation_P->Case.Copy.useList = 0 ;
Operation_P->Case.Copy.to = (yyvsp[(5) - (7)].c) ;
Operation_P->Case.Copy.from = 0 ;
;}
break;
case 545:
#line 5739 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1) ;
Operation_P->Type = (yyvsp[(1) - (9)].i);
int i;
if ((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (9)].c)) ;
Free((yyvsp[(3) - (9)].c)) ;
Operation_P->DefineSystemIndex = i ;
Operation_P->Case.Copy.useList = 1 ;
Operation_P->Case.Copy.to = (yyvsp[(5) - (9)].c) ;
Operation_P->Case.Copy.from = 0 ;
;}
break;
case 546:
#line 5754 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1) ;
Operation_P->Type = (yyvsp[(1) - (7)].i);
int i;
if ((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(5) - (7)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(5) - (7)].c)) ;
Free((yyvsp[(5) - (7)].c)) ;
Operation_P->DefineSystemIndex = i ;
Operation_P->Case.Copy.useList = 0 ;
Operation_P->Case.Copy.to = 0 ;
Operation_P->Case.Copy.from = (yyvsp[(3) - (7)].c) ;
;}
break;
case 547:
#line 5769 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1) ;
Operation_P->Type = (yyvsp[(1) - (9)].i);
int i;
if ((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(7) - (9)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(7) - (9)].c)) ;
Free((yyvsp[(7) - (9)].c)) ;
Operation_P->DefineSystemIndex = i ;
Operation_P->Case.Copy.useList = 1 ;
Operation_P->Case.Copy.to = 0 ;
Operation_P->Case.Copy.from = (yyvsp[(3) - (9)].c) ;
;}
break;
case 548:
#line 5784 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Type = NONE;
;}
break;
case 549:
#line 5793 "ProParser.y"
{
Operation_P->Case.Print.Expressions = List_Copy(ListOfInt_L);
Operation_P->Case.Print.FormatString = NULL;
;}
break;
case 550:
#line 5799 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(1) - (1)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(1) - (1)].c));
Free((yyvsp[(1) - (1)].c));
Operation_P->DefineSystemIndex = i;
Operation_P->Case.Print.FormatString = NULL;
;}
break;
case 551:
#line 5810 "ProParser.y"
{
Operation_P->Case.Print.Expressions = List_Create(1,1,sizeof(int));
Operation_P->Case.Print.FormatString = (yyvsp[(1) - (1)].c);
;}
break;
case 552:
#line 5818 "ProParser.y"
{
Operation_P->Case.Print.FileOut = NULL;
Operation_P->Case.Print.TimeStep = NULL;
Operation_P->Case.Print.DofNumber = NULL;
;}
break;
case 554:
#line 5828 "ProParser.y"
{ Operation_P->Case.Print.FileOut = (yyvsp[(3) - (3)].c); ;}
break;
case 555:
#line 5831 "ProParser.y"
{ Operation_P->Case.Print.TimeStep =
List_Create(List_Nbr((yyvsp[(3) - (3)].l)), 1, sizeof(int));
for(int i = 0; i < List_Nbr((yyvsp[(3) - (3)].l)); i++){
double d;
List_Read((yyvsp[(3) - (3)].l),i,&d);
int j = (int)d;
List_Add(Operation_P->Case.Print.TimeStep, &j);
}
List_Delete((yyvsp[(3) - (3)].l));
;}
break;
case 556:
#line 5843 "ProParser.y"
{
Operation_P->Case.Print.FormatString = (yyvsp[(3) - (3)].c);
;}
break;
case 557:
#line 5848 "ProParser.y"
{ Operation_P->Case.Print.DofNumber =
List_Create(List_Nbr((yyvsp[(2) - (2)].l)), 1, sizeof(int));
for(int i = 0; i < List_Nbr((yyvsp[(2) - (2)].l)); i++) {
double d;
List_Read((yyvsp[(2) - (2)].l), i, &d);
int j = (int)d;
List_Add(Operation_P->Case.Print.DofNumber, &j);
}
List_Delete((yyvsp[(2) - (2)].l));
;}
break;
case 558:
#line 5863 "ProParser.y"
{
Operation_P->Case.TimeLoopAdaptive.LTEtarget = -1.;
Operation_P->Case.TimeLoopAdaptive.DTimeMaxScal = -1.;
Operation_P->Case.TimeLoopAdaptive.DTimeScal_NotConverged = -1.;
;}
break;
case 559:
#line 5870 "ProParser.y"
{
Operation_P->Case.TimeLoopAdaptive.LTEtarget = (yyvsp[(2) - (2)].d);
Operation_P->Case.TimeLoopAdaptive.DTimeMaxScal = -1.;
Operation_P->Case.TimeLoopAdaptive.DTimeScal_NotConverged = -1.;
;}
break;
case 560:
#line 5877 "ProParser.y"
{
Operation_P->Case.TimeLoopAdaptive.LTEtarget = (yyvsp[(2) - (4)].d);
Operation_P->Case.TimeLoopAdaptive.DTimeMaxScal = (yyvsp[(4) - (4)].d);
Operation_P->Case.TimeLoopAdaptive.DTimeScal_NotConverged = -1.;
;}
break;
case 561:
#line 5884 "ProParser.y"
{
Operation_P->Case.TimeLoopAdaptive.LTEtarget = (yyvsp[(2) - (6)].d);
Operation_P->Case.TimeLoopAdaptive.DTimeMaxScal = (yyvsp[(4) - (6)].d);
Operation_P->Case.TimeLoopAdaptive.DTimeScal_NotConverged = (yyvsp[(6) - (6)].d);
;}
break;
case 562:
#line 5894 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopAdaptive.TimeLoopAdaptiveSystems_L = NULL;
Operation_P->Case.TimeLoopAdaptive.TimeLoopAdaptivePOs_L = NULL;
;}
break;
case 563:
#line 5902 "ProParser.y"
{
Operation_P->Case.TimeLoopAdaptive.TimeLoopAdaptiveSystems_L = (yyvsp[(4) - (5)].l);
;}
break;
case 564:
#line 5907 "ProParser.y"
{
Operation_P->Case.TimeLoopAdaptive.TimeLoopAdaptivePOs_L = (yyvsp[(4) - (5)].l);
;}
break;
case 565:
#line 5916 "ProParser.y"
{
(yyval.l) = List_Create(4, 4, sizeof(struct TimeLoopAdaptiveSystem));
;}
break;
case 566:
#line 5921 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (10)].c), fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (10)].c));
TimeLoopAdaptiveSystem_S.SystemIndex = i;
TimeLoopAdaptiveSystem_S.SystemLTEreltol = (yyvsp[(5) - (10)].d);
TimeLoopAdaptiveSystem_S.SystemLTEabstol = (yyvsp[(7) - (10)].d);
TimeLoopAdaptiveSystem_S.NormType = Get_DefineForString(ErrorNorm_Type, (yyvsp[(9) - (10)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(9) - (10)].c), ErrorNorm_Type);
vyyerror(0, "Unknown error norm type of TimeLoopAdaptive system %s", (yyvsp[(3) - (10)].c));
}
TimeLoopAdaptiveSystem_S.NormTypeString = (yyvsp[(9) - (10)].c);
List_Add((yyval.l) = (yyvsp[(1) - (10)].l), &TimeLoopAdaptiveSystem_S);
Free((yyvsp[(3) - (10)].c));
;}
break;
case 567:
#line 5941 "ProParser.y"
{
(yyval.l) = List_Create(4, 4, sizeof(struct LoopErrorPostOperation));
;}
break;
case 568:
#line 5946 "ProParser.y"
{
TimeLoopAdaptivePO_S.PostOperationName = (yyvsp[(3) - (10)].c);
TimeLoopAdaptivePO_S.PostOperationReltol = (yyvsp[(5) - (10)].d);
TimeLoopAdaptivePO_S.PostOperationAbstol = (yyvsp[(7) - (10)].d);
TimeLoopAdaptivePO_S.NormType = Get_DefineForString(ErrorNorm_Type, (yyvsp[(9) - (10)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(9) - (10)].c), ErrorNorm_Type);
vyyerror(0, "Unknown error norm type of TimeLoopAdaptive PostOperation %s", (yyvsp[(3) - (10)].c));
}
TimeLoopAdaptivePO_S.NormTypeString = (yyvsp[(9) - (10)].c);
List_Add((yyval.l) = (yyvsp[(1) - (10)].l), &TimeLoopAdaptivePO_S);
;}
break;
case 569:
#line 5962 "ProParser.y"
{
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeLoop.IterativeLoopSystems_L = NULL;
Operation_P->Case.IterativeLoop.IterativeLoopPOs_L = NULL;
;}
break;
case 570:
#line 5970 "ProParser.y"
{
Operation_P->Case.IterativeLoop.IterativeLoopSystems_L = (yyvsp[(4) - (5)].l);
;}
break;
case 571:
#line 5975 "ProParser.y"
{
Operation_P->Case.IterativeLoop.IterativeLoopPOs_L = (yyvsp[(4) - (5)].l);
;}
break;
case 572:
#line 5984 "ProParser.y"
{
(yyval.l) = List_Create(4, 4, sizeof(struct IterativeLoopSystem));
;}
break;
case 573:
#line 5989 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(3) - (11)].c), fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(3) - (11)].c));
IterativeLoopSystem_S.SystemIndex = i;
IterativeLoopSystem_S.SystemILreltol = (yyvsp[(5) - (11)].d);
IterativeLoopSystem_S.SystemILabstol = (yyvsp[(7) - (11)].d);
IterativeLoopSystem_S.NormOf = Get_DefineForString(NormOf_Type, (yyvsp[(9) - (11)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(3) - (11)].c), ChangeOfState_Type);
vyyerror(0, "Unknown object for error norm of IterativeLoop system: %s", (yyvsp[(3) - (11)].c));
}
IterativeLoopSystem_S.NormOfString = (yyvsp[(9) - (11)].c);
IterativeLoopSystem_S.NormType = Get_DefineForString(ErrorNorm_Type, (yyvsp[(10) - (11)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(10) - (11)].c), ErrorNorm_Type);
vyyerror(0, "Unknown error norm type of IterativeLoop system: %s", (yyvsp[(3) - (11)].c));
}
IterativeLoopSystem_S.NormTypeString = (yyvsp[(10) - (11)].c);
List_Add((yyval.l) = (yyvsp[(1) - (11)].l), &IterativeLoopSystem_S);
Free((yyvsp[(3) - (11)].c));
;}
break;
case 574:
#line 6016 "ProParser.y"
{
(yyval.l) = List_Create(4, 4, sizeof(struct LoopErrorPostOperation));
;}
break;
case 575:
#line 6021 "ProParser.y"
{
IterativeLoopPO_S.PostOperationName = (yyvsp[(3) - (10)].c);
IterativeLoopPO_S.PostOperationReltol = (yyvsp[(5) - (10)].d);
IterativeLoopPO_S.PostOperationAbstol = (yyvsp[(7) - (10)].d);
IterativeLoopPO_S.NormType = Get_DefineForString(ErrorNorm_Type, (yyvsp[(9) - (10)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(9) - (10)].c), ErrorNorm_Type);
vyyerror(0, "Unknown error norm type of IterativeLoopN PostOperation %s", (yyvsp[(3) - (10)].c));
}
IterativeLoopPO_S.NormTypeString = (yyvsp[(9) - (10)].c);
List_Add((yyval.l) = (yyvsp[(1) - (10)].l), &IterativeLoopPO_S);
;}
break;
case 576:
#line 6041 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopTheta.Time0 = 0.;
Operation_P->Case.TimeLoopTheta.TimeMax = 1.;
Operation_P->Case.TimeLoopTheta.DTimeIndex = -1;
Operation_P->Case.TimeLoopTheta.ThetaIndex = -1;
Operation_P->Case.TimeLoopTheta.Operation = NULL;
;}
break;
case 578:
#line 6057 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopTheta.Time0 = (yyvsp[(2) - (3)].d); ;}
break;
case 579:
#line 6061 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopTheta.TimeMax = (yyvsp[(2) - (3)].d); ;}
break;
case 580:
#line 6065 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopTheta.DTimeIndex = (yyvsp[(2) - (3)].i); ;}
break;
case 581:
#line 6069 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopTheta.ThetaIndex = (yyvsp[(2) - (3)].i); ;}
break;
case 582:
#line 6074 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopTheta.Operation = (yyvsp[(3) - (4)].l);
;}
break;
case 583:
#line 6085 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopNewmark.Time0 = 0.;
Operation_P->Case.TimeLoopNewmark.TimeMax = 1.;
Operation_P->Case.TimeLoopNewmark.DTimeIndex = -1;
Operation_P->Case.TimeLoopNewmark.Beta = 0.25;
Operation_P->Case.TimeLoopNewmark.Gamma = 0.5;
Operation_P->Case.TimeLoopNewmark.Operation = NULL;
;}
break;
case 585:
#line 6102 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopNewmark.Time0 = (yyvsp[(2) - (3)].d); ;}
break;
case 586:
#line 6106 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopNewmark.TimeMax = (yyvsp[(2) - (3)].d); ;}
break;
case 587:
#line 6110 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopNewmark.DTimeIndex = (yyvsp[(2) - (3)].i); ;}
break;
case 588:
#line 6114 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopNewmark.Beta = (yyvsp[(2) - (3)].d); ;}
break;
case 589:
#line 6118 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopNewmark.Gamma = (yyvsp[(2) - (3)].d); ;}
break;
case 590:
#line 6123 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.TimeLoopNewmark.Operation = (yyvsp[(3) - (4)].l);
;}
break;
case 591:
#line 6134 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeLoop.NbrMaxIteration = 20;
Operation_P->Case.IterativeLoop.Criterion = 1.e-3;
Operation_P->Case.IterativeLoop.RelaxationFactorIndex = -1;
Operation_P->Case.IterativeLoop.Flag = 0;
Operation_P->Case.IterativeLoop.Operation = NULL;
;}
break;
case 593:
#line 6149 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeLoop.NbrMaxIteration = (int)(yyvsp[(2) - (3)].d); ;}
break;
case 594:
#line 6153 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeLoop.Criterion = (yyvsp[(2) - (3)].d); ;}
break;
case 595:
#line 6157 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeLoop.RelaxationFactorIndex = (yyvsp[(2) - (3)].i); ;}
break;
case 596:
#line 6161 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeLoop.Flag = (int)(yyvsp[(2) - (3)].d); ;}
break;
case 597:
#line 6165 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeLoop.Operation = (yyvsp[(3) - (4)].l);
;}
break;
case 598:
#line 6176 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeTimeReduction.NbrMaxIteration = 20;
Operation_P->Case.IterativeTimeReduction.DivisionCoefficient = 2.;
Operation_P->Case.IterativeTimeReduction.Criterion = 1.e-3;
Operation_P->Case.IterativeTimeReduction.Flag = 0;
Current_System = Operation_P->DefineSystemIndex = -1;
Operation_P->Case.IterativeTimeReduction.ChangeOfState = NULL;
Operation_P->Case.IterativeTimeReduction.Operation = NULL;
Operation_P->Case.IterativeTimeReduction.OperationEnd = NULL;
;}
break;
case 600:
#line 6194 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeTimeReduction.NbrMaxIteration = (int)(yyvsp[(2) - (3)].d); ;}
break;
case 601:
#line 6198 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeTimeReduction.DivisionCoefficient = (yyvsp[(2) - (3)].d); ;}
break;
case 602:
#line 6202 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeTimeReduction.Criterion = (yyvsp[(2) - (3)].d); ;}
break;
case 603:
#line 6206 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeTimeReduction.Flag = (int)(yyvsp[(2) - (3)].d); ;}
break;
case 604:
#line 6211 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
int i;
if((i = List_ISearchSeq(Resolution_S.DefineSystem, (yyvsp[(2) - (3)].c),
fcmp_DefineSystem_Name)) < 0)
vyyerror(0, "Unknown System: %s", (yyvsp[(2) - (3)].c));
Free((yyvsp[(2) - (3)].c));
Current_System = Operation_P->DefineSystemIndex = i;
;}
break;
case 605:
#line 6222 "ProParser.y"
{ Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeTimeReduction.ChangeOfState = (yyvsp[(3) - (4)].l);
;}
break;
case 606:
#line 6228 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeTimeReduction.Operation = (yyvsp[(3) - (4)].l);
;}
break;
case 607:
#line 6234 "ProParser.y"
{ List_Pop(Operation_L);
Operation_P = (struct Operation*)
List_Pointer(Operation_L, List_Nbr(Operation_L)-1);
Operation_P->Case.IterativeTimeReduction.OperationEnd = (yyvsp[(3) - (4)].l);
;}
break;
case 608:
#line 6244 "ProParser.y"
{ (yyval.l) = List_Create(3, 3, sizeof (struct ChangeOfState)); ;}
break;
case 609:
#line 6247 "ProParser.y"
{ List_Add((yyval.l) = (yyvsp[(1) - (4)].l), &ChangeOfState_S); ;}
break;
case 610:
#line 6252 "ProParser.y"
{
ChangeOfState_S.Type = CHANGEOFSTATE_CHANGESIGN;
ChangeOfState_S.QuantityIndex = -1;
ChangeOfState_S.FormulationIndex = -1;
ChangeOfState_S.InIndex = -1;
ChangeOfState_S.Criterion = 1.e-2;
ChangeOfState_S.ExpressionIndex = ChangeOfState_S.ExpressionIndex2 = -1;
ChangeOfState_S.FlagIndex = -1;
ChangeOfState_S.ActiveList[0] = NULL;
ChangeOfState_S.ActiveList[1] = NULL;
;}
break;
case 612:
#line 6270 "ProParser.y"
{ ChangeOfState_S.Type =
Get_DefineForString(ChangeOfState_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), ChangeOfState_Type);
vyyerror(0, "Unknown type of ChangeOfState: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 613:
#line 6280 "ProParser.y"
{
if(Current_System >= 0) {
List_T *ListOfInt_Lnew =
((struct DefineSystem *)List_Pointer(Resolution_S.DefineSystem,
Current_System))->FormulationIndex;
int *ListOfInt_P =(int *)List_Pointer(ListOfInt_Lnew, 0);
int i = 0, j;
for(j = 0; j < List_Nbr(ListOfInt_Lnew); j++) {
Formulation_S.DefineQuantity =
((struct Formulation *)
List_Pointer(Problem_S.Formulation, ListOfInt_P[j]))->DefineQuantity;
if((i = List_ISearchSeq(Formulation_S.DefineQuantity, (yyvsp[(2) - (3)].c),
fcmp_DefineQuantity_Name)) >= 0)
break;
}
if(j<List_Nbr(ListOfInt_Lnew)) {
ChangeOfState_S.FormulationIndex = ListOfInt_P[j];
ChangeOfState_S.QuantityIndex = i;
}
else
vyyerror(0, "Unknown discrete Quantity: %s", (yyvsp[(2) - (3)].c));
}
else
vyyerror(0, "System undefined for Quantity: %s", (yyvsp[(2) - (3)].c));
Free((yyvsp[(2) - (3)].c));
;}
break;
case 614:
#line 6308 "ProParser.y"
{ ChangeOfState_S.InIndex = Num_Group(&Group_S, (char*)"OP_In", (yyvsp[(2) - (3)].i)); ;}
break;
case 615:
#line 6311 "ProParser.y"
{ ChangeOfState_S.Criterion = (yyvsp[(2) - (3)].d); ;}
break;
case 616:
#line 6314 "ProParser.y"
{
if(ChangeOfState_S.ExpressionIndex < 0)
ChangeOfState_S.ExpressionIndex = (yyvsp[(2) - (3)].i);
else
ChangeOfState_S.ExpressionIndex2 = (yyvsp[(2) - (3)].i);
;}
break;
case 617:
#line 6322 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.Expression, (yyvsp[(2) - (3)].c), fcmp_Expression_Name)) < 0)
vyyerror(0, "Unknown name of expression for Flag: %s", (yyvsp[(2) - (3)].c));
Free((yyvsp[(2) - (3)].c));
ChangeOfState_S.FlagIndex = i;
;}
break;
case 618:
#line 6340 "ProParser.y"
{
if(!Problem_S.PostProcessing)
Problem_S.PostProcessing =
List_Create(10, 5, sizeof (struct PostProcessing));
;}
break;
case 620:
#line 6352 "ProParser.y"
{
if (level_Append && index_Append>=0)
List_Write(Problem_S.PostProcessing, index_Append, &PostProcessing_S);
else
List_Add(Problem_S.PostProcessing, &PostProcessing_S);
;}
break;
case 622:
#line 6364 "ProParser.y"
{
PostProcessing_S.Name = NULL;
PostProcessing_S.FormulationIndex = -1;
PostProcessing_S.OriginSystemIndex = NULL;
PostProcessing_S.NameOfSystem = NULL;
PostProcessing_S.PostQuantity = NULL;
level_Append = 0;
;}
break;
case 625:
#line 6380 "ProParser.y"
{ level_Append = (yyvsp[(1) - (2)].i); index_Append = -1; ;}
break;
case 626:
#line 6383 "ProParser.y"
{
index_Append =
Check_NameOfStructExist("PostProcessing", Problem_S.PostProcessing,
(yyvsp[(2) - (3)].c), fcmp_PostProcessing_Name, level_Append);
if (index_Append<0)
PostProcessing_S.Name = (yyvsp[(2) - (3)].c);
else{
List_Read(Problem_S.PostProcessing, index_Append, &PostProcessing_S);
Free((yyvsp[(2) - (3)].c));
}
;}
break;
case 627:
#line 6396 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.Formulation, (yyvsp[(2) - (3)].c),
fcmp_Formulation_Name)) < 0){
vyyerror(0, "Unknown Formulation: %s", (yyvsp[(2) - (3)].c));
}
else {
PostProcessing_S.FormulationIndex = i;
List_Read(Problem_S.Formulation, i, &Formulation_S);
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 628:
#line 6410 "ProParser.y"
{
PostProcessing_S.NameOfSystem = (yyvsp[(2) - (3)].c);
;}
break;
case 630:
#line 6420 "ProParser.y"
{
if (!PostProcessing_S.PostQuantity)
PostProcessing_S.PostQuantity =
List_Create(6, 6, sizeof (struct PostQuantity));
;}
break;
case 631:
#line 6427 "ProParser.y"
{
if (level_Append_2 && index_Append_2>=0)
List_Write(PostProcessing_S.PostQuantity, index_Append_2, &PostQuantity_S);
else
List_Add(PostProcessing_S.PostQuantity, &PostQuantity_S);
;}
break;
case 633:
#line 6439 "ProParser.y"
{
PostQuantity_S.Name = NULL;
PostQuantity_S.PostQuantityTerm = NULL;
level_Append_2 = (level_Append)? level_Append-1 : 0;
index_Append_2 = -1;
;}
break;
case 635:
#line 6452 "ProParser.y"
{
level_Append_2 = (yyvsp[(1) - (2)].i); index_Append_2 = -1;
;}
break;
case 636:
#line 6457 "ProParser.y"
{
index_Append_2 =
Check_NameOfStructExist("PostQuantity", PostProcessing_S.PostQuantity,
(yyvsp[(2) - (3)].c), fcmp_PostQuantity_Name, level_Append_2);
if (index_Append_2<0)
PostQuantity_S.Name = (yyvsp[(2) - (3)].c);
else{
List_Read(PostProcessing_S.PostQuantity, index_Append_2, &PostQuantity_S);
Free((yyvsp[(2) - (3)].c));
}
;}
break;
case 637:
#line 6470 "ProParser.y"
{ PostQuantity_S.PostQuantityTerm = (yyvsp[(3) - (4)].l); ;}
break;
case 638:
#line 6476 "ProParser.y"
{
(yyval.l) = PostQuantity_S.PostQuantityTerm?
PostQuantity_S.PostQuantityTerm :
List_Create(5, 5, sizeof (struct PostQuantityTerm));
if (level_Append_2 < 0)
for(int i=0; i<-level_Append_2; i++)
List_Pop(PostQuantity_S.PostQuantityTerm);
//+++ TODO: to be refined for clean delete of existing data
;}
break;
case 639:
#line 6489 "ProParser.y"
{
PostQuantityTerm_S.EvaluationType = INTEGRAL;
List_Add((yyval.l) = (yyvsp[(1) - (5)].l), &PostQuantityTerm_S);
;}
break;
case 640:
#line 6495 "ProParser.y"
{
PostQuantityTerm_S.EvaluationType =
Get_DefineForString(PostQuantityTerm_EvaluationType, (yyvsp[(2) - (5)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (5)].c), PostQuantityTerm_EvaluationType);
vyyerror(0, "Unknown EvaluationType for PostQuantityTerm: %s", (yyvsp[(2) - (5)].c));
}
Free((yyvsp[(2) - (5)].c));
List_Add((yyval.l) = (yyvsp[(1) - (5)].l), &PostQuantityTerm_S);
;}
break;
case 641:
#line 6507 "ProParser.y"
{ (yyval.l) = (yyvsp[(1) - (2)].l) ; ;}
break;
case 642:
#line 6512 "ProParser.y"
{
PostQuantityTerm_S.Type = 0;
PostQuantityTerm_S.TypeTimeDerivative = NODT_;
PostQuantityTerm_S.WholeQuantity = NULL;
PostQuantityTerm_S.InIndex = -1;
PostQuantityTerm_S.SubRegion = -1;
PostQuantityTerm_S.JacobianMethodIndex = -1;
PostQuantityTerm_S.IntegrationMethodIndex = -1;
;}
break;
case 644:
#line 6527 "ProParser.y"
{
PostQuantityTerm_S.TypeTimeDerivative = Type_TermOperator;
Current_DofIndexInWholeQuantity = -2;
List_Reset(ListOfPointer_L);
;}
break;
case 645:
#line 6534 "ProParser.y"
{ PostQuantityTerm_S.WholeQuantity = (yyvsp[(4) - (6)].l);
Pro_DefineQuantityIndex
(PostQuantityTerm_S.WholeQuantity, -1,
&PostQuantityTerm_S.NbrQuantityIndex,
&PostQuantityTerm_S.QuantityIndexTable,
&PostQuantityTerm_S.QuantityTraceGroupIndexTable);
if(!PostQuantityTerm_S.Type) {
PostQuantityTerm_S.Type = 0;
for(int i = 0; i < PostQuantityTerm_S.NbrQuantityIndex; i++) {
int j = -1;
if(PostQuantityTerm_S.QuantityIndexTable[i] >= 0)
j = ((struct DefineQuantity *)
List_Pointer
(((struct Formulation *)
List_Pointer(Problem_S.Formulation,
PostProcessing_S.FormulationIndex))->DefineQuantity,
PostQuantityTerm_S.QuantityIndexTable[i])) -> Type;
if(PostQuantityTerm_S.Type == 0)
PostQuantityTerm_S.Type = j;
else if(PostQuantityTerm_S.Type != j)
vyyerror(0, "Mixed discrete Quantity types in term (should be split in separate terms)");
}
if(PostQuantityTerm_S.Type == 0) PostQuantityTerm_S.Type = LOCALQUANTITY;
}
;}
break;
case 646:
#line 6563 "ProParser.y"
{ /* force the Type */
PostQuantityTerm_S.Type =
Get_DefineForString(DefineQuantity_Type, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), DefineQuantity_Type);
vyyerror(0, "Unknown type of Operation: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 647:
#line 6574 "ProParser.y"
{
PostQuantityTerm_S.InIndex = Num_Group(&Group_S, (char*)"PQ_In", (yyvsp[(2) - (3)].i));
;}
break;
case 648:
#line 6579 "ProParser.y"
{
PostQuantityTerm_S.SubRegion = Num_Group(&Group_S, (char*)"PQ_SR", (yyvsp[(2) - (3)].i));
;}
break;
case 649:
#line 6584 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.JacobianMethod, (yyvsp[(2) - (3)].c),
fcmp_JacobianMethod_Name)) < 0)
vyyerror(0, "Unknown Jacobian method: %s",(yyvsp[(2) - (3)].c));
else
PostQuantityTerm_S.JacobianMethodIndex = i;
Free((yyvsp[(2) - (3)].c));
;}
break;
case 650:
#line 6595 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.IntegrationMethod, (yyvsp[(2) - (3)].c),
fcmp_IntegrationMethod_Name)) < 0)
vyyerror(0, "Unknown Integration method: %s",(yyvsp[(2) - (3)].c));
else
PostQuantityTerm_S.IntegrationMethodIndex = i;
Free((yyvsp[(2) - (3)].c));
;}
break;
case 651:
#line 6614 "ProParser.y"
{
if(!Problem_S.PostOperation)
Problem_S.PostOperation =
List_Create(10, 5, sizeof (struct PostOperation));
;}
break;
case 653:
#line 6626 "ProParser.y"
{
if (level_Append && index_Append>=0)
List_Write(Problem_S.PostOperation, index_Append, &PostOperation_S);
else
List_Add(Problem_S.PostOperation, &PostOperation_S);
;}
break;
case 655:
#line 6638 "ProParser.y"
{
PostOperation_S.Name = NULL;
PostOperation_S.Hidden = false;
PostOperation_S.Format = FORMAT_GMSH;
PostOperation_S.PostProcessingIndex = -1;
PostOperation_S.ResampleTime = false;
PostOperation_S.TimeValue_L = NULL;
PostOperation_S.TimeImagValue_L = NULL;
PostOperation_S.LastTimeStepOnly = 0;
PostOperation_S.OverrideTimeStepValue = -1;
PostOperation_S.NoMesh = 0;
PostOperation_S.CatFile = 0;
PostOperation_S.PostSubOperation = NULL;
level_Append = 0;
;}
break;
case 657:
#line 6659 "ProParser.y"
{ level_Append = (yyvsp[(1) - (2)].i); index_Append = -1; ;}
break;
case 658:
#line 6662 "ProParser.y"
{
index_Append =
Check_NameOfStructExist("PostOperation", Problem_S.PostOperation,
(yyvsp[(2) - (3)].c), fcmp_PostOperation_Name, level_Append);
if (index_Append<0)
PostOperation_S.Name = (yyvsp[(2) - (3)].c);
else{
List_Read(Problem_S.PostOperation, index_Append, &PostOperation_S);
Free((yyvsp[(2) - (3)].c));
}
;}
break;
case 659:
#line 6674 "ProParser.y"
{ PostOperation_S.Hidden = (yyvsp[(2) - (3)].d) ? true : false; ;}
break;
case 660:
#line 6677 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(Problem_S.PostProcessing, (yyvsp[(2) - (3)].c),
fcmp_PostProcessing_Name)) < 0)
vyyerror(0, "Unknown PostProcessing: %s", (yyvsp[(2) - (3)].c));
else {
PostOperation_S.PostProcessingIndex = i;
List_Read(Problem_S.PostProcessing, i, &InteractivePostProcessing_S);
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 661:
#line 6690 "ProParser.y"
{
PostOperation_S.Format =
Get_DefineForString(PostSubOperation_Format, (yyvsp[(2) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(2) - (3)].c), PostSubOperation_Format);
vyyerror(0, "Unknown PostProcessing Format: %s", (yyvsp[(2) - (3)].c));
}
Free((yyvsp[(2) - (3)].c));
;}
break;
case 662:
#line 6701 "ProParser.y"
{
PostOperation_S.TimeValue_L = (yyvsp[(2) - (3)].l);
;}
break;
case 663:
#line 6706 "ProParser.y"
{
PostOperation_S.TimeImagValue_L = (yyvsp[(2) - (3)].l);
;}
break;
case 664:
#line 6711 "ProParser.y"
{
PostOperation_S.LastTimeStepOnly = 1;
;}
break;
case 665:
#line 6716 "ProParser.y"
{
PostOperation_S.LastTimeStepOnly = (int)(yyvsp[(2) - (3)].d);
;}
break;
case 666:
#line 6721 "ProParser.y"
{
PostOperation_S.CatFile = (yyvsp[(2) - (3)].d);
;}
break;
case 667:
#line 6726 "ProParser.y"
{
PostOperation_S.NoMesh = (yyvsp[(2) - (3)].d);
;}
break;
case 668:
#line 6731 "ProParser.y"
{
PostOperation_S.OverrideTimeStepValue = (yyvsp[(2) - (3)].d);
;}
break;
case 669:
#line 6736 "ProParser.y"
{
PostOperation_S.ResampleTime = true;
PostOperation_S.ResampleTimeStart = (yyvsp[(3) - (9)].d);
PostOperation_S.ResampleTimeStop = (yyvsp[(5) - (9)].d);
PostOperation_S.ResampleTimeStep = (yyvsp[(7) - (9)].d);
;}
break;
case 670:
#line 6744 "ProParser.y"
{
PostOperation_S.PostSubOperation = (yyvsp[(3) - (4)].l);
;}
break;
case 672:
#line 6754 "ProParser.y"
{
PostOperation_S.Hidden = false;
PostOperation_S.Format = FORMAT_GMSH;
PostOperation_S.PostProcessingIndex = -1;
PostOperation_S.ResampleTime = false;
PostOperation_S.TimeValue_L = NULL;
PostOperation_S.TimeImagValue_L = NULL;
PostOperation_S.LastTimeStepOnly = 0;
PostOperation_S.OverrideTimeStepValue = -1;
PostOperation_S.NoMesh = 0;
PostOperation_S.CatFile = 0;
PostOperation_S.PostSubOperation = NULL;
level_Append = (yyvsp[(2) - (5)].i); index_Append = -1;
int i;
if((i = List_ISearchSeq(Problem_S.PostProcessing, (yyvsp[(5) - (5)].c),
fcmp_PostProcessing_Name)) < 0)
vyyerror(0, "Unknown PostProcessing: %s", (yyvsp[(5) - (5)].c));
else {
PostOperation_S.PostProcessingIndex = i;
List_Read(Problem_S.PostProcessing, i, &InteractivePostProcessing_S);
if(!Problem_S.PostOperation)
Problem_S.PostOperation = List_Create(5, 5, sizeof (struct PostOperation));
index_Append =
Check_NameOfStructExist("PostOperation", Problem_S.PostOperation,
(yyvsp[(3) - (5)].c), fcmp_PostOperation_Name, level_Append);
if (index_Append<0)
PostOperation_S.Name = (yyvsp[(3) - (5)].c);
else{
List_Read(Problem_S.PostOperation, index_Append, &PostOperation_S);
Free((yyvsp[(3) - (5)].c));
}
}
Free((yyvsp[(5) - (5)].c));
;}
break;
case 673:
#line 6790 "ProParser.y"
{
if(!PostOperation_S.PostSubOperation) PostOperation_S.PostSubOperation = (yyvsp[(8) - (9)].l);
if(PostOperation_S.PostProcessingIndex >= 0){
if (level_Append && index_Append>=0)
List_Write(Problem_S.PostOperation, index_Append, &PostOperation_S);
else
List_Add(Problem_S.PostOperation, &PostOperation_S);
}
;}
break;
case 674:
#line 6804 "ProParser.y"
{
(yyval.l) =
PostOperation_S.PostSubOperation?
PostOperation_S.PostSubOperation :
List_Create(5, 5, sizeof (struct PostSubOperation));
;}
break;
case 675:
#line 6812 "ProParser.y"
{
PostSubOperation_S.Format = -1;
PostSubOperation_S.FileOut = NULL;
PostSubOperation_S.Depth = 1;
PostSubOperation_S.Smoothing = 0;
PostSubOperation_S.Skin = 0;
PostSubOperation_S.Comma = 0;
PostSubOperation_S.Dimension = _ALL;
PostSubOperation_S.Adapt = 0;
PostSubOperation_S.Target = -1.;
PostSubOperation_S.HarmonicToTime = 1;
PostSubOperation_S.TimeToHarmonic = 0;
PostSubOperation_S.FourierTransform = 0;
PostSubOperation_S.FrozenTimeStepList = 0;
PostSubOperation_S.TimeStep_L = List_Create(10,10,sizeof(int));;
PostSubOperation_S.Frequency_L = List_Create(10,10,sizeof(double));;
PostSubOperation_S.Value_L = List_Create(10,10,sizeof(double));;
PostSubOperation_S.Iso = 0;
PostSubOperation_S.Iso_L = List_Create(10,10,sizeof(double));;
PostSubOperation_S.Sort = 0;
PostSubOperation_S.NoNewLine = 0;
PostSubOperation_S.NoTitle = 0;
PostSubOperation_S.DecomposeInSimplex = 0;
PostSubOperation_S.NewCoordinates = 0;
PostSubOperation_S.NewCoordinatesFile = NULL;
PostSubOperation_S.ChangeOfCoordinates[0] = -1;
PostSubOperation_S.ChangeOfCoordinates[1] = -1;
PostSubOperation_S.ChangeOfCoordinates[2] = -1;
PostSubOperation_S.ChangeOfValues = NULL;
PostSubOperation_S.Legend = LEGEND_NONE;
PostSubOperation_S.LegendPosition[0] = 0.;
PostSubOperation_S.LegendPosition[1] = 0.;
PostSubOperation_S.LegendPosition[2] = 0.;
PostSubOperation_S.EvaluationPoints = NULL;
PostSubOperation_S.StoreInVariable = NULL;
PostSubOperation_S.StoreInRegister = -1;
PostSubOperation_S.StoreMinInRegister = -1;
PostSubOperation_S.StoreMinXinRegister = -1;
PostSubOperation_S.StoreMinYinRegister = -1;
PostSubOperation_S.StoreMinZinRegister = -1;
PostSubOperation_S.StoreMaxInRegister = -1;
PostSubOperation_S.StoreMaxXinRegister = -1;
PostSubOperation_S.StoreMaxYinRegister = -1;
PostSubOperation_S.StoreMaxZinRegister = -1;
PostSubOperation_S.StoreInField = -1;
PostSubOperation_S.StoreInMeshBasedField = -1;
PostSubOperation_S.LastTimeStepOnly = 0;
PostSubOperation_S.AppendTimeStepToFileName = 0;
PostSubOperation_S.AppendExpressionToFileName = -1;
PostSubOperation_S.AppendExpressionFormat = NULL;
PostSubOperation_S.AppendStringToFileName = NULL;
PostSubOperation_S.OverrideTimeStepValue = -1;
PostSubOperation_S.NoMesh = 0;
PostSubOperation_S.CatFile = 0;
PostSubOperation_S.SendToServer = NULL;
PostSubOperation_S.SendToServerList = NULL;
PostSubOperation_S.Color = NULL;
PostSubOperation_S.Units = NULL;
PostSubOperation_S.ValueIndex = 0;
PostSubOperation_S.ValueName = NULL;
PostSubOperation_S.Label = NULL;
PostSubOperation_S.TimeValue_L = NULL;
PostSubOperation_S.TimeImagValue_L = NULL;
PostSubOperation_S.TimeInterval_Flag = 0;
PostSubOperation_S.TimeInterval[0] = 0.;
PostSubOperation_S.TimeInterval[1] = 0.;
;}
break;
case 676:
#line 6880 "ProParser.y"
{
if(PostSubOperation_S.Type != POP_NONE) {
if(PostSubOperation_S.Format < 0)
PostSubOperation_S.Format = PostOperation_S.Format;
if(!PostSubOperation_S.TimeValue_L)
PostSubOperation_S.TimeValue_L = PostOperation_S.TimeValue_L;
if(!PostSubOperation_S.TimeImagValue_L)
PostSubOperation_S.TimeImagValue_L = PostOperation_S.TimeImagValue_L;
if(!PostSubOperation_S.LastTimeStepOnly)
PostSubOperation_S.LastTimeStepOnly = PostOperation_S.LastTimeStepOnly;
if(!PostSubOperation_S.NoMesh)
PostSubOperation_S.NoMesh = PostOperation_S.NoMesh;
if(PostSubOperation_S.OverrideTimeStepValue < 0)
PostSubOperation_S.OverrideTimeStepValue = PostOperation_S.OverrideTimeStepValue;
if(!PostSubOperation_S.CatFile)
PostSubOperation_S.CatFile = PostOperation_S.CatFile;
List_Add((yyval.l) = (yyvsp[(1) - (3)].l), &PostSubOperation_S);
}
;}
break;
case 677:
#line 6906 "ProParser.y"
{
vyyerror(0, "Plot has been superseded by Print "
"(Plot OnRegion becomes Print OnElementsOf)");
;}
break;
case 678:
#line 6912 "ProParser.y"
{
PostSubOperation_S.Type = POP_PRINT;
;}
break;
case 679:
#line 6917 "ProParser.y"
{
PostSubOperation_S.Type = POP_EXPRESSION;
PostSubOperation_S.Case.Expression.String = (yyvsp[(3) - (8)].c);
PostSubOperation_S.Case.Expression.String2 = NULL;
PostSubOperation_S.Case.Expression.ExpressionIndex = (yyvsp[(5) - (8)].i);
PostSubOperation_S.PostQuantityIndex[0] = -1;
;}
break;
case 680:
#line 6926 "ProParser.y"
{
PostSubOperation_S.Type = POP_EXPRESSION;
PostSubOperation_S.Case.Expression.String = (yyvsp[(3) - (11)].c);
PostSubOperation_S.Case.Expression.String2 = (yyvsp[(7) - (11)].c);
PostSubOperation_S.Case.Expression.ExpressionIndex = -1;
PostSubOperation_S.PostQuantityIndex[0] = -1;
;}
break;
case 681:
#line 6935 "ProParser.y"
{
PostSubOperation_S.Type = POP_EXPRESSION;
PostSubOperation_S.Case.Expression.String = (yyvsp[(3) - (6)].c);
PostSubOperation_S.Case.Expression.String2 = NULL;
PostSubOperation_S.Case.Expression.ExpressionIndex = -1;
PostSubOperation_S.PostQuantityIndex[0] = -1;
;}
break;
case 682:
#line 6944 "ProParser.y"
{
PostSubOperation_S.Type = POP_GROUP;
PostSubOperation_S.Case.Group.ExtendedGroupIndex =
Num_Group(&Group_S, (char*)"PO_Group", (yyvsp[(3) - (3)].i));
PostSubOperation_S.PostQuantityIndex[0] = -1;
;}
break;
case 683:
#line 6951 "ProParser.y"
{
PostSubOperation_S.Case.Group.GroupIndex =
Num_Group(&Group_S, (char*)"PO_Group", (yyvsp[(7) - (10)].i));
;}
break;
case 684:
#line 6957 "ProParser.y"
{
PostSubOperation_S.Type = POP_MERGE;
PostSubOperation_S.FileOut = (yyvsp[(3) - (5)].c);
;}
break;
case 685:
#line 6963 "ProParser.y"
{
PostSubOperation_S.Type = POP_NONE;
;}
break;
case 686:
#line 6972 "ProParser.y"
{
int i;
if((i = List_ISearchSeq(InteractivePostProcessing_S.PostQuantity, (yyvsp[(1) - (3)].c),
fcmp_PostQuantity_Name)) < 0)
vyyerror(0, "Unknown PostProcessing Quantity: %s", (yyvsp[(1) - (3)].c));
PostSubOperation_S.PostQuantityIndex[0] = i;
PostSubOperation_S.PostQuantityIndex[1] = -1;
PostSubOperation_S.PostQuantitySupport[0] = (yyvsp[(2) - (3)].i);
PostSubOperation_S.PostQuantitySupport[1] = -1;
Free((yyvsp[(1) - (3)].c));
;}
break;
case 687:
#line 6985 "ProParser.y"
{
vyyerror(1, "Combined post-quantities are deprecated: use registers instead");
int i;
if((i = List_ISearchSeq(InteractivePostProcessing_S.PostQuantity, (yyvsp[(1) - (6)].c),
fcmp_PostQuantity_Name)) < 0)
vyyerror(0, "Unknown PostProcessing Quantity: %s", (yyvsp[(1) - (6)].c));
PostSubOperation_S.PostQuantityIndex[0] = i;
PostSubOperation_S.PostQuantitySupport[0] = (yyvsp[(2) - (6)].i);
int j = -1;
if((j = List_ISearchSeq(InteractivePostProcessing_S.PostQuantity, (yyvsp[(4) - (6)].c),
fcmp_PostQuantity_Name)) < 0)
vyyerror(0, "Unknown PostProcessing Quantity: %s", (yyvsp[(4) - (6)].c));
PostSubOperation_S.PostQuantityIndex[1] = j;
PostSubOperation_S.PostQuantitySupport[1] = (yyvsp[(5) - (6)].i);
if(((yyvsp[(2) - (6)].i) < 0 && (yyvsp[(5) - (6)].i) < 0) || ((yyvsp[(2) - (6)].i) >= 0 && (yyvsp[(5) - (6)].i) >= 0)) {
vyyerror(0, "Postprocessing Quantities '%s' and '%s' of same type (%s)",
(yyvsp[(1) - (6)].c), (yyvsp[(4) - (6)].c), ((yyvsp[(2) - (6)].i)>0)? "with Support":"without Support");
}
Free((yyvsp[(1) - (6)].c)); Free((yyvsp[(4) - (6)].c));
;}
break;
case 688:
#line 7010 "ProParser.y"
{ PostSubOperation_S.CombinationType = MULTIPLICATION; ;}
break;
case 689:
#line 7011 "ProParser.y"
{ PostSubOperation_S.CombinationType = DIVISION; ;}
break;
case 690:
#line 7012 "ProParser.y"
{ PostSubOperation_S.CombinationType = ADDITION; ;}
break;
case 691:
#line 7013 "ProParser.y"
{ PostSubOperation_S.CombinationType = SOUSTRACTION; ;}
break;
case 692:
#line 7019 "ProParser.y"
{ (yyval.i) = -1; ;}
break;
case 693:
#line 7021 "ProParser.y"
{ (yyval.i) = Num_Group(&Group_S, (char*)"PO_Support", (yyvsp[(2) - (3)].i)); ;}
break;
case 694:
#line 7027 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_ONREGION;
PostSubOperation_S.Case.OnRegion.RegionIndex = -1;
;}
break;
case 695:
#line 7033 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_ONREGION;
PostSubOperation_S.Case.OnRegion.RegionIndex =
Num_Group(&Group_S, (char*)"PO_OnRegion", (yyvsp[(2) - (2)].i));
;}
break;
case 696:
#line 7040 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_ONELEMENTSOF;
PostSubOperation_S.Case.OnRegion.RegionIndex =
Num_Group(&Group_S, (char*)"PO_OnElementsOf", (yyvsp[(2) - (2)].i));
;}
break;
case 697:
#line 7049 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_ONSECTION_2D;
if(List_Nbr((yyvsp[(4) - (12)].l)) != 3 || List_Nbr((yyvsp[(7) - (12)].l)) != 3 || List_Nbr((yyvsp[(10) - (12)].l)) != 3)
vyyerror(0, "Expected {3}{3}{3} coordinates, got {%d}{%d}{%d}",
List_Nbr((yyvsp[(4) - (12)].l)), List_Nbr((yyvsp[(7) - (12)].l)), List_Nbr((yyvsp[(10) - (12)].l)));
else{
List_Read((yyvsp[(4) - (12)].l), 0, &PostSubOperation_S.Case.OnSection.x[0]);
List_Read((yyvsp[(4) - (12)].l), 1, &PostSubOperation_S.Case.OnSection.y[0]);
List_Read((yyvsp[(4) - (12)].l), 2, &PostSubOperation_S.Case.OnSection.z[0]);
List_Read((yyvsp[(7) - (12)].l), 0, &PostSubOperation_S.Case.OnSection.x[1]);
List_Read((yyvsp[(7) - (12)].l), 1, &PostSubOperation_S.Case.OnSection.y[1]);
List_Read((yyvsp[(7) - (12)].l), 2, &PostSubOperation_S.Case.OnSection.z[1]);
List_Read((yyvsp[(10) - (12)].l), 0, &PostSubOperation_S.Case.OnSection.x[2]);
List_Read((yyvsp[(10) - (12)].l), 1, &PostSubOperation_S.Case.OnSection.y[2]);
List_Read((yyvsp[(10) - (12)].l), 2, &PostSubOperation_S.Case.OnSection.z[2]);
}
List_Delete((yyvsp[(4) - (12)].l));
List_Delete((yyvsp[(7) - (12)].l));
List_Delete((yyvsp[(10) - (12)].l));
;}
break;
case 698:
#line 7071 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_ONGRID;
PostSubOperation_S.Case.OnRegion.RegionIndex =
Num_Group(&Group_S, (char*)"PO_OnGrid", (yyvsp[(2) - (2)].i));
;}
break;
case 699:
#line 7079 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_ONGRID_PARAM;
PostSubOperation_S.Case.OnParamGrid.ExpressionIndex[0] = (yyvsp[(3) - (15)].i);
PostSubOperation_S.Case.OnParamGrid.ExpressionIndex[1] = (yyvsp[(5) - (15)].i);
PostSubOperation_S.Case.OnParamGrid.ExpressionIndex[2] = (yyvsp[(7) - (15)].i);
PostSubOperation_S.Case.OnParamGrid.ParameterValue[0] = (yyvsp[(10) - (15)].l);
PostSubOperation_S.Case.OnParamGrid.ParameterValue[1] = (yyvsp[(12) - (15)].l);
PostSubOperation_S.Case.OnParamGrid.ParameterValue[2] = (yyvsp[(14) - (15)].l);
;}
break;
case 700:
#line 7090 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_ONGRID_0D;
if(List_Nbr((yyvsp[(3) - (4)].l)) != 3)
vyyerror(0, "Expected {3} coordinates, got {%d}", List_Nbr((yyvsp[(3) - (4)].l)));
else{
List_Read((yyvsp[(3) - (4)].l), 0, &PostSubOperation_S.Case.OnGrid.x[0]);
List_Read((yyvsp[(3) - (4)].l), 1, &PostSubOperation_S.Case.OnGrid.y[0]);
List_Read((yyvsp[(3) - (4)].l), 2, &PostSubOperation_S.Case.OnGrid.z[0]);
}
List_Delete((yyvsp[(3) - (4)].l));
;}
break;
case 701:
#line 7104 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_ONGRID_1D;
if(List_Nbr((yyvsp[(4) - (12)].l)) != 3 || List_Nbr((yyvsp[(7) - (12)].l)) != 3)
vyyerror(0, "Expected {3}{3} coordinates, got {%d}{%d}",
List_Nbr((yyvsp[(4) - (12)].l)), List_Nbr((yyvsp[(7) - (12)].l)));
else{
List_Read((yyvsp[(4) - (12)].l), 0, &PostSubOperation_S.Case.OnGrid.x[0]);
List_Read((yyvsp[(4) - (12)].l), 1, &PostSubOperation_S.Case.OnGrid.y[0]);
List_Read((yyvsp[(4) - (12)].l), 2, &PostSubOperation_S.Case.OnGrid.z[0]);
List_Read((yyvsp[(7) - (12)].l), 0, &PostSubOperation_S.Case.OnGrid.x[1]);
List_Read((yyvsp[(7) - (12)].l), 1, &PostSubOperation_S.Case.OnGrid.y[1]);
List_Read((yyvsp[(7) - (12)].l), 2, &PostSubOperation_S.Case.OnGrid.z[1]);
}
PostSubOperation_S.Case.OnGrid.n[0] = (int)(yyvsp[(11) - (12)].d);
List_Delete((yyvsp[(4) - (12)].l));
List_Delete((yyvsp[(7) - (12)].l));
;}
break;
case 702:
#line 7125 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_ONGRID_2D;
if(List_Nbr((yyvsp[(4) - (17)].l)) != 3 || List_Nbr((yyvsp[(7) - (17)].l)) != 3 || List_Nbr((yyvsp[(10) - (17)].l)) != 3)
vyyerror(0, "Expected {3}{3}{3} coordinates, got {%d}{%d}{%d}",
List_Nbr((yyvsp[(4) - (17)].l)), List_Nbr((yyvsp[(7) - (17)].l)), List_Nbr((yyvsp[(10) - (17)].l)));
else{
List_Read((yyvsp[(4) - (17)].l), 0, &PostSubOperation_S.Case.OnGrid.x[0]);
List_Read((yyvsp[(4) - (17)].l), 1, &PostSubOperation_S.Case.OnGrid.y[0]);
List_Read((yyvsp[(4) - (17)].l), 2, &PostSubOperation_S.Case.OnGrid.z[0]);
List_Read((yyvsp[(7) - (17)].l), 0, &PostSubOperation_S.Case.OnGrid.x[1]);
List_Read((yyvsp[(7) - (17)].l), 1, &PostSubOperation_S.Case.OnGrid.y[1]);
List_Read((yyvsp[(7) - (17)].l), 2, &PostSubOperation_S.Case.OnGrid.z[1]);
List_Read((yyvsp[(10) - (17)].l), 0, &PostSubOperation_S.Case.OnGrid.x[2]);
List_Read((yyvsp[(10) - (17)].l), 1, &PostSubOperation_S.Case.OnGrid.y[2]);
List_Read((yyvsp[(10) - (17)].l), 2, &PostSubOperation_S.Case.OnGrid.z[2]);
}
PostSubOperation_S.Case.OnGrid.n[0] = (int)(yyvsp[(14) - (17)].d);
PostSubOperation_S.Case.OnGrid.n[1] = (int)(yyvsp[(16) - (17)].d);
List_Delete((yyvsp[(4) - (17)].l));
List_Delete((yyvsp[(7) - (17)].l));
List_Delete((yyvsp[(10) - (17)].l));
;}
break;
case 703:
#line 7152 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_ONGRID_3D;
if(List_Nbr((yyvsp[(4) - (22)].l)) != 3 || List_Nbr((yyvsp[(7) - (22)].l)) != 3 ||
List_Nbr((yyvsp[(10) - (22)].l)) != 3 || List_Nbr((yyvsp[(13) - (22)].l)) != 3)
vyyerror(0, "Expected {3}{3}{3}{3} coordinates, got {%d}{%d}{%d}{%d}",
List_Nbr((yyvsp[(4) - (22)].l)), List_Nbr((yyvsp[(7) - (22)].l)), List_Nbr((yyvsp[(10) - (22)].l)), List_Nbr((yyvsp[(13) - (22)].l)));
else{
List_Read((yyvsp[(4) - (22)].l), 0, &PostSubOperation_S.Case.OnGrid.x[0]);
List_Read((yyvsp[(4) - (22)].l), 1, &PostSubOperation_S.Case.OnGrid.y[0]);
List_Read((yyvsp[(4) - (22)].l), 2, &PostSubOperation_S.Case.OnGrid.z[0]);
List_Read((yyvsp[(7) - (22)].l), 0, &PostSubOperation_S.Case.OnGrid.x[1]);
List_Read((yyvsp[(7) - (22)].l), 1, &PostSubOperation_S.Case.OnGrid.y[1]);
List_Read((yyvsp[(7) - (22)].l), 2, &PostSubOperation_S.Case.OnGrid.z[1]);
List_Read((yyvsp[(10) - (22)].l), 0, &PostSubOperation_S.Case.OnGrid.x[2]);
List_Read((yyvsp[(10) - (22)].l), 1, &PostSubOperation_S.Case.OnGrid.y[2]);
List_Read((yyvsp[(10) - (22)].l), 2, &PostSubOperation_S.Case.OnGrid.z[2]);
List_Read((yyvsp[(13) - (22)].l), 0, &PostSubOperation_S.Case.OnGrid.x[3]);
List_Read((yyvsp[(13) - (22)].l), 1, &PostSubOperation_S.Case.OnGrid.y[3]);
List_Read((yyvsp[(13) - (22)].l), 2, &PostSubOperation_S.Case.OnGrid.z[3]);
}
PostSubOperation_S.Case.OnGrid.n[0] = (int)(yyvsp[(17) - (22)].d);
PostSubOperation_S.Case.OnGrid.n[1] = (int)(yyvsp[(19) - (22)].d);
PostSubOperation_S.Case.OnGrid.n[2] = (int)(yyvsp[(21) - (22)].d);
List_Delete((yyvsp[(4) - (22)].l));
List_Delete((yyvsp[(7) - (22)].l));
List_Delete((yyvsp[(10) - (22)].l));
List_Delete((yyvsp[(13) - (22)].l));
;}
break;
case 704:
#line 7184 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_WITHARGUMENT;
PostSubOperation_S.Case.WithArgument.RegionIndex =
Num_Group(&Group_S, (char*)"PO_On", (yyvsp[(2) - (12)].i));
int i;
if((i = List_ISearchSeq(Problem_S.Expression, (yyvsp[(4) - (12)].c), fcmp_Expression_Name)) < 0)
vyyerror(0, "Unknown Name of Expression: %s", (yyvsp[(4) - (12)].c));
Free((yyvsp[(4) - (12)].c));
PostSubOperation_S.Case.WithArgument.ArgumentIndex = i;
PostSubOperation_S.Case.WithArgument.x[0] = (yyvsp[(6) - (12)].d);
PostSubOperation_S.Case.WithArgument.x[1] = (yyvsp[(8) - (12)].d);
PostSubOperation_S.Case.WithArgument.n = (int)(yyvsp[(11) - (12)].d);
;}
break;
case 705:
#line 7204 "ProParser.y"
{
PostSubOperation_S.SubType = PRINT_WITHARGUMENT;
PostSubOperation_S.Case.WithArgument.RegionIndex =
Num_Group(&Group_S, (char*)"PO_On", (yyvsp[(2) - (7)].i));
int i;
if((i = List_ISearchSeq(Problem_S.Expression, (yyvsp[(4) - (7)].c), fcmp_Expression_Name)) < 0)
vyyerror(0, "Unknown Name of Expression: %s", (yyvsp[(4) - (7)].c));
Free((yyvsp[(4) - (7)].c));
PostSubOperation_S.Case.WithArgument.ArgumentIndex = i;
PostSubOperation_S.Case.WithArgument.x[0] = (yyvsp[(6) - (7)].d);
PostSubOperation_S.Case.WithArgument.x[1] = (yyvsp[(6) - (7)].d);
PostSubOperation_S.Case.WithArgument.n = 0;
;}
break;
case 706:
#line 7224 "ProParser.y"
{
;}
break;
case 708:
#line 7231 "ProParser.y"
{
PostSubOperation_S.FileOut = (yyvsp[(3) - (3)].c);
PostSubOperation_S.CatFile = 0;
;}
break;
case 709:
#line 7236 "ProParser.y"
{
PostSubOperation_S.FileOut = (yyvsp[(4) - (4)].c);
PostSubOperation_S.CatFile = 1;
;}
break;
case 710:
#line 7241 "ProParser.y"
{
PostSubOperation_S.FileOut = (yyvsp[(4) - (4)].c);
PostSubOperation_S.CatFile = 2;
;}
break;
case 711:
#line 7246 "ProParser.y"
{
PostSubOperation_S.CatFile = (yyvsp[(3) - (3)].d);
;}
break;
case 712:
#line 7250 "ProParser.y"
{
PostSubOperation_S.Depth = (int)(yyvsp[(3) - (3)].d);
;}
break;
case 713:
#line 7254 "ProParser.y"
{
PostSubOperation_S.Skin = 1;
;}
break;
case 714:
#line 7258 "ProParser.y"
{
PostSubOperation_S.Smoothing = 1;
;}
break;
case 715:
#line 7262 "ProParser.y"
{
PostSubOperation_S.Smoothing = (int)(yyvsp[(3) - (3)].d);
;}
break;
case 716:
#line 7266 "ProParser.y"
{
PostSubOperation_S.HarmonicToTime = (int)(yyvsp[(3) - (3)].d);
;}
break;
case 717:
#line 7270 "ProParser.y"
{
PostSubOperation_S.TimeToHarmonic = (int)(yyvsp[(3) - (3)].d);
;}
break;
case 718:
#line 7274 "ProParser.y"
{
PostSubOperation_S.FourierTransform = 2;
;}
break;
case 719:
#line 7278 "ProParser.y"
{
PostSubOperation_S.FourierTransform = 1;
;}
break;
case 720:
#line 7282 "ProParser.y"
{
PostSubOperation_S.Format =
Get_DefineForString(PostSubOperation_Format, (yyvsp[(3) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(3) - (3)].c), PostSubOperation_Format);
vyyerror(0, "Unknown PostProcessing Format: %s", (yyvsp[(3) - (3)].c));
}
Free((yyvsp[(3) - (3)].c));
;}
break;
case 721:
#line 7292 "ProParser.y"
{
PostSubOperation_S.Comma = 1;
;}
break;
case 722:
#line 7296 "ProParser.y"
{
PostSubOperation_S.ValueIndex = (yyvsp[(3) - (3)].d);
;}
break;
case 723:
#line 7300 "ProParser.y"
{
PostSubOperation_S.ValueName = (yyvsp[(3) - (3)].c);
;}
break;
case 724:
#line 7304 "ProParser.y"
{
PostSubOperation_S.Label = (yyvsp[(3) - (3)].c);
;}
break;
case 725:
#line 7308 "ProParser.y"
{
if((int)(yyvsp[(3) - (3)].d) >= 1 && (int)(yyvsp[(3) - (3)].d) <= 3)
PostSubOperation_S.Dimension = (int)(yyvsp[(3) - (3)].d);
else
vyyerror(0, "Wrong Dimension in Print");
;}
break;
case 726:
#line 7315 "ProParser.y"
{
PostSubOperation_S.FrozenTimeStepList = 1;
for(int i = 0; i < List_Nbr((yyvsp[(3) - (3)].l)); i++){
double d;
List_Read((yyvsp[(3) - (3)].l),i,&d);
int j = (int)d;
List_Add(PostSubOperation_S.TimeStep_L, &j);
}
List_Delete((yyvsp[(3) - (3)].l));
;}
break;
case 727:
#line 7326 "ProParser.y"
{
PostSubOperation_S.TimeValue_L = (yyvsp[(3) - (3)].l);
;}
break;
case 728:
#line 7330 "ProParser.y"
{
PostSubOperation_S.TimeInterval_Flag = 1;
PostSubOperation_S.TimeInterval[0] = (yyvsp[(4) - (7)].d);
PostSubOperation_S.TimeInterval[1] = (yyvsp[(6) - (7)].d);
;}
break;
case 729:
#line 7336 "ProParser.y"
{
PostSubOperation_S.TimeImagValue_L = (yyvsp[(3) - (3)].l);
;}
break;
case 730:
#line 7340 "ProParser.y"
{
PostSubOperation_S.Adapt =
Get_DefineForString(PostSubOperation_AdaptationType, (yyvsp[(3) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(3) - (3)].c), PostSubOperation_AdaptationType);
vyyerror(0, "Unknown Adaptation method: %s", (yyvsp[(3) - (3)].c));
}
;}
break;
case 731:
#line 7349 "ProParser.y"
{
PostSubOperation_S.Sort =
Get_DefineForString(PostSubOperation_SortType, (yyvsp[(3) - (3)].c), &FlagError);
if(FlagError){
Get_Valid_SXD((yyvsp[(3) - (3)].c), PostSubOperation_SortType);
vyyerror(0, "Unknown Sort method: %s", (yyvsp[(3) - (3)].c));
}
;}
break;
case 732:
#line 7358 "ProParser.y"
{
if((yyvsp[(3) - (3)].d) >= 0.)
PostSubOperation_S.Target = (yyvsp[(3) - (3)].d);
else
vyyerror(0, "Bad Target value");
;}
break;
case 733:
#line 7365 "ProParser.y"
{
for(int i = 0; i < List_Nbr((yyvsp[(3) - (3)].l)); i++){
double d;
List_Read((yyvsp[(3) - (3)].l),i,&d);
List_Add(PostSubOperation_S.Value_L, &d);
}
List_Delete((yyvsp[(3) - (3)].l));
;}
break;
case 734:
#line 7374 "ProParser.y"
{
PostSubOperation_S.Iso = (int)(yyvsp[(3) - (3)].d);
;}
break;
case 735:
#line 7378 "ProParser.y"
{
PostSubOperation_S.Iso = -1;
for(int i = 0; i < List_Nbr((yyvsp[(4) - (5)].l)); i++){
double d;
List_Read((yyvsp[(4) - (5)].l),i,&d);
List_Add(PostSubOperation_S.Iso_L, &d);
}
List_Delete((yyvsp[(4) - (5)].l));
;}
break;
case 736:
#line 7388 "ProParser.y"
{
PostSubOperation_S.NoNewLine = 1;
;}
break;
case 737:
#line 7392 "ProParser.y"
{
PostSubOperation_S.NoTitle = 1;
;}
break;
case 738:
#line 7396 "ProParser.y"
{
PostSubOperation_S.DecomposeInSimplex = 1;
;}
break;
case 739:
#line 7400 "ProParser.y"
{
for(int i = 0; i < List_Nbr((yyvsp[(3) - (3)].l)); i++){
double d;
List_Read((yyvsp[(3) - (3)].l),i,&d);
List_Add(PostSubOperation_S.Frequency_L, &d);
}
List_Delete((yyvsp[(3) - (3)].l));
;}
break;
case 740:
#line 7409 "ProParser.y"
{
PostSubOperation_S.ChangeOfCoordinates[0] = (yyvsp[(4) - (9)].i);
PostSubOperation_S.ChangeOfCoordinates[1] = (yyvsp[(6) - (9)].i);
PostSubOperation_S.ChangeOfCoordinates[2] = (yyvsp[(8) - (9)].i);
;}
break;
case 741:
#line 7415 "ProParser.y"
{
PostSubOperation_S.ChangeOfValues = List_Copy(ListOfInt_L);
;}
break;
case 742:
#line 7419 "ProParser.y"
{
PostSubOperation_S.Legend = LEGEND_TIME;
PostSubOperation_S.LegendPosition[0] = 1.e5;
PostSubOperation_S.LegendPosition[1] = 30.;
/* (align<<16)|(font<<8)|(fontsize) */
PostSubOperation_S.LegendPosition[2] = 66574;
;}
break;
case 743:
#line 7427 "ProParser.y"
{
PostSubOperation_S.Legend = LEGEND_TIME;
PostSubOperation_S.LegendPosition[0] = (yyvsp[(4) - (9)].d);
PostSubOperation_S.LegendPosition[1] = (yyvsp[(6) - (9)].d);
PostSubOperation_S.LegendPosition[2] = (yyvsp[(8) - (9)].d);
;}
break;
case 744:
#line 7434 "ProParser.y"
{
PostSubOperation_S.Legend = LEGEND_FREQUENCY;
PostSubOperation_S.LegendPosition[0] = 1.e5;
PostSubOperation_S.LegendPosition[1] = 30.;
/* (align<<16)|(font<<8)|(fontsize) */
PostSubOperation_S.LegendPosition[2] = 66574;
;}
break;
case 745:
#line 7442 "ProParser.y"
{
PostSubOperation_S.Legend = LEGEND_FREQUENCY;
PostSubOperation_S.LegendPosition[0] = (yyvsp[(4) - (9)].d);
PostSubOperation_S.LegendPosition[1] = (yyvsp[(6) - (9)].d);
PostSubOperation_S.LegendPosition[2] = (yyvsp[(8) - (9)].d);
;}
break;
case 746:
#line 7449 "ProParser.y"
{
PostSubOperation_S.Legend = LEGEND_EIGENVALUES;
PostSubOperation_S.LegendPosition[0] = 1.e5;
PostSubOperation_S.LegendPosition[1] = 30.;
/* (align<<16)|(font<<8)|(fontsize) */
PostSubOperation_S.LegendPosition[2] = 66574;
;}
break;
case 747:
#line 7457 "ProParser.y"
{
PostSubOperation_S.Legend = LEGEND_EIGENVALUES;
PostSubOperation_S.LegendPosition[0] = (yyvsp[(4) - (9)].d);
PostSubOperation_S.LegendPosition[1] = (yyvsp[(6) - (9)].d);
PostSubOperation_S.LegendPosition[2] = (yyvsp[(8) - (9)].d);
;}
break;
case 748:
#line 7464 "ProParser.y"
{
if(List_Nbr((yyvsp[(4) - (5)].l))%3 != 0)
vyyerror(0, "Expected 3n coordinates, got %d", List_Nbr((yyvsp[(4) - (5)].l)));
else {
PostSubOperation_S.EvaluationPoints = (yyvsp[(4) - (5)].l);
}
;}
break;
case 749:
#line 7472 "ProParser.y"
{
PostSubOperation_S.StoreInVariable = (yyvsp[(4) - (4)].c);
;}
break;
case 750:
#line 7476 "ProParser.y"
{
PostSubOperation_S.StoreInRegister = (int)(yyvsp[(3) - (3)].d) - 1;
;}
break;
case 751:
#line 7480 "ProParser.y"
{
PostSubOperation_S.StoreMinInRegister = (int)(yyvsp[(3) - (3)].d) - 1;
;}
break;
case 752:
#line 7484 "ProParser.y"
{
PostSubOperation_S.StoreMinXinRegister = (int)(yyvsp[(3) - (3)].d) - 1;
;}
break;
case 753:
#line 7488 "ProParser.y"
{
PostSubOperation_S.StoreMinYinRegister = (int)(yyvsp[(3) - (3)].d) - 1;
;}
break;
case 754:
#line 7492 "ProParser.y"
{
PostSubOperation_S.StoreMinZinRegister = (int)(yyvsp[(3) - (3)].d) - 1;
;}
break;
case 755:
#line 7496 "ProParser.y"
{
PostSubOperation_S.StoreMaxInRegister = (int)(yyvsp[(3) - (3)].d) - 1;
;}
break;
case 756:
#line 7500 "ProParser.y"
{
PostSubOperation_S.StoreMaxXinRegister = (int)(yyvsp[(3) - (3)].d) - 1;
;}
break;
case 757:
#line 7504 "ProParser.y"
{
PostSubOperation_S.StoreMaxYinRegister = (int)(yyvsp[(3) - (3)].d) - 1;
;}
break;
case 758:
#line 7508 "ProParser.y"
{
PostSubOperation_S.StoreMaxZinRegister = (int)(yyvsp[(3) - (3)].d) - 1;
;}
break;
case 759:
#line 7512 "ProParser.y"
{
PostSubOperation_S.StoreInField = (yyvsp[(3) - (3)].d);
;}
break;
case 760:
#line 7516 "ProParser.y"
{
PostSubOperation_S.StoreInMeshBasedField = (yyvsp[(3) - (3)].d);
;}
break;
case 761:
#line 7520 "ProParser.y"
{
PostSubOperation_S.LastTimeStepOnly = 1;
;}
break;
case 762:
#line 7524 "ProParser.y"
{
PostSubOperation_S.LastTimeStepOnly = (int)(yyvsp[(3) - (3)].d);
;}
break;
case 763:
#line 7528 "ProParser.y"
{
PostSubOperation_S.AppendTimeStepToFileName = 1;
;}
break;
case 764:
#line 7532 "ProParser.y"
{
PostSubOperation_S.AppendTimeStepToFileName = (int)(yyvsp[(3) - (3)].d);
;}
break;
case 765:
#line 7536 "ProParser.y"
{
PostSubOperation_S.AppendExpressionToFileName = (yyvsp[(3) - (3)].i);
;}
break;
case 766:
#line 7540 "ProParser.y"
{
PostSubOperation_S.AppendExpressionFormat = (yyvsp[(3) - (3)].c);
;}
break;
case 767:
#line 7544 "ProParser.y"
{
PostSubOperation_S.AppendStringToFileName = (yyvsp[(3) - (3)].c);
;}
break;
case 768:
#line 7548 "ProParser.y"
{
PostSubOperation_S.OverrideTimeStepValue = (yyvsp[(3) - (3)].d);
;}
break;
case 769:
#line 7552 "ProParser.y"
{
PostSubOperation_S.NoMesh = 1;
;}
break;
case 770:
#line 7556 "ProParser.y"
{
PostSubOperation_S.NoMesh = (yyvsp[(3) - (3)].d);
;}
break;
case 771:
#line 7560 "ProParser.y"
{
PostSubOperation_S.SendToServer = (yyvsp[(3) - (3)].c);
;}
break;
case 772:
#line 7564 "ProParser.y"
{
PostSubOperation_S.SendToServer = (yyvsp[(3) - (6)].c);
PostSubOperation_S.SendToServerList = (yyvsp[(5) - (6)].l);
;}
break;
case 773:
#line 7569 "ProParser.y"
{
std::string cat((yyvsp[(2) - (3)].c));
Free((yyvsp[(2) - (3)].c));
if(cat == "Units"){
PostSubOperation_S.Units = (yyvsp[(3) - (3)].c);
}
else if(cat == "Color"){
PostSubOperation_S.Color = (yyvsp[(3) - (3)].c);
}
else if(cat == "NewCoordinates"){
PostSubOperation_S.NewCoordinates = 1;
PostSubOperation_S.NewCoordinatesFile = (yyvsp[(3) - (3)].c);
}
;}
break;
case 774:
#line 7592 "ProParser.y"
{ (yyval.c) = (yyvsp[(1) - (1)].c); ;}
break;
case 775:
#line 7594 "ProParser.y"
{ (yyval.c) = (yyvsp[(1) - (1)].c); ;}
break;
case 776:
#line 7600 "ProParser.y"
{
LoopControlVariablesTab[ImbricatedLoop][0] = (yyvsp[(3) - (6)].d);
LoopControlVariablesTab[ImbricatedLoop][1] = (yyvsp[(5) - (6)].d);
LoopControlVariablesTab[ImbricatedLoop][2] = 1.0;
LoopControlVariablesNameTab[ImbricatedLoop] = (char*)"";
fgetpos(getdp_yyin, &FposImbricatedLoopsTab[ImbricatedLoop]);
LinenoImbricatedLoopsTab[ImbricatedLoop] = getdp_yylinenum;
if((yyvsp[(3) - (6)].d) > (yyvsp[(5) - (6)].d))
skipUntil("For", "EndFor");
else
ImbricatedLoop++;
if(ImbricatedLoop > MAX_RECUR_LOOPS-1){
vyyerror(0, "Reached maximum number of imbricated loops");
ImbricatedLoop = MAX_RECUR_LOOPS-1;
}
;}
break;
case 777:
#line 7617 "ProParser.y"
{
LoopControlVariablesTab[ImbricatedLoop][0] = (yyvsp[(3) - (8)].d);
LoopControlVariablesTab[ImbricatedLoop][1] = (yyvsp[(5) - (8)].d);
LoopControlVariablesTab[ImbricatedLoop][2] = (yyvsp[(7) - (8)].d);
LoopControlVariablesNameTab[ImbricatedLoop] = (char*)"";
fgetpos(getdp_yyin, &FposImbricatedLoopsTab[ImbricatedLoop]);
LinenoImbricatedLoopsTab[ImbricatedLoop] = getdp_yylinenum;
if(((yyvsp[(7) - (8)].d) > 0. && (yyvsp[(3) - (8)].d) > (yyvsp[(5) - (8)].d)) || ((yyvsp[(7) - (8)].d) < 0. && (yyvsp[(3) - (8)].d) < (yyvsp[(5) - (8)].d)))
skipUntil("For", "EndFor");
else
ImbricatedLoop++;
if(ImbricatedLoop > MAX_RECUR_LOOPS-1){
vyyerror(0, "Reached maximum number of imbricated loops");
ImbricatedLoop = MAX_RECUR_LOOPS-1;
}
;}
break;
case 778:
#line 7634 "ProParser.y"
{
LoopControlVariablesTab[ImbricatedLoop][0] = (yyvsp[(5) - (8)].d);
LoopControlVariablesTab[ImbricatedLoop][1] = (yyvsp[(7) - (8)].d);
LoopControlVariablesTab[ImbricatedLoop][2] = 1.0;
LoopControlVariablesNameTab[ImbricatedLoop] = (yyvsp[(2) - (8)].c);
Constant_S.Name = (yyvsp[(2) - (8)].c);
Constant_S.Type = VAR_FLOAT;
Constant_S.Value.Float = (yyvsp[(5) - (8)].d);
Tree_Replace(ConstantTable_L, &Constant_S);
fgetpos(getdp_yyin, &FposImbricatedLoopsTab[ImbricatedLoop]);
/* hack_fsetpos_printf(); */
LinenoImbricatedLoopsTab[ImbricatedLoop] = getdp_yylinenum;
if((yyvsp[(5) - (8)].d) > (yyvsp[(7) - (8)].d))
skipUntil("For", "EndFor");
else
ImbricatedLoop++;
if(ImbricatedLoop > MAX_RECUR_LOOPS-1){
vyyerror(0, "Reached maximum number of imbricated loops");
ImbricatedLoop = MAX_RECUR_LOOPS-1;
}
;}
break;
case 779:
#line 7656 "ProParser.y"
{
LoopControlVariablesTab[ImbricatedLoop][0] = (yyvsp[(5) - (10)].d);
LoopControlVariablesTab[ImbricatedLoop][1] = (yyvsp[(7) - (10)].d);
LoopControlVariablesTab[ImbricatedLoop][2] = (yyvsp[(9) - (10)].d);
LoopControlVariablesNameTab[ImbricatedLoop] = (yyvsp[(2) - (10)].c);
Constant_S.Name = (yyvsp[(2) - (10)].c);
Constant_S.Type = VAR_FLOAT;
Constant_S.Value.Float = (yyvsp[(5) - (10)].d);
Tree_Replace(ConstantTable_L, &Constant_S);
fgetpos(getdp_yyin, &FposImbricatedLoopsTab[ImbricatedLoop]);
LinenoImbricatedLoopsTab[ImbricatedLoop] = getdp_yylinenum;
if(((yyvsp[(9) - (10)].d) > 0. && (yyvsp[(5) - (10)].d) > (yyvsp[(7) - (10)].d)) || ((yyvsp[(9) - (10)].d) < 0. && (yyvsp[(5) - (10)].d) < (yyvsp[(7) - (10)].d)))
skipUntil("For", "EndFor");
else
ImbricatedLoop++;
if(ImbricatedLoop > MAX_RECUR_LOOPS-1){
vyyerror(0, "Reached maximum number of imbricated loops");
ImbricatedLoop = MAX_RECUR_LOOPS-1;
}
;}
break;
case 780:
#line 7677 "ProParser.y"
{
if(ImbricatedLoop <= 0){
vyyerror(0, "Invalid For/EndFor loop");
ImbricatedLoop = 0;
}
else{
double x0 = LoopControlVariablesTab[ImbricatedLoop-1][0];
double x1 = LoopControlVariablesTab[ImbricatedLoop-1][1];
double step = LoopControlVariablesTab[ImbricatedLoop-1][2];
int do_next = (step > 0.) ? (x0+step <= x1) : (x0+step >= x1);
if(do_next){
LoopControlVariablesTab[ImbricatedLoop-1][0] +=
LoopControlVariablesTab[ImbricatedLoop-1][2];
if(strlen(LoopControlVariablesNameTab[ImbricatedLoop-1])){
Constant_S.Name = LoopControlVariablesNameTab[ImbricatedLoop-1];
Constant_S.Type = VAR_FLOAT;
Constant_S.Value.Float = LoopControlVariablesTab[ImbricatedLoop-1][0];
if(!Tree_Search(ConstantTable_L, &Constant_S))
vyyerror(0, "Unknown For/EndFor loop control variable %s", Constant_S.Name);
Tree_Replace(ConstantTable_L, &Constant_S);
}
fsetpos(getdp_yyin, &FposImbricatedLoopsTab[ImbricatedLoop-1]);
/* fsetpos() seems to position the file just after the For
but with one additional character (the one after EndFor)
at the beginning. I do not understand why there is such
a mixing of two separate data. hack_fsetpos() removes the
useless additional character. */
hack_fsetpos();
/* hack_fsetpos_printf(); */
getdp_yylinenum = LinenoImbricatedLoopsTab[ImbricatedLoop-1];
}
else{
ImbricatedLoop--;
}
}
;}
break;
case 781:
#line 7714 "ProParser.y"
{
if(!MacroManager::Instance()->createMacro
(std::string((yyvsp[(2) - (2)].c)), getdp_yyin, getdp_yyname, getdp_yylinenum + 1))
vyyerror(0, "Redefinition of macro '%s'", (yyvsp[(2) - (2)].c));
skipUntil(NULL, "Return");
Free((yyvsp[(2) - (2)].c));
;}
break;
case 782:
#line 7722 "ProParser.y"
{
if(!MacroManager::Instance()->createMacro
(std::string((yyvsp[(2) - (2)].c)), getdp_yyin, getdp_yyname, getdp_yylinenum + 0))
vyyerror(0, "Redefinition of macro '%s'", (yyvsp[(2) - (2)].c));
skipUntil(NULL, "Return");
Free((yyvsp[(2) - (2)].c));
;}
break;
case 783:
#line 7730 "ProParser.y"
{
if(!MacroManager::Instance()->leaveMacro
(&getdp_yyin, getdp_yyname, getdp_yylinenum))
vyyerror(0, "Error while exiting macro");
;}
break;
case 784:
#line 7736 "ProParser.y"
{
if(!MacroManager::Instance()->enterMacro
(std::string((yyvsp[(2) - (3)].c)), &getdp_yyin, getdp_yyname, getdp_yylinenum))
vyyerror(0, "Unknown macro '%s'", (yyvsp[(2) - (3)].c));
Free((yyvsp[(2) - (3)].c));
;}
break;
case 785:
#line 7743 "ProParser.y"
{
if((yyvsp[(3) - (6)].d))
if(!MacroManager::Instance()->enterMacro
(std::string((yyvsp[(5) - (6)].c)), &getdp_yyin, getdp_yyname, getdp_yylinenum))
vyyerror(0, "Unknown macro '%s'", (yyvsp[(5) - (6)].c));
Free((yyvsp[(5) - (6)].c));
;}
break;
case 786:
#line 7751 "ProParser.y"
{
ImbricatedTest++;
if(ImbricatedTest > MAX_RECUR_TESTS-1){
vyyerror(0, "Reached maximum number of imbricated tests");
ImbricatedTest = MAX_RECUR_TESTS-1;
}
if((yyvsp[(3) - (4)].d)){
// Current test is true
statusImbricatedTests[ImbricatedTest] = 1;
}
else{
statusImbricatedTests[ImbricatedTest] = 0;
// Go after the next ElseIf or Else or EndIf
int type_until2 = 0;
skipUntil_test("If", "EndIf", "ElseIf", 4, &type_until2);
if(!type_until2) ImbricatedTest--; // EndIf reached
}
;}
break;
case 787:
#line 7771 "ProParser.y"
{
if(ImbricatedTest > 0){
if (statusImbricatedTests[ImbricatedTest]){
// Last test (If or ElseIf) was true, thus go after EndIf (out of If EndIf)
skipUntil("If", "EndIf");
ImbricatedTest--;
}
else{
// Previous test(s) (If and ElseIf) not yet true
if((yyvsp[(3) - (4)].d)){
statusImbricatedTests[ImbricatedTest] = 1;
}
else{
// Current test still not true: statusImbricatedTests[ImbricatedTest] = 0;
// Go after the next ElseIf or Else or EndIf
int type_until2 = 0;
skipUntil_test("If", "EndIf", "ElseIf", 4, &type_until2);
if(!type_until2) ImbricatedTest--;
}
}
}
else{
Message::Error("Orphan ElseIf");
}
;}
break;
case 788:
#line 7797 "ProParser.y"
{
if(ImbricatedTest > 0){
if(statusImbricatedTests[ImbricatedTest]){
skipUntil("If", "EndIf");
ImbricatedTest--;
}
}
else{
Message::Error("Orphan Else");
}
;}
break;
case 789:
#line 7809 "ProParser.y"
{
ImbricatedTest--;
if(ImbricatedTest < 0)
vyyerror(1, "Orphan EndIf");
;}
break;
case 790:
#line 7815 "ProParser.y"
{
getdp_yystring = (yyvsp[(3) - (5)].c);
Free((yyvsp[(3) - (5)].c));
;}
break;
case 792:
#line 7828 "ProParser.y"
{ (yyval.i) = 3; ;}
break;
case 793:
#line 7829 "ProParser.y"
{ (yyval.i) = -3; ;}
break;
case 794:
#line 7834 "ProParser.y"
{
(yyval.c) = (char*)"w";
;}
break;
case 795:
#line 7838 "ProParser.y"
{
(yyval.c) = (char*)"a";
;}
break;
case 800:
#line 7854 "ProParser.y"
{
Message::SetOnelabNumber((yyvsp[(3) - (7)].c), (yyvsp[(5) - (7)].d));
Free((yyvsp[(3) - (7)].c));
;}
break;
case 801:
#line 7860 "ProParser.y"
{
Message::SetOnelabString((yyvsp[(3) - (7)].c), (yyvsp[(5) - (7)].c));
Free((yyvsp[(3) - (7)].c));
Free((yyvsp[(5) - (7)].c));
;}
break;
case 802:
#line 7867 "ProParser.y"
{
Constant_S.Name = (yyvsp[(2) - (3)].c);
// FIXME: leak if constant is list or char; all Tree_Replace functions
// below also leak; correct fix is to replace all of this with a std::map
// like in Gmsh
Tree_Suppress(ConstantTable_L, &Constant_S);
Free((yyvsp[(2) - (3)].c));
;}
break;
case 803:
#line 7877 "ProParser.y"
{
Constant_S.Name = (yyvsp[(3) - (5)].c);
// FIXME: leak if constant is list or char; all Tree_Replace functions
// below also leak; correct fix is to replace all of this with a std::map
// like in Gmsh
Tree_Suppress(ConstantTable_L, &Constant_S);
Free((yyvsp[(3) - (5)].c));
;}
break;
case 804:
#line 7887 "ProParser.y"
{
nameSpaces.clear();
;}
break;
case 805:
#line 7892 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (4)].c);
if(List_Nbr((yyvsp[(3) - (4)].l)) == 1){
Constant_S.Type = VAR_FLOAT;
List_Read((yyvsp[(3) - (4)].l), 0, &Constant_S.Value.Float);
List_Delete((yyvsp[(3) - (4)].l));
}
else{
Constant_S.Type = VAR_LISTOFFLOAT;
Constant_S.Value.List = (yyvsp[(3) - (4)].l);
}
Tree_Replace(ConstantTable_L, &Constant_S);
;}
break;
case 806:
#line 7907 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (6)].c);
Constant_S.Type = VAR_LISTOFFLOAT;
Constant_S.Value.List = (yyvsp[(5) - (6)].l);
Tree_Replace(ConstantTable_L, &Constant_S);
;}
break;
case 807:
#line 7915 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (7)].c);
Constant *c = (Constant*)Tree_PQuery(ConstantTable_L, &Constant_S);
if(c && (c->Type == VAR_LISTOFFLOAT)){
if(List_Nbr((yyvsp[(3) - (7)].l)) == List_Nbr((yyvsp[(6) - (7)].l))){
for(int i = 0; i < List_Nbr((yyvsp[(3) - (7)].l)); i++){
double d;
List_Read((yyvsp[(3) - (7)].l), i, &d);
int idx = (int)d;
if(idx >= 0 && idx < List_Nbr(c->Value.List)){
double *pd = (double*)List_Pointer(c->Value.List, idx);
double d2 = *(double*)List_Pointer((yyvsp[(6) - (7)].l), i);
*pd = d2;
}
else
vyyerror(0, "Index %d out of range", idx);
}
}
else
vyyerror(0, "Bad list sizes for affectation %d != %d", List_Nbr((yyvsp[(3) - (7)].l)), List_Nbr((yyvsp[(6) - (7)].l)));
}
else
vyyerror(0, "Unknown list Constant: %s", (yyvsp[(1) - (7)].c));
List_Delete((yyvsp[(3) - (7)].l));
List_Delete((yyvsp[(6) - (7)].l));
;}
break;
case 808:
#line 7943 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (8)].c);
Constant *c = (Constant*)Tree_PQuery(ConstantTable_L, &Constant_S);
if(c && (c->Type == VAR_LISTOFFLOAT)){
if(List_Nbr((yyvsp[(3) - (8)].l)) == List_Nbr((yyvsp[(7) - (8)].l))){
for(int i = 0; i < List_Nbr((yyvsp[(3) - (8)].l)); i++){
double d;
List_Read((yyvsp[(3) - (8)].l), i, &d);
int idx = (int)d;
if(idx >= 0 && idx < List_Nbr(c->Value.List)){
double *pd = (double*)List_Pointer(c->Value.List, idx);
double d2 = *(double*)List_Pointer((yyvsp[(7) - (8)].l), i);
*pd += d2;
}
else
vyyerror(0, "Index %d out of range", idx);
}
}
else
vyyerror(0, "Bad list sizes (%d, %d) for += operation", List_Nbr((yyvsp[(3) - (8)].l)), List_Nbr((yyvsp[(7) - (8)].l)));
}
else
vyyerror(0, "Unknown list Constant: %s", (yyvsp[(1) - (8)].c));
List_Delete((yyvsp[(3) - (8)].l));
List_Delete((yyvsp[(7) - (8)].l));
;}
break;
case 809:
#line 7971 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (8)].c);
Constant *c = (Constant*)Tree_PQuery(ConstantTable_L, &Constant_S);
if(c && (c->Type == VAR_LISTOFFLOAT)){
if(List_Nbr((yyvsp[(3) - (8)].l)) == List_Nbr((yyvsp[(7) - (8)].l))){
for(int i = 0; i < List_Nbr((yyvsp[(3) - (8)].l)); i++){
double d;
List_Read((yyvsp[(3) - (8)].l), i, &d);
int idx = (int)d;
if(idx >= 0 && idx < List_Nbr(c->Value.List)){
double *pd = (double*)List_Pointer(c->Value.List, idx);
double d2 = *(double*)List_Pointer((yyvsp[(7) - (8)].l), i);
*pd -= d2;
}
else
vyyerror(0, "Index %d out of range", idx);
}
}
else
vyyerror(0, "Bad list sizes (%d, %d) for -= operation", List_Nbr((yyvsp[(3) - (8)].l)), List_Nbr((yyvsp[(7) - (8)].l)));
}
else
vyyerror(0, "Unknown list Constant: %s", (yyvsp[(1) - (8)].c));
List_Delete((yyvsp[(3) - (8)].l));
List_Delete((yyvsp[(7) - (8)].l));
;}
break;
case 810:
#line 7999 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (5)].c);
Constant *c = (Constant*)Tree_PQuery(ConstantTable_L, &Constant_S);
if(c){
if(c->Type == VAR_FLOAT && List_Nbr((yyvsp[(4) - (5)].l)) == 1){
double d;
List_Read((yyvsp[(4) - (5)].l), 0, &d);
c->Value.Float += d;
}
else if(c->Type == VAR_LISTOFFLOAT){
for(int i = 0; i < List_Nbr((yyvsp[(4) - (5)].l)); i++)
List_Add(c->Value.List, List_Pointer((yyvsp[(4) - (5)].l), i));
}
else
vyyerror(0, "Cannot append list to float");
}
else
vyyerror(0, "Unknown Constant: %s", (yyvsp[(1) - (5)].c));
List_Delete((yyvsp[(4) - (5)].l));
;}
break;
case 811:
#line 8021 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (7)].c);
Constant *c = (Constant*)Tree_PQuery(ConstantTable_L, &Constant_S);
if(c){
if(c->Type == VAR_LISTOFFLOAT){
for(int i = 0; i < List_Nbr((yyvsp[(6) - (7)].l)); i++)
List_Add(c->Value.List, List_Pointer((yyvsp[(6) - (7)].l), i));
}
else
vyyerror(0, "Cannot append list to float");
}
else
vyyerror(0, "Unknown Constant: %s", (yyvsp[(1) - (7)].c));
List_Delete((yyvsp[(6) - (7)].l));
;}
break;
case 812:
#line 8038 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (5)].c);
Constant *c = (Constant*)Tree_PQuery(ConstantTable_L, &Constant_S);
if(c){
if(c->Type == VAR_FLOAT && List_Nbr((yyvsp[(4) - (5)].l)) == 1){
double d;
List_Read((yyvsp[(4) - (5)].l), 0, &d);
c->Value.Float -= d;
}
else if(c->Type == VAR_LISTOFFLOAT){
std::vector<double> tmp;
for(int i = 0; i < List_Nbr(c->Value.List); i++){
double d;
List_Read(c->Value.List, i, &d);
tmp.push_back(d);
}
for(int i = 0; i < List_Nbr((yyvsp[(4) - (5)].l)); i++){
double d;
List_Read((yyvsp[(4) - (5)].l), i, &d);
std::vector<double>::iterator it = std::find(tmp.begin(), tmp.end(), d);
if(it != tmp.end()) tmp.erase(it);
}
List_Reset(c->Value.List);
for(unsigned int i = 0; i < tmp.size(); i++)
List_Add(c->Value.List, &tmp[i]);
}
else
vyyerror(0, "Cannot erase list from float");
}
else
vyyerror(0, "Unknown Constant: %s", (yyvsp[(1) - (5)].c));
List_Delete((yyvsp[(4) - (5)].l));
;}
break;
case 813:
#line 8073 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (7)].c);
Constant *c = (Constant*)Tree_PQuery(ConstantTable_L, &Constant_S);
if(c){
if(c->Type == VAR_LISTOFFLOAT){
std::vector<double> tmp;
for(int i = 0; i < List_Nbr(c->Value.List); i++){
double d;
List_Read(c->Value.List, i, &d);
tmp.push_back(d);
}
for(int i = 0; i < List_Nbr((yyvsp[(6) - (7)].l)); i++){
double d;
List_Read((yyvsp[(6) - (7)].l), i, &d);
std::vector<double>::iterator it = std::find(tmp.begin(), tmp.end(), d);
if(it != tmp.end()) tmp.erase(it);
}
List_Reset(c->Value.List);
for(unsigned int i = 0; i < tmp.size(); i++)
List_Add(c->Value.List, &tmp[i]);
}
else
vyyerror(0, "Cannot erase list from float");
}
else
vyyerror(0, "Unknown Constant: %s", (yyvsp[(1) - (7)].c));
List_Delete((yyvsp[(6) - (7)].l));
;}
break;
case 814:
#line 8103 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (4)].c); Constant_S.Type = VAR_CHAR;
Constant_S.Value.Char = (yyvsp[(3) - (4)].c);
Tree_Replace(ConstantTable_L, &Constant_S);
;}
break;
case 815:
#line 8110 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (8)].c);
Constant_S.Type = VAR_LISTOFCHAR;
Constant_S.Value.List = List_Create(20, 20, sizeof(char*));
Tree_Replace(ConstantTable_L, &Constant_S);
;}
break;
case 816:
#line 8118 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (9)].c);
Constant_S.Type = VAR_LISTOFCHAR;
Constant_S.Value.List = (yyvsp[(7) - (9)].l);
Tree_Replace(ConstantTable_L, &Constant_S);
;}
break;
case 817:
#line 8126 "ProParser.y"
{
Constant_S.Name = (yyvsp[(1) - (10)].c);
Constant *c = (Constant*)Tree_PQuery(ConstantTable_L, &Constant_S);
if(c){
if(c->Type == VAR_LISTOFCHAR){
for(int i = 0; i < List_Nbr((yyvsp[(8) - (10)].l)); i++)
List_Add(c->Value.List, List_Pointer((yyvsp[(8) - (10)].l), i));
}
else
vyyerror(0, "Cannot append string to non-list of strings");
}
else
vyyerror(0, "Unknown Constant: %s", (yyvsp[(1) - (10)].c));
List_Delete((yyvsp[(8) - (10)].l));
;}
break;
case 818:
#line 8143 "ProParser.y"
{
Message::Direct((yyvsp[(1) - (5)].i), (yyvsp[(3) - (5)].c));
;}
break;
case 819:
#line 8148 "ProParser.y"
{
std::string tmp = Fix_RelativePath((yyvsp[(6) - (7)].c));
FILE *fp = FOpen(tmp.c_str(), (yyvsp[(5) - (7)].c));
if(!fp){
vyyerror(0, "Unable to open file '%s'", tmp.c_str());
}
else{
fprintf(fp, "%s\n", (yyvsp[(3) - (7)].c));
fclose(fp);
}
Free((yyvsp[(3) - (7)].c));
Free((yyvsp[(6) - (7)].c));
;}
break;
case 820:
#line 8163 "ProParser.y"
{
Constant_S.Name = (yyvsp[(2) - (3)].c);
if(!Tree_Query(ConstantTable_L, &Constant_S))
vyyerror(0, "Unknown Constant: %s", (yyvsp[(2) - (3)].c));
else
if(Constant_S.Type != VAR_LISTOFFLOAT)
Message::Direct((yyvsp[(1) - (3)].i), "%s: %g", (yyvsp[(2) - (3)].c), Constant_S.Value.Float);
else
Message::Direct((yyvsp[(1) - (3)].i), "%s: Dimension %d", (yyvsp[(2) - (3)].c), List_Nbr(Constant_S.Value.List));
for(int i = 0; i < List_Nbr(Constant_S.Value.List); i++) {
double d;
List_Read(Constant_S.Value.List, i, &d);
Message::Direct((yyvsp[(1) - (3)].i), " (%d) %g", i, d);
}
;}
break;
case 821:
#line 8180 "ProParser.y"
{
Message::Direct((yyvsp[(1) - (3)].i), "Line number: %d", getdp_yylinenum);
;}
break;
case 822:
#line 8185 "ProParser.y"
{
char tmpstr[256];
int i = Print_ListOfDouble((yyvsp[(3) - (7)].c), (yyvsp[(5) - (7)].l), tmpstr);
if(i < 0)
vyyerror(0, "Too few arguments in Printf");
else if(i > 0)
vyyerror(0, "Too many arguments (%d) in Printf", i);
else
Message::Direct((yyvsp[(1) - (7)].i), tmpstr);
Free((yyvsp[(3) - (7)].c));
List_Delete((yyvsp[(5) - (7)].l));
;}
break;
case 823:
#line 8199 "ProParser.y"
{
std::string tmp = Fix_RelativePath((yyvsp[(8) - (9)].c));
FILE *fp = FOpen(tmp.c_str(), (yyvsp[(7) - (9)].c));
if(!fp){
vyyerror(0, "Unable to open file '%s'", tmp.c_str());
}
else{
char tmpstr[256];
int i = Print_ListOfDouble((yyvsp[(3) - (9)].c), (yyvsp[(5) - (9)].l), tmpstr);
if(i < 0)
vyyerror(0, "Too few arguments in Printf");
else if(i > 0)
vyyerror(0, "Too many arguments (%d) in Printf", i);
else
fprintf(fp, "%s\n", (yyvsp[(3) - (9)].c));
fclose(fp);
}
Free((yyvsp[(3) - (9)].c));
Free((yyvsp[(8) - (9)].c));
List_Delete((yyvsp[(5) - (9)].l));
;}
break;
case 824:
#line 8222 "ProParser.y"
{
Message::Error((yyvsp[(3) - (5)].c));
Free((yyvsp[(3) - (5)].c));
;}
break;
case 825:
#line 8229 "ProParser.y"
{
Message::Info("? ");
char tmpstr[256];
fgets(tmpstr, sizeof(tmpstr), stdin);
Constant_S.Value.Float = atof(tmpstr);
Constant_S.Name = (yyvsp[(3) - (5)].c);
Constant_S.Type = VAR_FLOAT;
Tree_Replace(ConstantTable_L, &Constant_S);
;}
break;
case 826:
#line 8240 "ProParser.y"
{
Message::Info("? ");
char tmpstr[256];
fgets(tmpstr, sizeof(tmpstr), stdin);
Constant_S.Value.Float = atof(tmpstr);
Constant_S.Name = (yyvsp[(3) - (5)].c);
Constant_S.Type = VAR_FLOAT;
Tree_Replace(ConstantTable_L, &Constant_S);
;}
break;
case 827:
#line 8252 "ProParser.y"
{
Message::Info("[<return>=%g] ? ",(yyvsp[(6) - (8)].d));
char tmpstr[256];
fgets(tmpstr, sizeof(tmpstr), stdin);
if(!strcmp(tmpstr,"\n"))
Constant_S.Value.Float = (yyvsp[(6) - (8)].d);
else
Constant_S.Value.Float = atof(tmpstr);
Constant_S.Name = (yyvsp[(3) - (8)].c);
Constant_S.Type = VAR_FLOAT;
Tree_Replace(ConstantTable_L, &Constant_S);
;}
break;
case 828:
#line 8267 "ProParser.y"
{
Message::Info("[<return>=%g] ? ",(yyvsp[(5) - (7)].d));
char tmpstr[256];
fgets(tmpstr, sizeof(tmpstr), stdin);
if(!strcmp(tmpstr,"\n"))
Constant_S.Value.Float = (yyvsp[(5) - (7)].d);
else
Constant_S.Value.Float = atof(tmpstr);
Constant_S.Name = (yyvsp[(3) - (7)].c);
Constant_S.Type = VAR_FLOAT;
Tree_Replace(ConstantTable_L, &Constant_S);
;}
break;
case 829:
#line 8282 "ProParser.y"
{
Print_Constants();
;}
break;
case 830:
#line 8289 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(doubleXstring));
doubleXstring v = {(yyvsp[(1) - (3)].d), (yyvsp[(3) - (3)].c)};
List_Add((yyval.l), &v);
;}
break;
case 831:
#line 8295 "ProParser.y"
{
doubleXstring v = {(yyvsp[(3) - (5)].d), (yyvsp[(5) - (5)].c)};
List_Add((yyval.l), &v);
;}
break;
case 832:
#line 8300 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(doubleXstring));
int n = List_Nbr((yyvsp[(1) - (5)].l));
Constant_S.Name = (yyvsp[(3) - (5)].c);
if(!Tree_Query(ConstantTable_L, &Constant_S))
vyyerror(0, "Unknown Constant: %s", (yyvsp[(3) - (5)].c));
else{
if(Constant_S.Type == VAR_LISTOFCHAR){
int m = List_Nbr(Constant_S.Value.List);
if(n == m){
for(int i = 0; i < n; i++){
double d;
List_Read((yyvsp[(1) - (5)].l), i, &d);
char *s;
List_Read(Constant_S.Value.List, i, &s);
doubleXstring v = {d, strSave(s)};
List_Add((yyval.l), &v);
}
}
else{
vyyerror(0, "Size mismatch in enumeration: %d != %d", n, m);
}
}
else{
vyyerror(0, "Enumeration requires list of strings");
}
}
List_Delete((yyvsp[(1) - (5)].l));
;}
break;
case 839:
#line 8349 "ProParser.y"
{
std::string key((yyvsp[(1) - (2)].c));
for(int i = 0; i < List_Nbr((yyvsp[(2) - (2)].l)); i++){
double v;
List_Read((yyvsp[(2) - (2)].l), i, &v);
floatOptions[key].push_back(v);
if (flag_Enum && !i) { member_ValMax = (int)v; }
}
Free((yyvsp[(1) - (2)].c));
List_Delete((yyvsp[(2) - (2)].l));
;}
break;
case 840:
#line 8362 "ProParser.y"
{
std::string key((yyvsp[(1) - (1)].c));
double v;
if (!flag_Enum) {
v = 1.;
if (key == "Enum") flag_Enum = 1;
}
else
v = (double)++member_ValMax;
floatOptions[key].push_back(v);
Free((yyvsp[(1) - (1)].c));
;}
break;
case 841:
#line 8376 "ProParser.y"
{
std::string key((yyvsp[(1) - (4)].c));
for(int i = 0; i < List_Nbr((yyvsp[(3) - (4)].l)); i++){
doubleXstring v;
List_Read((yyvsp[(3) - (4)].l), i, &v);
floatOptions[key].push_back(v.d);
charOptions[key].push_back(v.s);
}
Free((yyvsp[(1) - (4)].c));
for(int i = 0; i < List_Nbr((yyvsp[(3) - (4)].l)); i++)
Free(((doubleXstring*)List_Pointer((yyvsp[(3) - (4)].l), i))->s);
List_Delete((yyvsp[(3) - (4)].l));
;}
break;
case 842:
#line 8391 "ProParser.y"
{
std::string key((yyvsp[(1) - (2)].c));
std::string val((yyvsp[(2) - (2)].c));
charOptions[key].push_back(val);
Free((yyvsp[(1) - (2)].c));
Free((yyvsp[(2) - (2)].c));
;}
break;
case 843:
#line 8400 "ProParser.y"
{
std::string key((yyvsp[(1) - (2)].c));
for(int i = 0; i < List_Nbr((yyvsp[(2) - (2)].l)); i++){
char *v;
List_Read((yyvsp[(2) - (2)].l), i, &v);
charOptions[key].push_back(v);
}
Free((yyvsp[(1) - (2)].c));
List_Delete((yyvsp[(2) - (2)].l));
;}
break;
case 844:
#line 8412 "ProParser.y"
{
std::string key("Name");
std::string val((yyvsp[(2) - (2)].c));
charOptions[key].push_back(val);
Free((yyvsp[(2) - (2)].c));
;}
break;
case 845:
#line 8420 "ProParser.y"
{
std::string key("Type");
for(int i = 0; i < List_Nbr((yyvsp[(2) - (2)].l)); i++){
double v;
List_Read((yyvsp[(2) - (2)].l), i, &v);
floatOptions[key].push_back(v);
}
List_Delete((yyvsp[(2) - (2)].l));
;}
break;
case 850:
#line 8444 "ProParser.y"
{
std::string key((yyvsp[(1) - (2)].c));
double val = (yyvsp[(2) - (2)].d);
floatOptions[key].push_back(val);
Free((yyvsp[(1) - (2)].c));
;}
break;
case 851:
#line 8452 "ProParser.y"
{
std::string key((yyvsp[(1) - (2)].c));
std::string val((yyvsp[(2) - (2)].c));
charOptions[key].push_back(val);
Free((yyvsp[(1) - (2)].c));
Free((yyvsp[(2) - (2)].c));
;}
break;
case 852:
#line 8461 "ProParser.y"
{
std::string key("Name");
std::string val((yyvsp[(2) - (2)].c));
charOptions[key].push_back(val);
Free((yyvsp[(2) - (2)].c));
;}
break;
case 853:
#line 8469 "ProParser.y"
{
std::string key("Macro");
std::string val((yyvsp[(2) - (2)].c));
charOptions[key].push_back(val);
Free((yyvsp[(2) - (2)].c));
;}
break;
case 854:
#line 8477 "ProParser.y"
{
std::string key((yyvsp[(1) - (2)].c));
for(int i = 0; i < List_Nbr((yyvsp[(2) - (2)].l)); i++){
char *s;
List_Read((yyvsp[(2) - (2)].l), i, &s);
std::string val(s);
Free(s);
charOptions[key].push_back(val);
}
Free((yyvsp[(1) - (2)].c));
List_Delete((yyvsp[(2) - (2)].l));
;}
break;
case 855:
#line 8491 "ProParser.y"
{
std::string key((yyvsp[(1) - (2)].c));
for(int i = 0; i < List_Nbr((yyvsp[(2) - (2)].l)); i++){
char *s;
List_Read((yyvsp[(2) - (2)].l), i, &s);
std::string val(s);
Free(s);
charOptions[key].push_back(val);
}
Free((yyvsp[(1) - (2)].c));
List_Delete((yyvsp[(2) - (2)].l));
;}
break;
case 857:
#line 8509 "ProParser.y"
{ Constant_S.Name = (yyvsp[(3) - (3)].c); Constant_S.Type = VAR_FLOAT;
init_Options();
if(!Tree_Search(ConstantTable_L, &Constant_S)){
Constant_S.Value.Float = 0.;
Tree_Replace(ConstantTable_L, &Constant_S);
}
;}
break;
case 858:
#line 8517 "ProParser.y"
{
Constant_S.Type = VAR_FLOAT ;
init_Options();
for (int k = 0 ; k < (int)(yyvsp[(5) - (6)].d) ; k++) {
char tmpstr[256];
sprintf(tmpstr, "%s_%d", (yyvsp[(3) - (6)].c), k+1) ;
Constant_S.Name = tmpstr ;
if (!Tree_Search(ConstantTable_L, &Constant_S)) {
Constant_S.Name = strSave(tmpstr);
Constant_S.Value.Float = 0. ;
Tree_Replace(ConstantTable_L, &Constant_S) ;
}
}
Free((yyvsp[(3) - (6)].c)) ;
;}
break;
case 859:
#line 8533 "ProParser.y"
{
Constant_S.Name = (yyvsp[(3) - (5)].c); Constant_S.Type = VAR_FLOAT;
if(!Tree_Search(ConstantTable_L, &Constant_S)){
Constant_S.Value.Float = (yyvsp[(5) - (5)].d);
Tree_Replace(ConstantTable_L, &Constant_S);
}
;}
break;
case 860:
#line 8541 "ProParser.y"
{
Constant_S.Name = (yyvsp[(3) - (8)].c); Constant_S.Type = VAR_LISTOFFLOAT;
if(!Tree_Search(ConstantTable_L, &Constant_S)){
Constant_S.Value.List = List_Create(2,20,sizeof(double));
Tree_Replace(ConstantTable_L, &Constant_S);
}
;}
break;
case 861:
#line 8549 "ProParser.y"
{ init_Options(); ;}
break;
case 862:
#line 8551 "ProParser.y"
{
Constant_S.Name = (yyvsp[(3) - (9)].c);
if(List_Nbr((yyvsp[(6) - (9)].l)) == 1){
Constant_S.Type = VAR_FLOAT;
if(!Tree_Search(ConstantTable_L, &Constant_S)){
double d;
List_Read((yyvsp[(6) - (9)].l), 0, &d);
Constant_S.Value.Float = d;
Message::ExchangeOnelabParameter(&Constant_S, floatOptions, charOptions);
Tree_Replace(ConstantTable_L, &Constant_S);
}
List_Delete((yyvsp[(6) - (9)].l));
}
else{
vyyerror(1, "List notation should be used to define list '%s()'", (yyvsp[(3) - (9)].c));
Constant_S.Type = VAR_LISTOFFLOAT;
if(!Tree_Search(ConstantTable_L, &Constant_S)){
Constant_S.Value.List = (yyvsp[(6) - (9)].l);
Message::ExchangeOnelabParameter(&Constant_S, floatOptions, charOptions);
Tree_Replace(ConstantTable_L, &Constant_S);
}
}
;}
break;
case 863:
#line 8575 "ProParser.y"
{ init_Options(); ;}
break;
case 864:
#line 8577 "ProParser.y"
{
Constant_S.Name = (yyvsp[(3) - (11)].c);
Constant_S.Type = VAR_LISTOFFLOAT;
if(!Tree_Search(ConstantTable_L, &Constant_S)){
Constant_S.Value.List = (yyvsp[(8) - (11)].l);
Message::ExchangeOnelabParameter(&Constant_S, floatOptions, charOptions);
Tree_Replace(ConstantTable_L, &Constant_S);
}
;}
break;
case 865:
#line 8587 "ProParser.y"
{
Constant_S.Name = (yyvsp[(3) - (5)].c); Constant_S.Type = VAR_CHAR;
if(!Tree_Search(ConstantTable_L, &Constant_S)){
Constant_S.Value.Char = (yyvsp[(5) - (5)].c);
Tree_Replace(ConstantTable_L, &Constant_S);
}
;}
break;
case 866:
#line 8595 "ProParser.y"
{ init_Options(); ;}
break;
case 867:
#line 8597 "ProParser.y"
{
Constant_S.Name = (yyvsp[(3) - (9)].c); Constant_S.Type = VAR_CHAR;
if(!Tree_Search(ConstantTable_L, &Constant_S)){
Constant_S.Value.Char = (yyvsp[(6) - (9)].c);
Message::ExchangeOnelabParameter(&Constant_S, floatOptions, charOptions);
Tree_Replace(ConstantTable_L, &Constant_S);
}
;}
break;
case 869:
#line 8611 "ProParser.y"
{
// undefine the onelab parameter
std::string name((yyvsp[(3) - (3)].c));
Message::UndefineOnelabParameter(name);
Free((yyvsp[(3) - (3)].c));
;}
break;
case 870:
#line 8619 "ProParser.y"
{
// undefine the onelab parameter and the getdp constant
std::string name((yyvsp[(3) - (3)].c));
Message::UndefineOnelabParameter(name);
Constant_S.Name = (yyvsp[(3) - (3)].c);
Tree_Suppress(ConstantTable_L, &Constant_S);
Free((yyvsp[(3) - (3)].c));
;}
break;
case 871:
#line 8633 "ProParser.y"
{ (yyval.c) = (char*)"Exp"; ;}
break;
case 872:
#line 8634 "ProParser.y"
{ (yyval.c) = (char*)"Log"; ;}
break;
case 873:
#line 8635 "ProParser.y"
{ (yyval.c) = (char*)"Log10"; ;}
break;
case 874:
#line 8636 "ProParser.y"
{ (yyval.c) = (char*)"Sqrt"; ;}
break;
case 875:
#line 8637 "ProParser.y"
{ (yyval.c) = (char*)"Sin"; ;}
break;
case 876:
#line 8638 "ProParser.y"
{ (yyval.c) = (char*)"Asin"; ;}
break;
case 877:
#line 8639 "ProParser.y"
{ (yyval.c) = (char*)"Cos"; ;}
break;
case 878:
#line 8640 "ProParser.y"
{ (yyval.c) = (char*)"Acos"; ;}
break;
case 879:
#line 8641 "ProParser.y"
{ (yyval.c) = (char*)"Tan"; ;}
break;
case 880:
#line 8642 "ProParser.y"
{ (yyval.c) = (char*)"Atan"; ;}
break;
case 881:
#line 8643 "ProParser.y"
{ (yyval.c) = (char*)"Atan2"; ;}
break;
case 882:
#line 8644 "ProParser.y"
{ (yyval.c) = (char*)"Sinh"; ;}
break;
case 883:
#line 8645 "ProParser.y"
{ (yyval.c) = (char*)"Cosh"; ;}
break;
case 884:
#line 8646 "ProParser.y"
{ (yyval.c) = (char*)"Tanh"; ;}
break;
case 885:
#line 8647 "ProParser.y"
{ (yyval.c) = (char*)"Fabs"; ;}
break;
case 886:
#line 8648 "ProParser.y"
{ (yyval.c) = (char*)"Floor"; ;}
break;
case 887:
#line 8649 "ProParser.y"
{ (yyval.c) = (char*)"Ceil"; ;}
break;
case 888:
#line 8650 "ProParser.y"
{ (yyval.c) = (char*)"Round"; ;}
break;
case 889:
#line 8651 "ProParser.y"
{ (yyval.c) = (char*)"Sign"; ;}
break;
case 890:
#line 8652 "ProParser.y"
{ (yyval.c) = (char*)"Fmod"; ;}
break;
case 891:
#line 8653 "ProParser.y"
{ (yyval.c) = (char*)"Modulo"; ;}
break;
case 892:
#line 8654 "ProParser.y"
{ (yyval.c) = (char*)"Hypot"; ;}
break;
case 893:
#line 8655 "ProParser.y"
{ (yyval.c) = (char*)"Rand"; ;}
break;
case 894:
#line 8659 "ProParser.y"
{ (yyval.c) = (yyvsp[(1) - (1)].c); ;}
break;
case 895:
#line 8660 "ProParser.y"
{ (yyval.c) = (yyvsp[(1) - (1)].c); ;}
break;
case 896:
#line 8664 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (1)].d); ;}
break;
case 897:
#line 8665 "ProParser.y"
{ (yyval.d) = (yyvsp[(2) - (3)].d); ;}
break;
case 898:
#line 8666 "ProParser.y"
{ (yyval.d) = -(yyvsp[(2) - (2)].d); ;}
break;
case 899:
#line 8667 "ProParser.y"
{ (yyval.d) = !(yyvsp[(2) - (2)].d); ;}
break;
case 900:
#line 8668 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) - (yyvsp[(3) - (3)].d); ;}
break;
case 901:
#line 8669 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) + (yyvsp[(3) - (3)].d); ;}
break;
case 902:
#line 8670 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) * (yyvsp[(3) - (3)].d); ;}
break;
case 903:
#line 8671 "ProParser.y"
{ (yyval.d) = (int)(yyvsp[(1) - (3)].d) | (int)(yyvsp[(3) - (3)].d); ;}
break;
case 904:
#line 8672 "ProParser.y"
{ (yyval.d) = (int)(yyvsp[(1) - (3)].d) & (int)(yyvsp[(3) - (3)].d); ;}
break;
case 905:
#line 8673 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) / (yyvsp[(3) - (3)].d); ;}
break;
case 906:
#line 8674 "ProParser.y"
{ (yyval.d) = (int)(yyvsp[(1) - (3)].d) % (int)(yyvsp[(3) - (3)].d); ;}
break;
case 907:
#line 8675 "ProParser.y"
{ (yyval.d) = pow((yyvsp[(1) - (3)].d),(yyvsp[(3) - (3)].d)); ;}
break;
case 908:
#line 8676 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) < (yyvsp[(3) - (3)].d); ;}
break;
case 909:
#line 8677 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) > (yyvsp[(3) - (3)].d); ;}
break;
case 910:
#line 8678 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) <= (yyvsp[(3) - (3)].d); ;}
break;
case 911:
#line 8679 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) >= (yyvsp[(3) - (3)].d); ;}
break;
case 912:
#line 8680 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) == (yyvsp[(3) - (3)].d); ;}
break;
case 913:
#line 8681 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) != (yyvsp[(3) - (3)].d); ;}
break;
case 914:
#line 8682 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) && (yyvsp[(3) - (3)].d); ;}
break;
case 915:
#line 8683 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (3)].d) || (yyvsp[(3) - (3)].d); ;}
break;
case 916:
#line 8684 "ProParser.y"
{ (yyval.d) = ((int)(yyvsp[(1) - (3)].d) >> (int)(yyvsp[(3) - (3)].d)); ;}
break;
case 917:
#line 8685 "ProParser.y"
{ (yyval.d) = ((int)(yyvsp[(1) - (3)].d) << (int)(yyvsp[(3) - (3)].d)); ;}
break;
case 918:
#line 8686 "ProParser.y"
{ (yyval.d) = exp((yyvsp[(3) - (4)].d)); ;}
break;
case 919:
#line 8687 "ProParser.y"
{ (yyval.d) = log((yyvsp[(3) - (4)].d)); ;}
break;
case 920:
#line 8688 "ProParser.y"
{ (yyval.d) = log10((yyvsp[(3) - (4)].d)); ;}
break;
case 921:
#line 8689 "ProParser.y"
{ (yyval.d) = sqrt((yyvsp[(3) - (4)].d)); ;}
break;
case 922:
#line 8690 "ProParser.y"
{ (yyval.d) = sin((yyvsp[(3) - (4)].d)); ;}
break;
case 923:
#line 8691 "ProParser.y"
{ (yyval.d) = asin((yyvsp[(3) - (4)].d)); ;}
break;
case 924:
#line 8692 "ProParser.y"
{ (yyval.d) = cos((yyvsp[(3) - (4)].d)); ;}
break;
case 925:
#line 8693 "ProParser.y"
{ (yyval.d) = acos((yyvsp[(3) - (4)].d)); ;}
break;
case 926:
#line 8694 "ProParser.y"
{ (yyval.d) = tan((yyvsp[(3) - (4)].d)); ;}
break;
case 927:
#line 8695 "ProParser.y"
{ (yyval.d) = atan((yyvsp[(3) - (4)].d)); ;}
break;
case 928:
#line 8696 "ProParser.y"
{ (yyval.d) = atan2((yyvsp[(3) - (6)].d),(yyvsp[(5) - (6)].d)); ;}
break;
case 929:
#line 8697 "ProParser.y"
{ (yyval.d) = sinh((yyvsp[(3) - (4)].d)); ;}
break;
case 930:
#line 8698 "ProParser.y"
{ (yyval.d) = cosh((yyvsp[(3) - (4)].d)); ;}
break;
case 931:
#line 8699 "ProParser.y"
{ (yyval.d) = tanh((yyvsp[(3) - (4)].d)); ;}
break;
case 932:
#line 8700 "ProParser.y"
{ (yyval.d) = fabs((yyvsp[(3) - (4)].d)); ;}
break;
case 933:
#line 8701 "ProParser.y"
{ (yyval.d) = floor((yyvsp[(3) - (4)].d)); ;}
break;
case 934:
#line 8702 "ProParser.y"
{ (yyval.d) = ceil((yyvsp[(3) - (4)].d)); ;}
break;
case 935:
#line 8703 "ProParser.y"
{ (yyval.d) = floor((yyvsp[(3) - (4)].d) + 0.5); ;}
break;
case 936:
#line 8704 "ProParser.y"
{ (yyval.d) = (((yyvsp[(3) - (4)].d) > 0.) ? 1. : ((yyvsp[(3) - (4)].d) < 0.) ? -1. : 0.); ;}
break;
case 937:
#line 8705 "ProParser.y"
{ (yyval.d) = fmod((yyvsp[(3) - (6)].d),(yyvsp[(5) - (6)].d)); ;}
break;
case 938:
#line 8706 "ProParser.y"
{ (yyval.d) = fmod((yyvsp[(3) - (6)].d),(yyvsp[(5) - (6)].d)); ;}
break;
case 939:
#line 8707 "ProParser.y"
{ (yyval.d) = sqrt((yyvsp[(3) - (6)].d)*(yyvsp[(3) - (6)].d)+(yyvsp[(5) - (6)].d)*(yyvsp[(5) - (6)].d)); ;}
break;
case 940:
#line 8708 "ProParser.y"
{ (yyval.d) = (yyvsp[(3) - (4)].d) * (double)rand() / (double)RAND_MAX; ;}
break;
case 941:
#line 8710 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (5)].d)? (yyvsp[(3) - (5)].d) : (yyvsp[(5) - (5)].d); ;}
break;
case 942:
#line 8712 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (1)].i); ;}
break;
case 943:
#line 8714 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (1)].i); ;}
break;
case 944:
#line 8716 "ProParser.y"
{ Message::Direct("Value (line %ld) --> %.16g", getdp_yylinenum, (yyvsp[(1) - (2)].d)); ;}
break;
case 945:
#line 8721 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (1)].d); ;}
break;
case 946:
#line 8722 "ProParser.y"
{ (yyval.d) = (double)(yyvsp[(1) - (1)].i); ;}
break;
case 947:
#line 8723 "ProParser.y"
{ (yyval.d) = 3.1415926535897932; ;}
break;
case 948:
#line 8724 "ProParser.y"
{ (yyval.d) = (double)_0D; ;}
break;
case 949:
#line 8725 "ProParser.y"
{ (yyval.d) = (double)_1D; ;}
break;
case 950:
#line 8726 "ProParser.y"
{ (yyval.d) = (double)_2D; ;}
break;
case 951:
#line 8727 "ProParser.y"
{ (yyval.d) = (double)_3D; ;}
break;
case 952:
#line 8728 "ProParser.y"
{ (yyval.d) = Message::GetCommRank(); ;}
break;
case 953:
#line 8729 "ProParser.y"
{ (yyval.d) = Message::GetCommSize(); ;}
break;
case 954:
#line 8730 "ProParser.y"
{ (yyval.d) = GETDP_MAJOR_VERSION; ;}
break;
case 955:
#line 8731 "ProParser.y"
{ (yyval.d) = GETDP_MINOR_VERSION; ;}
break;
case 956:
#line 8732 "ProParser.y"
{ (yyval.d) = GETDP_PATCH_VERSION; ;}
break;
case 957:
#line 8733 "ProParser.y"
{ (yyval.d) = GetTotalRam(); ;}
break;
case 958:
#line 8735 "ProParser.y"
{ (yyval.d) = (double)ImbricatedTest; ;}
break;
case 959:
#line 8736 "ProParser.y"
{ (yyval.d) = (double)num_include; ;}
break;
case 960:
#line 8737 "ProParser.y"
{ (yyval.d) = (double)level_include; ;}
break;
case 961:
#line 8741 "ProParser.y"
{ init_Options(); ;}
break;
case 962:
#line 8743 "ProParser.y"
{
Constant_S.Name = (char*)""; Constant_S.Type = VAR_FLOAT;
Constant_S.Value.Float = (yyvsp[(3) - (6)].d);
Message::ExchangeOnelabParameter(&Constant_S, floatOptions, charOptions);
(yyval.d) = Constant_S.Value.Float;
;}
break;
case 963:
#line 8751 "ProParser.y"
{ (yyval.d) = (yyvsp[(1) - (1)].d); ;}
break;
case 964:
#line 8754 "ProParser.y"
{
(yyval.d) = Treat_Struct_FullName_dot_tSTRING_Float((yyvsp[(1) - (3)].c2).char1, (yyvsp[(1) - (3)].c2).char2, (yyvsp[(3) - (3)].c));
;}
break;
case 965:
#line 8759 "ProParser.y"
{
(yyval.d) = Treat_Struct_FullName_dot_tSTRING_Float((yyvsp[(1) - (6)].c2).char1, (yyvsp[(1) - (6)].c2).char2, (yyvsp[(3) - (6)].c), (int)(yyvsp[(5) - (6)].d));
;}
break;
case 966:
#line 8764 "ProParser.y"
{
(yyval.d) = Message::GetOnelabNumber((yyvsp[(3) - (4)].c), 0.);
Free((yyvsp[(3) - (4)].c));
;}
break;
case 967:
#line 8770 "ProParser.y"
{
(yyval.d) = Message::GetOnelabNumber((yyvsp[(3) - (6)].c), (yyvsp[(5) - (6)].d));
Free((yyvsp[(3) - (6)].c));
;}
break;
case 968:
#line 8776 "ProParser.y"
{
(yyval.d) = Treat_Struct_FullName_Float((yyvsp[(1) - (1)].c2).char1, (yyvsp[(1) - (1)].c2).char2);
;}
break;
case 969:
#line 8781 "ProParser.y"
{
if ((yyvsp[(2) - (4)].c2).char1) vyyerror(1, "NameSpace '%s' not used yet", (yyvsp[(2) - (4)].c2).char1);
Constant_S.Name = (yyvsp[(2) - (4)].c2).char2;
int ret = 0;
if(!Tree_Query(ConstantTable_L, &Constant_S))
vyyerror(0, "Unknown Constant: %s", (yyvsp[(2) - (4)].c2).char2);
else{
if(Constant_S.Type == VAR_LISTOFFLOAT ||
Constant_S.Type == VAR_LISTOFCHAR)
ret = List_Nbr(Constant_S.Value.List);
else if(Constant_S.Type == VAR_FLOAT)
ret = 1;
else
vyyerror(0, "Float Constant needed: %s", (yyvsp[(2) - (4)].c2).char2);
}
(yyval.d) = ret;
Free((yyvsp[(2) - (4)].c2).char1); Free((yyvsp[(2) - (4)].c2).char2);
;}
break;
case 970:
#line 8801 "ProParser.y"
{
(yyval.d) = Treat_Struct_FullName_dot_tSTRING_Float_getDim((yyvsp[(2) - (6)].c2).char1, (yyvsp[(2) - (6)].c2).char2, (yyvsp[(4) - (6)].c));
;}
break;
case 971:
#line 8806 "ProParser.y"
{
std::string struct_namespace((yyvsp[(3) - (4)].c));
(yyval.d) = (double)nameSpaces[struct_namespace].size();
Free((yyvsp[(3) - (4)].c));
;}
break;
case 972:
#line 8812 "ProParser.y"
{
std::string struct_namespace(std::string(""));
(yyval.d) = (double)nameSpaces[struct_namespace].size();
;}
break;
case 973:
#line 8818 "ProParser.y"
{
(yyval.d) = Treat_Struct_FullName_Float((yyvsp[(1) - (4)].c2).char1, (yyvsp[(1) - (4)].c2).char2, 2, (int)(yyvsp[(3) - (4)].d));
;}
break;
case 974:
#line 8823 "ProParser.y"
{
(yyval.d) = Treat_Struct_FullName_Float((yyvsp[(3) - (4)].c2).char1, (yyvsp[(3) - (4)].c2).char2, 1, 0, 0., 1);
;}
break;
case 975:
#line 8828 "ProParser.y"
{
(yyval.d) = Treat_Struct_FullName_dot_tSTRING_Float((yyvsp[(3) - (6)].c2).char1, (yyvsp[(3) - (6)].c2).char2, (yyvsp[(5) - (6)].c), 0, 0., 1);
;}
break;
case 976:
#line 8833 "ProParser.y"
{
if(List_ISearchSeq(Problem_S.Expression, (yyvsp[(3) - (6)].c), fcmp_Expression_Name) >= 0)
(yyval.d) = 1;
else
(yyval.d) = 0;
Free((yyvsp[(3) - (6)].c));
;}
break;
case 977:
#line 8842 "ProParser.y"
{
(yyval.d) = Treat_Struct_FullName_Float((yyvsp[(3) - (5)].c2).char1, (yyvsp[(3) - (5)].c2).char2, 1, 0, (yyvsp[(4) - (5)].d), 2);
;}
break;
case 978:
#line 8847 "ProParser.y"
{
(yyval.d) = Treat_Struct_FullName_dot_tSTRING_Float((yyvsp[(3) - (7)].c2).char1, (yyvsp[(3) - (7)].c2).char2, (yyvsp[(5) - (7)].c), 0, (yyvsp[(6) - (7)].d), 2);
;}
break;
case 979:
#line 8852 "ProParser.y"
{
std::string tmp = Fix_RelativePath((yyvsp[(3) - (4)].c)).c_str();
(yyval.d) = !StatusFile(tmp);
Free((yyvsp[(3) - (4)].c));
;}
break;
case 980:
#line 8861 "ProParser.y"
{ (yyval.d) = 0.; ;}
break;
case 981:
#line 8863 "ProParser.y"
{ (yyval.d) = (yyvsp[(2) - (2)].d);;}
break;
case 982:
#line 8868 "ProParser.y"
{ (yyval.c) = NULL; ;}
break;
case 983:
#line 8870 "ProParser.y"
{ (yyval.c) = (yyvsp[(2) - (2)].c);;}
break;
case 984:
#line 8875 "ProParser.y"
{
std::string struct_namespace((yyvsp[(2) - (3)].c2).char1? (yyvsp[(2) - (3)].c2).char1 : std::string("")),
struct_name((yyvsp[(2) - (3)].c2).char2);
init_Options
(nameSpaces.getMember_ValMax(struct_namespace, struct_name));
;}
break;
case 985:
#line 8882 "ProParser.y"
{
std::string struct_namespace((yyvsp[(2) - (7)].c2).char1? (yyvsp[(2) - (7)].c2).char1 : std::string("")),
struct_name((yyvsp[(2) - (7)].c2).char2);
Free((yyvsp[(2) - (7)].c2).char1); Free((yyvsp[(2) - (7)].c2).char2);
int tag_out;
if (nameSpaces.defStruct(struct_namespace, struct_name,
floatOptions, charOptions,
tag_out, member_ValMax, (yyvsp[(3) - (7)].i)))
vyyerror(0, "Redefinition of Struct '%s::%s'",
struct_namespace.c_str(), struct_name.c_str());
(yyval.d) = (double)tag_out;
;}
break;
case 986:
#line 8898 "ProParser.y"
{ (yyval.c2).char1 = NULL; (yyval.c2).char2 = (yyvsp[(1) - (1)].c); ;}
break;
case 987:
#line 8900 "ProParser.y"
{ (yyval.c2).char1 = (yyvsp[(1) - (3)].c); (yyval.c2).char2 = (yyvsp[(3) - (3)].c); ;}
break;
case 988:
#line 8905 "ProParser.y"
{ (yyval.c) = (yyvsp[(1) - (1)].c); flag_tSTRING_alloc = 1; ;}
break;
case 989:
#line 8907 "ProParser.y"
{ (yyval.c) = (char*)"Type"; flag_tSTRING_alloc = 0; ;}
break;
case 990:
#line 8914 "ProParser.y"
{ (yyval.l) = List_Create(20,20,sizeof(double)); ;}
break;
case 991:
#line 8917 "ProParser.y"
{
(yyval.l) = List_Create(1,10,sizeof(double));
List_Add((yyval.l), &((yyvsp[(1) - (1)].d)));
;}
break;
case 992:
#line 8923 "ProParser.y"
{ (yyval.l) = (yyvsp[(1) - (1)].l); ;}
break;
case 993:
#line 8926 "ProParser.y"
{ (yyval.l) = (yyvsp[(2) - (3)].l); ;}
break;
case 994:
#line 8929 "ProParser.y"
{
(yyval.l) = (yyvsp[(3) - (4)].l);
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
(*pd) = - (*pd);
}
;}
break;
case 995:
#line 8938 "ProParser.y"
{
(yyval.l) = (yyvsp[(4) - (5)].l);
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
(*pd) *= (yyvsp[(1) - (5)].d);
}
;}
break;
case 996:
#line 8951 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(double));
List_Add((yyval.l), &((yyvsp[(1) - (1)].d)));
;}
break;
case 997:
#line 8957 "ProParser.y"
{ (yyval.l) = (yyvsp[(1) - (1)].l); ;}
break;
case 998:
#line 8960 "ProParser.y"
{ List_Add((yyval.l), &((yyvsp[(3) - (3)].d))); ;}
break;
case 999:
#line 8963 "ProParser.y"
{
for(int i = 0; i < List_Nbr((yyvsp[(3) - (3)].l)); i++){
double d;
List_Read((yyvsp[(3) - (3)].l), i, &d);
List_Add((yyval.l), &d);
}
List_Delete((yyvsp[(3) - (3)].l));
;}
break;
case 1000:
#line 8976 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(char*));
;}
break;
case 1001:
#line 8980 "ProParser.y"
{
;}
break;
case 1002:
#line 8988 "ProParser.y"
{
(yyval.l) = (yyvsp[(2) - (2)].l);
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
*pd *= -1.0;
}
;}
break;
case 1003:
#line 8997 "ProParser.y"
{
(yyval.l) = (yyvsp[(3) - (3)].l);
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
*pd *= (yyvsp[(1) - (3)].d);
}
;}
break;
case 1004:
#line 9006 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (3)].l);
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
*pd *= (yyvsp[(3) - (3)].d);
}
;}
break;
case 1005:
#line 9015 "ProParser.y"
{
(yyval.l) = (yyvsp[(3) - (3)].l);
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
if(*pd) *pd = (yyvsp[(1) - (3)].d) / *pd;
}
;}
break;
case 1006:
#line 9024 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (3)].l);
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
if((yyvsp[(3) - (3)].d)) *pd /= (yyvsp[(3) - (3)].d);
}
;}
break;
case 1007:
#line 9033 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (3)].l);
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
*pd = pow(*pd, (yyvsp[(3) - (3)].d));
}
;}
break;
case 1008:
#line 9042 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (3)].l);
if(List_Nbr((yyval.l)) == List_Nbr((yyvsp[(3) - (3)].l))){
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
double d = *(double*)List_Pointer((yyvsp[(3) - (3)].l), i);
*pd += d;
}
}
else
vyyerror(0, "Wrong list sizes %d != %d", List_Nbr((yyval.l)), List_Nbr((yyvsp[(3) - (3)].l)));
List_Delete((yyvsp[(3) - (3)].l));
;}
break;
case 1009:
#line 9057 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (3)].l);
if(List_Nbr((yyval.l)) == List_Nbr((yyvsp[(3) - (3)].l))){
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
double d = *(double*)List_Pointer((yyvsp[(3) - (3)].l), i);
*pd -= d;
}
}
else
vyyerror(0, "Wrong list sizes %d != %d", List_Nbr((yyval.l)), List_Nbr((yyvsp[(3) - (3)].l)));
List_Delete((yyvsp[(3) - (3)].l));
;}
break;
case 1010:
#line 9072 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (3)].l);
if(List_Nbr((yyval.l)) == List_Nbr((yyvsp[(3) - (3)].l))){
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
double d = *(double*)List_Pointer((yyvsp[(3) - (3)].l), i);
*pd *= d;
}
}
else
vyyerror(0, "Wrong list sizes %d != %d", List_Nbr((yyval.l)), List_Nbr((yyvsp[(3) - (3)].l)));
List_Delete((yyvsp[(3) - (3)].l));
;}
break;
case 1011:
#line 9087 "ProParser.y"
{
(yyval.l) = (yyvsp[(1) - (3)].l);
if(List_Nbr((yyval.l)) == List_Nbr((yyvsp[(3) - (3)].l))){
for(int i = 0; i < List_Nbr((yyval.l)); i++){
double *pd = (double*)List_Pointer((yyval.l), i);
double d = *(double*)List_Pointer((yyvsp[(3) - (3)].l), i);
if(d) *pd /= d;
}
}
else
vyyerror(0, "Wrong list sizes %d != %d", List_Nbr((yyval.l)), List_Nbr((yyvsp[(3) - (3)].l)));
List_Delete((yyvsp[(3) - (3)].l));
;}
break;
case 1012:
#line 9102 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(double));
for(double d = (yyvsp[(1) - (3)].d); ((yyvsp[(1) - (3)].d) < (yyvsp[(3) - (3)].d)) ? (d <= (yyvsp[(3) - (3)].d)) : (d >= (yyvsp[(3) - (3)].d));
((yyvsp[(1) - (3)].d) < (yyvsp[(3) - (3)].d)) ? (d += 1.) : (d -= 1.))
List_Add((yyval.l), &d);
;}
break;
case 1013:
#line 9110 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(double));
if(!(yyvsp[(5) - (5)].d) || ((yyvsp[(1) - (5)].d)<(yyvsp[(3) - (5)].d) && (yyvsp[(5) - (5)].d)<0) || ((yyvsp[(1) - (5)].d)>(yyvsp[(3) - (5)].d) && (yyvsp[(5) - (5)].d)>0)){
vyyerror(0, "Wrong increment in '%g : %g : %g'", (yyvsp[(1) - (5)].d), (yyvsp[(3) - (5)].d), (yyvsp[(5) - (5)].d));
List_Add((yyval.l), &((yyvsp[(1) - (5)].d)));
}
else
for(double d = (yyvsp[(1) - (5)].d); ((yyvsp[(5) - (5)].d) > 0) ? (d <= (yyvsp[(3) - (5)].d)) : (d >= (yyvsp[(3) - (5)].d)); d += (yyvsp[(5) - (5)].d))
List_Add((yyval.l), &d);
;}
break;
case 1014:
#line 9122 "ProParser.y"
{
(yyval.l) = List_Create(List_Nbr(Group_S.InitialList),20,sizeof(double));
int j;
for(int k = 0; k < List_Nbr(Group_S.InitialList); k++) {
List_Read(Group_S.InitialList, k, &j);
double d = (double)j;
List_Add((yyval.l), &d);
}
;}
break;
case 1015:
#line 9133 "ProParser.y"
{
if ((yyvsp[(1) - (3)].c2).char1) vyyerror(1, "NameSpace '%s' not used yet", (yyvsp[(1) - (3)].c2).char1);
(yyval.l) = List_Create(20,20,sizeof(double));
Constant_S.Name = (yyvsp[(1) - (3)].c2).char2;
if(!Tree_Query(ConstantTable_L, &Constant_S))
vyyerror(0, "Unknown Constant: %s", (yyvsp[(1) - (3)].c2).char2);
else
if(Constant_S.Type != VAR_LISTOFFLOAT)
// vyyerror(0, "Multi value Constant needed: %s", $1.char2);
List_Add((yyval.l), &Constant_S.Value.Float);
else
for(int i = 0; i < List_Nbr(Constant_S.Value.List); i++) {
double d;
List_Read(Constant_S.Value.List, i, &d);
List_Add((yyval.l), &d);
}
Free((yyvsp[(1) - (3)].c2).char1); Free((yyvsp[(1) - (3)].c2).char2);
;}
break;
case 1016:
#line 9153 "ProParser.y"
{
if ((yyvsp[(1) - (6)].c2).char1) vyyerror(1, "NameSpace '%s' not used yet", (yyvsp[(1) - (6)].c2).char1);
(yyval.l) = List_Create(20,20,sizeof(double));
Constant_S.Name = (yyvsp[(1) - (6)].c2).char2;
if(!Tree_Query(ConstantTable_L, &Constant_S))
vyyerror(0, "Unknown Constant: %s", (yyvsp[(1) - (6)].c2).char2);
else
if(Constant_S.Type != VAR_LISTOFFLOAT)
vyyerror(0, "Multi value Constant needed: %s", (yyvsp[(1) - (6)].c2).char2);
else
for(int i = 0; i < List_Nbr((yyvsp[(4) - (6)].l)); i++) {
int j = (int)(*(double*)List_Pointer((yyvsp[(4) - (6)].l), i));
if(j >= 0 && j < List_Nbr(Constant_S.Value.List)){
double d;
List_Read(Constant_S.Value.List, j, &d);
List_Add((yyval.l), &d);
}
else{
vyyerror(0, "Index %d out of range", j);
double d = 0.;
List_Add((yyval.l), &d);
}
}
List_Delete((yyvsp[(4) - (6)].l));
Free((yyvsp[(1) - (6)].c2).char1); Free((yyvsp[(1) - (6)].c2).char2);
;}
break;
case 1017:
#line 9181 "ProParser.y"
{
(yyval.l) = Treat_Struct_FullName_dot_tSTRING_ListOfFloat((yyvsp[(1) - (5)].c2).char1, (yyvsp[(1) - (5)].c2).char2, (yyvsp[(3) - (5)].c));
;}
break;
case 1018:
#line 9187 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(double));
Constant_S.Name = (yyvsp[(3) - (4)].c);
if(!Tree_Query(ConstantTable_L, &Constant_S))
vyyerror(0, "Unknown Constant: %s", (yyvsp[(3) - (4)].c));
else
if(Constant_S.Type != VAR_LISTOFFLOAT)
vyyerror(0, "Multi value Constant needed: %s", (yyvsp[(3) - (4)].c));
else
for(int i = 0; i < List_Nbr(Constant_S.Value.List); i++) {
double d;
List_Read(Constant_S.Value.List, i, &d);
List_Add((yyval.l), &d);
}
;}
break;
case 1019:
#line 9204 "ProParser.y"
{
(yyval.l) = (yyvsp[(3) - (4)].l);
;}
break;
case 1020:
#line 9209 "ProParser.y"
{
(yyval.l) = (yyvsp[(4) - (6)].l);
;}
break;
case 1021:
#line 9214 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(double));
Constant1_S.Name = (yyvsp[(3) - (6)].c); Constant2_S.Name = (yyvsp[(5) - (6)].c);
if(!Tree_Query(ConstantTable_L, &Constant1_S)) {
vyyerror(0, "Unknown Constant: %s", (yyvsp[(3) - (6)].c));
}
else
if(Constant1_S.Type != VAR_LISTOFFLOAT) {
vyyerror(0, "Multi value Constant needed: %s", (yyvsp[(3) - (6)].c));
}
else {
if(!Tree_Query(ConstantTable_L, &Constant2_S)) {
vyyerror(0, "Unknown Constant: %s", (yyvsp[(5) - (6)].c));
}
else
if(Constant2_S.Type != VAR_LISTOFFLOAT) {
vyyerror(0, "Multi value Constant needed: %s", (yyvsp[(5) - (6)].c));
}
else {
if(List_Nbr(Constant1_S.Value.List) !=
List_Nbr(Constant2_S.Value.List)) {
vyyerror(0, "Different dimensions of Multi value Constants: "
"%s {%d}, %s {%d}",
(yyvsp[(3) - (6)].c), List_Nbr(Constant1_S.Value.List),
(yyvsp[(5) - (6)].c), List_Nbr(Constant2_S.Value.List));
}
else {
for(int i = 0; i < List_Nbr(Constant1_S.Value.List); i++) {
double d;
List_Read(Constant1_S.Value.List, i, &d);
List_Add((yyval.l), &d);
List_Read(Constant2_S.Value.List, i, &d);
List_Add((yyval.l), &d);
}
}
}
}
Free((yyvsp[(3) - (6)].c)); Free((yyvsp[(5) - (6)].c));
;}
break;
case 1022:
#line 9255 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(double));
if(List_Nbr((yyvsp[(3) - (6)].l)) != List_Nbr((yyvsp[(5) - (6)].l))) {
vyyerror(0, "Different dimensions of lists: %d != %d",
List_Nbr((yyvsp[(3) - (6)].l)), List_Nbr((yyvsp[(5) - (6)].l)));
}
else {
for(int i = 0; i < List_Nbr((yyvsp[(3) - (6)].l)); i++) {
double d;
List_Read((yyvsp[(3) - (6)].l), i, &d);
List_Add((yyval.l), &d);
List_Read((yyvsp[(5) - (6)].l), i, &d);
List_Add((yyval.l), &d);
}
}
List_Delete((yyvsp[(3) - (6)].l));
List_Delete((yyvsp[(5) - (6)].l));
;}
break;
case 1023:
#line 9275 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(double));
for(int i = 0; i < (int)(yyvsp[(7) - (8)].d); i++) {
double d = (yyvsp[(3) - (8)].d) + ((yyvsp[(5) - (8)].d)-(yyvsp[(3) - (8)].d))*(double)i/((yyvsp[(7) - (8)].d)-1);
List_Add((yyval.l), &d);
}
;}
break;
case 1024:
#line 9284 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(double));
for(int i = 0; i < (int)(yyvsp[(7) - (8)].d); i++) {
double d = pow(10,(yyvsp[(3) - (8)].d) + ((yyvsp[(5) - (8)].d)-(yyvsp[(3) - (8)].d))*(double)i/((yyvsp[(7) - (8)].d)-1));
List_Add((yyval.l), &d);
}
;}
break;
case 1025:
#line 9293 "ProParser.y"
{
Message::Barrier();
FILE *File;
(yyval.l) = List_Create(100, 100, sizeof(double));
if(!(File = FOpen(Fix_RelativePath((yyvsp[(3) - (4)].c)).c_str(), "rb"))){
vyyerror(1, "Could not open file '%s'", (yyvsp[(3) - (4)].c));
}
else{
double d;
while(!feof(File)){
int ret = fscanf(File, "%lf", &d);
if(ret == 1){
List_Add((yyval.l), &d);
}
else if(ret == EOF){
break;
}
else{
char dummy[1024];
fscanf(File, "%s", dummy);
vyyerror(1, "Ignoring '%s' in file '%s'", dummy, (yyvsp[(3) - (4)].c));
}
}
fclose(File);
}
Free((yyvsp[(3) - (4)].c));
;}
break;
case 1026:
#line 9325 "ProParser.y"
{
char tmpstr[256];
sprintf(tmpstr, "_%d", (int)(yyvsp[(4) - (5)].d));
(yyval.c) = (char *)Malloc((strlen((yyvsp[(1) - (5)].c))+strlen(tmpstr)+1)*sizeof(char));
strcpy((yyval.c), (yyvsp[(1) - (5)].c)); strcat((yyval.c), tmpstr);
Free((yyvsp[(1) - (5)].c));
;}
break;
case 1027:
#line 9334 "ProParser.y"
{
char tmpstr[256];
sprintf(tmpstr, "_%d", (int)(yyvsp[(4) - (5)].d));
(yyval.c) = (char *)Malloc((strlen((yyvsp[(1) - (5)].c))+strlen(tmpstr)+1)*sizeof(char)) ;
strcpy((yyval.c), (yyvsp[(1) - (5)].c)) ; strcat((yyval.c), tmpstr) ;
Free((yyvsp[(1) - (5)].c));
;}
break;
case 1028:
#line 9343 "ProParser.y"
{
char tmpstr[256];
sprintf(tmpstr, "_%d", (int)(yyvsp[(7) - (8)].d));
(yyval.c) = (char *)Malloc((strlen((yyvsp[(3) - (8)].c))+strlen(tmpstr)+1)*sizeof(char));
strcpy((yyval.c), (yyvsp[(3) - (8)].c)); strcat((yyval.c), tmpstr);
Free((yyvsp[(3) - (8)].c));
;}
break;
case 1029:
#line 9355 "ProParser.y"
{ (yyval.c) = (yyvsp[(1) - (1)].c); ;}
break;
case 1030:
#line 9358 "ProParser.y"
{ (yyval.c) = (yyvsp[(1) - (1)].c); ;}
break;
case 1031:
#line 9362 "ProParser.y"
{ (yyval.c) = (yyvsp[(3) - (4)].c); ;}
break;
case 1032:
#line 9367 "ProParser.y"
{ (yyval.c) = (yyvsp[(1) - (1)].c); ;}
break;
case 1033:
#line 9370 "ProParser.y"
{ (yyval.c) = (yyvsp[(3) - (4)].c); ;}
break;
case 1034:
#line 9373 "ProParser.y"
{
(yyval.c) = (yyvsp[(1) - (1)].c);
;}
break;
case 1035:
#line 9378 "ProParser.y"
{
int i = 0;
while ((yyvsp[(3) - (4)].c)[i]) {
(yyvsp[(3) - (4)].c)[i] = toupper((yyvsp[(3) - (4)].c)[i]);
i++;
}
(yyval.c) = (yyvsp[(3) - (4)].c);
;}
break;
case 1036:
#line 9388 "ProParser.y"
{
int i = 0;
while ((yyvsp[(3) - (4)].c)[i]) {
(yyvsp[(3) - (4)].c)[i] = tolower((yyvsp[(3) - (4)].c)[i]);
i++;
}
(yyval.c) = (yyvsp[(3) - (4)].c);
;}
break;
case 1037:
#line 9398 "ProParser.y"
{
int i=0;
while ((yyvsp[(3) - (4)].c)[i]) {
if (i > 0 && (yyvsp[(3) - (4)].c)[i-1] != '_')
(yyvsp[(3) - (4)].c)[i] = tolower((yyvsp[(3) - (4)].c)[i]);
i++;
}
(yyval.c) = (yyvsp[(3) - (4)].c);
;}
break;
case 1038:
#line 9409 "ProParser.y"
{
int size = 1;
for(int i = 0; i < List_Nbr((yyvsp[(3) - (4)].l)); i++){
char *s;
List_Read((yyvsp[(3) - (4)].l), i, &s);
size += strlen(s) + 1;
}
(yyval.c) = (char*)Malloc(size * sizeof(char));
(yyval.c)[0] = '\0';
for(int i = 0; i < List_Nbr((yyvsp[(3) - (4)].l)); i++){
char *s;
List_Read((yyvsp[(3) - (4)].l), i, &s);
strcat((yyval.c), s);
Free(s);//FIXME: DONE with added function strEmpty()
if(i != List_Nbr((yyvsp[(3) - (4)].l)) - 1) strcat((yyval.c), "\n");
}
List_Delete((yyvsp[(3) - (4)].l));
;}
break;
case 1039:
#line 9429 "ProParser.y"
{
if((yyvsp[(3) - (8)].d)){
(yyval.c) = (yyvsp[(5) - (8)].c);
Free((yyvsp[(7) - (8)].c));
}
else{
(yyval.c) = (yyvsp[(7) - (8)].c);
Free((yyvsp[(5) - (8)].c));
}
;}
break;
case 1040:
#line 9441 "ProParser.y"
{
std::string in = (yyvsp[(3) - (8)].c);
std::string out = in.substr((int)(yyvsp[(5) - (8)].d), (int)(yyvsp[(7) - (8)].d));
(yyval.c) = (char *)Malloc((out.size() + 1) * sizeof(char));
strcpy((yyval.c), out.c_str());
Free((yyvsp[(3) - (8)].c));
;}
break;
case 1041:
#line 9450 "ProParser.y"
{
std::string in = (yyvsp[(3) - (6)].c);
std::string out = in.substr((int)(yyvsp[(5) - (6)].d), std::string::npos);
(yyval.c) = (char *)Malloc((out.size() + 1) * sizeof(char));
strcpy((yyval.c), out.c_str());
Free((yyvsp[(3) - (6)].c));
;}
break;
case 1042:
#line 9459 "ProParser.y"
{
(yyval.c) = (yyvsp[(3) - (4)].c);
;}
break;
case 1043:
#line 9464 "ProParser.y"
{
char tmpstr[256];
int i = Print_ListOfDouble((yyvsp[(3) - (6)].c),(yyvsp[(5) - (6)].l),tmpstr);
if(i<0){
vyyerror(0, "Too few arguments in Sprintf");
(yyval.c) = (yyvsp[(3) - (6)].c);
}
else if(i>0){
vyyerror(0, "Too many arguments (%d) in Sprintf", i);
(yyval.c) = (yyvsp[(3) - (6)].c);
}
else{
(yyval.c) = (char*)Malloc((strlen(tmpstr)+1)*sizeof(char));
strcpy((yyval.c), tmpstr);
Free((yyvsp[(3) - (6)].c));
}
List_Delete((yyvsp[(5) - (6)].l));
;}
break;
case 1044:
#line 9484 "ProParser.y"
{
time_t date_info;
time(&date_info);
(yyval.c) = (char *)Malloc((strlen(ctime(&date_info))+1)*sizeof(char));
strcpy((yyval.c), ctime(&date_info));
(yyval.c)[strlen((yyval.c))-1] = 0;
;}
break;
case 1045:
#line 9493 "ProParser.y"
{
char str_date[80];
time_t rawtime;
struct tm * timeinfo;
time (&rawtime);
timeinfo = localtime (&rawtime);
strftime (str_date, 80, (yyvsp[(3) - (4)].c), timeinfo);
(yyval.c) = (char *)Malloc((strlen(str_date)+1)*sizeof(char));
strcpy((yyval.c), str_date);
;}
break;
case 1046:
#line 9506 "ProParser.y"
{
std::string action = Message::GetOnelabAction();
(yyval.c) = (char *)Malloc(action.size() + 1);
strcpy((yyval.c), action.c_str());
;}
break;
case 1047:
#line 9513 "ProParser.y"
{
(yyval.c) = strSave((char*)"GetDP");
;}
break;
case 1048:
#line 9518 "ProParser.y"
{
(yyval.c) = strSave(getdp_yyname.c_str());
;}
break;
case 1049:
#line 9523 "ProParser.y"
{
std::string tmp = GetDirName(GetFullPath(getdp_yyname));
(yyval.c) = (char*)Malloc((tmp.size() + 1) * sizeof(char));
strcpy((yyval.c), tmp.c_str());
;}
break;
case 1050:
#line 9530 "ProParser.y"
{
(yyval.c) = strSave(GetFullPath((yyvsp[(3) - (4)].c)).c_str());
Free((yyvsp[(3) - (4)].c));
;}
break;
case 1051:
#line 9536 "ProParser.y"
{
(yyval.c) = strSave(GetDirName((yyvsp[(3) - (4)].c)).c_str());
Free((yyvsp[(3) - (4)].c));
;}
break;
case 1052:
#line 9542 "ProParser.y"
{
(yyval.c) = strSave(GetBaseName(getdp_yyname).c_str());
;}
break;
case 1053:
#line 9547 "ProParser.y"
{
(yyval.c) = strSave(Fix_RelativePath((yyvsp[(3) - (4)].c)).c_str());
Free((yyvsp[(3) - (4)].c));
;}
break;
case 1054:
#line 9553 "ProParser.y"
{ init_Options(); ;}
break;
case 1055:
#line 9555 "ProParser.y"
{
Constant_S.Name = (char*)""; Constant_S.Type = VAR_CHAR;
Constant_S.Value.Char = (yyvsp[(3) - (6)].c);
Message::ExchangeOnelabParameter(&Constant_S, floatOptions, charOptions);
(yyval.c) = strSave(Constant_S.Value.Char);
Free((yyvsp[(3) - (6)].c));
;}
break;
case 1056:
#line 9564 "ProParser.y"
{
(yyval.c) = strSave(Message::GetOnelabString((yyvsp[(3) - (4)].c), "").c_str());
Free((yyvsp[(3) - (4)].c));
;}
break;
case 1057:
#line 9570 "ProParser.y"
{
(yyval.c) = strSave(Message::GetOnelabString((yyvsp[(3) - (6)].c), (yyvsp[(5) - (6)].c)).c_str());
Free((yyvsp[(3) - (6)].c));
Free((yyvsp[(5) - (6)].c));
;}
break;
case 1058:
#line 9578 "ProParser.y"
{
(yyval.c) = Treat_Struct_FullName_String(NULL, (yyvsp[(3) - (5)].c2).char2, 1, 0, (yyvsp[(4) - (5)].c), 2);
;}
break;
case 1059:
#line 9583 "ProParser.y"
{
(yyval.c) = Treat_Struct_FullName_dot_tSTRING_String((yyvsp[(3) - (7)].c2).char1, (yyvsp[(3) - (7)].c2).char2, (yyvsp[(5) - (7)].c), 0, (yyvsp[(6) - (7)].c), 2);
;}
break;
case 1060:
#line 9588 "ProParser.y"
{
const std::string * key_struct = NULL;
switch (nameSpaces.get_key_struct_from_tag(struct_namespace,
(int)(yyvsp[(3) - (4)].d), key_struct)) {
case 0:
(yyval.c) = strSave(key_struct->c_str());
break;
case 1:
vyyerror(1, "Unknown NameSpace '%s' of Struct", struct_namespace.c_str());
(yyval.c) = strEmpty();
break;
case 2:
vyyerror(1, "Unknown Struct of Tag %d", (int)(yyvsp[(3) - (4)].d));
(yyval.c) = strEmpty();
break;
default:
(yyval.c) = strEmpty();
break;
}
;}
break;
case 1061:
#line 9612 "ProParser.y"
{ struct_namespace = std::string(""); (yyval.d) = (yyvsp[(2) - (2)].d); ;}
break;
case 1062:
#line 9614 "ProParser.y"
{ struct_namespace = (yyvsp[(1) - (4)].c); Free((yyvsp[(1) - (4)].c)); (yyval.d) = (yyvsp[(4) - (4)].d); ;}
break;
case 1063:
#line 9621 "ProParser.y"
{ (yyval.c) = (yyvsp[(1) - (1)].c); ;}
break;
case 1064:
#line 9624 "ProParser.y"
{
if ((yyvsp[(1) - (1)].c2).char1) vyyerror(1, "NameSpace '%s' not used yet", (yyvsp[(1) - (1)].c2).char1);
// No need to extend to Struct_FullName (a Tag is not a String)
(yyval.c) = Treat_Struct_FullName_String(NULL, (yyvsp[(1) - (1)].c2).char2);
;}
break;
case 1065:
#line 9631 "ProParser.y"
{
(yyval.c) = Treat_Struct_FullName_String((yyvsp[(1) - (4)].c2).char1, (yyvsp[(1) - (4)].c2).char2, 2, (int)(yyvsp[(3) - (4)].d));
;}
break;
case 1066:
#line 9636 "ProParser.y"
{
(yyval.c) = Treat_Struct_FullName_dot_tSTRING_String((yyvsp[(1) - (3)].c2).char1, (yyvsp[(1) - (3)].c2).char2, (yyvsp[(3) - (3)].c));
;}
break;
case 1067:
#line 9641 "ProParser.y"
{
(yyval.c) = Treat_Struct_FullName_dot_tSTRING_String((yyvsp[(1) - (6)].c2).char1, (yyvsp[(1) - (6)].c2).char2, (yyvsp[(3) - (6)].c), (int)(yyvsp[(5) - (6)].d));
;}
break;
case 1068:
#line 9648 "ProParser.y"
{ (yyval.l) = (yyvsp[(3) - (4)].l); ;}
break;
case 1069:
#line 9653 "ProParser.y"
{ (yyval.l) = (yyvsp[(1) - (1)].l); ;}
break;
case 1070:
#line 9655 "ProParser.y"
{ (yyval.l) = (yyvsp[(1) - (1)].l); ;}
break;
case 1071:
#line 9660 "ProParser.y"
{ (yyval.l) = (yyvsp[(2) - (3)].l); ;}
break;
case 1072:
#line 9665 "ProParser.y"
{
(yyval.l) = List_Create(20,20,sizeof(char*));
List_Add((yyval.l), &((yyvsp[(1) - (1)].c)));
;}
break;
case 1073:
#line 9670 "ProParser.y"
{ (yyval.l) = (yyvsp[(1) - (1)].l); ;}
break;
case 1074:
#line 9672 "ProParser.y"
{ List_Add((yyval.l), &((yyvsp[(3) - (3)].c))); ;}
break;
case 1075:
#line 9674 "ProParser.y"
{
for(int i = 0; i < List_Nbr((yyvsp[(3) - (3)].l)); i++){
char* c;
List_Read((yyvsp[(3) - (3)].l), i, &c);
List_Add((yyval.l), &c);
}
List_Delete((yyvsp[(3) - (3)].l));
;}
break;
case 1076:
#line 9688 "ProParser.y"
{ (yyval.c) = (char*)"("; ;}
break;
case 1077:
#line 9688 "ProParser.y"
{ (yyval.c) = (char*)"["; ;}
break;
case 1078:
#line 9689 "ProParser.y"
{ (yyval.c) = (char*)")"; ;}
break;
case 1079:
#line 9689 "ProParser.y"
{ (yyval.c) = (char*)"]"; ;}
break;
case 1080:
#line 9694 "ProParser.y"
{
int size = 1;
for(int i = 0; i < List_Nbr((yyvsp[(3) - (4)].l)); i++){
char *s;
List_Read((yyvsp[(3) - (4)].l), i, &s);
size += strlen(s) + 1;
}
(yyval.c) = (char*)Malloc(size * sizeof(char));
(yyval.c)[0] = '\0';
for(int i = 0; i < List_Nbr((yyvsp[(3) - (4)].l)); i++){
char *s;
List_Read((yyvsp[(3) - (4)].l), i, &s);
strcat((yyval.c), s);
Free(s);
}
List_Delete((yyvsp[(3) - (4)].l));
;}
break;
case 1081:
#line 9716 "ProParser.y"
{
if ((yyvsp[(3) - (6)].c) != NULL && (yyvsp[(5) - (6)].c) != NULL) {
(yyval.i) = strcmp((yyvsp[(3) - (6)].c), (yyvsp[(5) - (6)].c));
}
else {
vyyerror(0, "Undefined argument for StrCmp function") ; (yyval.i) = 1 ;
}
Free((yyvsp[(3) - (6)].c));
Free((yyvsp[(5) - (6)].c));
;}
break;
case 1082:
#line 9727 "ProParser.y"
{
if ((yyvsp[(3) - (4)].c) != NULL) {
(yyval.i) = strlen((yyvsp[(3) - (4)].c));
}
else {
vyyerror(0, "Undefined argument for StrLen function") ; (yyval.i) = 0 ;
}
Free((yyvsp[(3) - (4)].c));
;}
break;
case 1083:
#line 9737 "ProParser.y"
{
std::string s((yyvsp[(3) - (6)].c)), substr((yyvsp[(5) - (6)].c));
if(s.find(substr) != std::string::npos)
(yyval.i) = 1.;
else
(yyval.i) = 0.;
Free((yyvsp[(3) - (6)].c));
Free((yyvsp[(5) - (6)].c));
;}
break;
case 1084:
#line 9751 "ProParser.y"
{
int n = 0;
for(int i = 0; i < List_Nbr(Problem_S.Group); i++) {
n += List_Nbr(((struct Group *)List_Pointer(Problem_S.Group, i))
->InitialList) ;
}
(yyval.i) = n;
;}
break;
case 1085:
#line 9760 "ProParser.y"
{
int i;
if ( (i = List_ISearchSeq(Problem_S.Group, (yyvsp[(3) - (4)].c), fcmp_Group_Name)) >= 0 ) {
(yyval.i) = List_Nbr(((struct Group *)List_Pointer(Problem_S.Group, i))
->InitialList) ;
}
else {
vyyerror(0, "Unknown Group: %s", (yyvsp[(3) - (4)].c)) ; (yyval.i) = 0 ;
}
;}
break;
case 1086:
#line 9771 "ProParser.y"
{
int i, j, indexInGroup;
indexInGroup = (int)(yyvsp[(5) - (6)].d);
if ( (i = List_ISearchSeq(Problem_S.Group, (yyvsp[(3) - (6)].c), fcmp_Group_Name)) >= 0 ) {
if (indexInGroup >= 1 &&
indexInGroup <= List_Nbr(((struct Group *)List_Pointer(Problem_S.Group, i))
->InitialList)) {
List_Read(((struct Group *)List_Pointer(Problem_S.Group, i))->InitialList,
indexInGroup-1, &j) ;
(yyval.i) = j;
}
else {
vyyerror(0, "GetRegion: Index out of range [1..%d]",
List_Nbr(((struct Group *)List_Pointer(Problem_S.Group, i))
->InitialList)) ;
(yyval.i) = 0 ;
}
}
else {
vyyerror(0, "Unknown Group: %s", (yyvsp[(3) - (6)].c)) ; (yyval.i) = 0 ;
}
;}
break;
case 1087:
#line 9797 "ProParser.y"
{ (yyval.i) = 99; ;}
break;
case 1088:
#line 9799 "ProParser.y"
{ (yyval.i) = (int)(yyvsp[(2) - (2)].d); ;}
break;
case 1089:
#line 9804 "ProParser.y"
{ (yyval.i) = 0; ;}
break;
case 1090:
#line 9806 "ProParser.y"
{ (yyval.i) = (yyvsp[(2) - (3)].i); ;}
break;
/* Line 1267 of yacc.c. */
#line 19160 "ProParser.tab.c"
default: break;
}
YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc);
YYPOPSTACK (yylen);
yylen = 0;
YY_STACK_PRINT (yyss, yyssp);
*++yyvsp = yyval;
/* Now `shift' the result of the reduction. Determine what state
that goes to, based on the state we popped back to and the rule
number reduced by. */
yyn = yyr1[yyn];
yystate = yypgoto[yyn - YYNTOKENS] + *yyssp;
if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp)
yystate = yytable[yystate];
else
yystate = yydefgoto[yyn - YYNTOKENS];
goto yynewstate;
/*------------------------------------.
| yyerrlab -- here on detecting error |
`------------------------------------*/
yyerrlab:
/* If not already recovering from an error, report this error. */
if (!yyerrstatus)
{
++yynerrs;
#if ! YYERROR_VERBOSE
yyerror (YY_("syntax error"));
#else
{
YYSIZE_T yysize = yysyntax_error (0, yystate, yychar);
if (yymsg_alloc < yysize && yymsg_alloc < YYSTACK_ALLOC_MAXIMUM)
{
YYSIZE_T yyalloc = 2 * yysize;
if (! (yysize <= yyalloc && yyalloc <= YYSTACK_ALLOC_MAXIMUM))
yyalloc = YYSTACK_ALLOC_MAXIMUM;
if (yymsg != yymsgbuf)
YYSTACK_FREE (yymsg);
yymsg = (char *) YYSTACK_ALLOC (yyalloc);
if (yymsg)
yymsg_alloc = yyalloc;
else
{
yymsg = yymsgbuf;
yymsg_alloc = sizeof yymsgbuf;
}
}
if (0 < yysize && yysize <= yymsg_alloc)
{
(void) yysyntax_error (yymsg, yystate, yychar);
yyerror (yymsg);
}
else
{
yyerror (YY_("syntax error"));
if (yysize != 0)
goto yyexhaustedlab;
}
}
#endif
}
if (yyerrstatus == 3)
{
/* If just tried and failed to reuse look-ahead token after an
error, discard it. */
if (yychar <= YYEOF)
{
/* Return failure if at end of input. */
if (yychar == YYEOF)
YYABORT;
}
else
{
yydestruct ("Error: discarding",
yytoken, &yylval);
yychar = YYEMPTY;
}
}
/* Else will try to reuse look-ahead token after shifting the error
token. */
goto yyerrlab1;
/*---------------------------------------------------.
| yyerrorlab -- error raised explicitly by YYERROR. |
`---------------------------------------------------*/
yyerrorlab:
/* Pacify compilers like GCC when the user code never invokes
YYERROR and the label yyerrorlab therefore never appears in user
code. */
if (/*CONSTCOND*/ 0)
goto yyerrorlab;
/* Do not reclaim the symbols of the rule which action triggered
this YYERROR. */
YYPOPSTACK (yylen);
yylen = 0;
YY_STACK_PRINT (yyss, yyssp);
yystate = *yyssp;
goto yyerrlab1;
/*-------------------------------------------------------------.
| yyerrlab1 -- common code for both syntax error and YYERROR. |
`-------------------------------------------------------------*/
yyerrlab1:
yyerrstatus = 3; /* Each real token shifted decrements this. */
for (;;)
{
yyn = yypact[yystate];
if (yyn != YYPACT_NINF)
{
yyn += YYTERROR;
if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR)
{
yyn = yytable[yyn];
if (0 < yyn)
break;
}
}
/* Pop the current state because it cannot handle the error token. */
if (yyssp == yyss)
YYABORT;
yydestruct ("Error: popping",
yystos[yystate], yyvsp);
YYPOPSTACK (1);
yystate = *yyssp;
YY_STACK_PRINT (yyss, yyssp);
}
if (yyn == YYFINAL)
YYACCEPT;
*++yyvsp = yylval;
/* Shift the error token. */
YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp);
yystate = yyn;
goto yynewstate;
/*-------------------------------------.
| yyacceptlab -- YYACCEPT comes here. |
`-------------------------------------*/
yyacceptlab:
yyresult = 0;
goto yyreturn;
/*-----------------------------------.
| yyabortlab -- YYABORT comes here. |
`-----------------------------------*/
yyabortlab:
yyresult = 1;
goto yyreturn;
#ifndef yyoverflow
/*-------------------------------------------------.
| yyexhaustedlab -- memory exhaustion comes here. |
`-------------------------------------------------*/
yyexhaustedlab:
yyerror (YY_("memory exhausted"));
yyresult = 2;
/* Fall through. */
#endif
yyreturn:
if (yychar != YYEOF && yychar != YYEMPTY)
yydestruct ("Cleanup: discarding lookahead",
yytoken, &yylval);
/* Do not reclaim the symbols of the rule which action triggered
this YYABORT or YYACCEPT. */
YYPOPSTACK (yylen);
YY_STACK_PRINT (yyss, yyssp);
while (yyssp != yyss)
{
yydestruct ("Cleanup: popping",
yystos[*yyssp], yyvsp);
YYPOPSTACK (1);
}
#ifndef yyoverflow
if (yyss != yyssa)
YYSTACK_FREE (yyss);
#endif
#if YYERROR_VERBOSE
if (yymsg != yymsgbuf)
YYSTACK_FREE (yymsg);
#endif
/* Make sure YYID is used. */
return YYID (yyresult);
}
#line 9809 "ProParser.y"
// This is a hack... Bison redefines 'const' if !__cplusplus and !__STDC__
#ifdef const
#undef const
#endif
void Alloc_ParserVariables()
{
if(!ConstantTable_L) {
ConstantTable_L = Tree_Create(sizeof(struct Constant), fcmp_Constant);
for(std::map<std::string, std::vector<double> >::iterator it =
CommandLineNumbers.begin(); it != CommandLineNumbers.end(); it++){
std::vector<double> &v(it->second);
Constant_S.Name = strSave(it->first.c_str());
if(v.size() == 1){
Message::Info("Adding number %s = %g", it->first.c_str(), v[0]);
Constant_S.Type = VAR_FLOAT;
Constant_S.Value.Float = v[0];
}
else{
Message::Info("Adding list of numbers %s", it->first.c_str());
Constant_S.Type = VAR_LISTOFFLOAT;
Constant_S.Value.List = List_Create(v.size(), 1, sizeof(double));
for(unsigned int i = 0; i < v.size(); i ++)
List_Add(Constant_S.Value.List, &v[i]);
}
Tree_Add(ConstantTable_L, &Constant_S);
}
for(std::map<std::string, std::vector<std::string> >::iterator it = CommandLineStrings.begin();
it != CommandLineStrings.end(); it++){
std::vector<std::string> &v(it->second);
Constant_S.Name = strSave(it->first.c_str());
if(v.size() == 1){
Message::Info("Adding string %s = \"%s\"", it->first.c_str(), v[0].c_str());
Constant_S.Type = VAR_CHAR;
Constant_S.Value.Char = strSave(v[0].c_str());
}
else{
Message::Info("Adding list of strings %s", it->first.c_str());
Constant_S.Type = VAR_LISTOFCHAR;
Constant_S.Value.List = List_Create(v.size(), 1, sizeof(char*));
for(unsigned int i = 0; i < v.size(); i ++)
List_Add(Constant_S.Value.List, strSave(v[i].c_str()));
}
Tree_Add(ConstantTable_L, &Constant_S);
}
ListOfInt_L = List_Create(20, 10, sizeof(int));
ListOfPointer_L = List_Create(10, 10, sizeof(void *));
ListOfPointer2_L= List_Create(10, 10, sizeof(void *));
ListOfChar_L = List_Create(128, 128, sizeof(char));
ListOfFormulation = List_Create(5,5, sizeof(int));
ListOfBasisFunction = List_Create(5,5, sizeof(List_T *));
ListOfEntityIndex = List_Create(5,5, sizeof(int));
}
}
void Free_ParserVariables()
{
List_T *tmp = Tree2List(ConstantTable_L);
for(int i = 0; i < List_Nbr(tmp); i++){
Constant *Constant_P = (struct Constant*)List_Pointer(tmp, i);
std::string name = Constant_P->Name;
switch(Constant_P->Type){
case VAR_FLOAT:
if(!GetDPNumbers.count(name))
GetDPNumbers[name] = std::vector<double>(1, Constant_P->Value.Float);
break;
case VAR_LISTOFFLOAT:
if(!GetDPNumbers.count(name)){
std::vector<double> v;
for(int j = 0; j < List_Nbr(Constant_P->Value.List); j++){
double d;
List_Read(Constant_P->Value.List, j, &d);
v.push_back(d);
}
GetDPNumbers[name] = v;
}
break;
case VAR_CHAR:
if(!GetDPStrings.count(name))
GetDPStrings[name] = std::vector<std::string>(1, Constant_P->Value.Char);
break;
case VAR_LISTOFCHAR:
if(!GetDPStrings.count(name)){
std::vector<std::string> v;
for(int j = 0; j < List_Nbr(Constant_P->Value.List); j++){
char *s;
List_Read(Constant_P->Value.List, j, &s);
v.push_back(s);
}
GetDPStrings[name] = v;
}
break;
}
}
List_Delete(tmp);
Tree_Delete(ConstantTable_L); ConstantTable_L = 0;
List_Delete(ListOfInt_L); ListOfInt_L = 0;
List_Delete(ListOfPointer_L); ListOfPointer_L = 0;
List_Delete(ListOfPointer2_L); ListOfPointer2_L = 0;
List_Delete(ListOfChar_L); ListOfChar_L = 0;
List_Delete(ListOfFormulation); ListOfFormulation = 0;
List_Delete(ListOfBasisFunction); ListOfBasisFunction = 0;
List_Delete(ListOfEntityIndex); ListOfEntityIndex = 0;
getdp_yyname = "";
strcpy(getdp_yyincludename, "");
getdp_yylinenum = 0;
getdp_yycolnum = 0;
getdp_yyincludenum = 0;
getdp_yyerrorlevel = 0;
CommandLineNumbers.clear();
CommandLineStrings.clear();
Num_BasisFunction = 1;
num_include = 0; level_include = 0;
}
/* A d d _ G r o u p & C o . */
int Add_Group(struct Group *Group_P, char *Name, bool Flag_Add,
int Flag_Plus, int Num_Index)
{
if(!Problem_S.Group)
Problem_S.Group = List_Create(50, 50, sizeof (struct Group));
char tmpstr[256];
switch (Flag_Plus) {
case 1 :
sprintf(tmpstr, "_%s_%d", Name, List_Nbr(Problem_S.Group));
Group_P->Name = strSave(tmpstr);
break;
case 2 :
sprintf(tmpstr, "%s_%d", Name, Num_Index);
Group_P->Name = strSave(tmpstr);
break;
default :
Group_P->Name = Name;
}
int i;
if((i = List_ISearchSeq(Problem_S.Group, Group_P->Name, fcmp_Group_Name)) < 0) {
i = Group_P->Num = List_Nbr(Problem_S.Group);
Group_P->ExtendedList = Group_P->ExtendedSuppList = Group_P->ExtendedSuppList2 = NULL;
List_Add(Problem_S.Group, Group_P);
}
else if(Flag_Add) {
List_T *InitialList = ((struct Group *)List_Pointer(Problem_S.Group, i))->InitialList;
for(int j = 0; j < List_Nbr(Group_P->InitialList); j++) {
List_Add(InitialList, (int *)List_Pointer(Group_P->InitialList, j));
}
}
else List_Write(Problem_S.Group, i, Group_P);
return i;
}
int Num_Group(struct Group *Group_P, char *Name, int Num_Group)
{
if (Num_Group >= 0) /* OK */;
else if(Num_Group == -1) Num_Group = Add_Group(Group_P, Name, false, 1, 0);
else vyyerror(0, "Bad Group right hand side");
return Num_Group;
}
void Fill_GroupInitialListFromString(List_T *list, const char *str)
{
bool found = false;
// try to find a group with name "str"
for(int i = 0; i < List_Nbr(Problem_S.Group); i++){
struct Group *Group_P = (struct Group*)List_Pointer(Problem_S.Group, i);
if(!strcmp(str, Group_P->Name)){
List_Copy(Group_P->InitialList, list);
found = true;
break;
}
}
// try to find a constant with name "str"
Constant_S.Name = (char*)str;
Constant *Constant_P = (Constant*)Tree_PQuery(ConstantTable_L, &Constant_S);
if(Constant_P){
switch(Constant_P->Type){
case VAR_FLOAT:
{
int num = (int)Constant_P->Value.Float;
List_Add(list, &num);
}
found = true;
break;
case VAR_LISTOFFLOAT:
for(int j = 0; j < List_Nbr(Constant_P->Value.List); j++){
double d;
List_Read(Constant_P->Value.List, j, &d);
int num = (int)d;
List_Add(list, &num);
}
found = true;
break;
}
}
// if not, try to convert "str" to an integer
if(!found){
int num = atoi(str);
if(num > 0){
List_Add(list, &num);
found = true;
}
}
if(!found) vyyerror(0, "Unknown Group '%s'", str);
}
/* A d d _ E x p r e s s i o n */
int Add_Expression(struct Expression *Expression_P,
char *Name, int Flag_Plus)
{
if(!Problem_S.Expression)
Problem_S.Expression = List_Create(50, 50, sizeof (struct Expression));
switch (Flag_Plus) {
case 1 :
char tmpstr[256];
sprintf(tmpstr, "_%s_%d", Name, List_Nbr(Problem_S.Expression)) ;
Expression_P->Name = strSave(tmpstr) ;
break ;
case 2 :
Expression_P->Name = strSave(Name) ;
break ;
default :
Expression_P->Name = Name ;
}
int i;
if((i = List_ISearchSeq
(Problem_S.Expression, Name, fcmp_Expression_Name)) < 0) {
i = List_Nbr(Problem_S.Expression);
List_Add(Problem_S.Expression, Expression_P);
}
else List_Write(Problem_S.Expression, i, Expression_P);
return i;
}
bool Is_ExpressionPieceWiseDefined(int index)
{
struct Expression *e = (struct Expression *)List_Pointer(Problem_S.Expression, index);
if(e->Type == PIECEWISEFUNCTION)
return true;
else if(e->Type == WHOLEQUANTITY){
for(int i = 0; i < List_Nbr(e->Case.WholeQuantity); i++){
struct WholeQuantity *w = (struct WholeQuantity *)List_Pointer(e->Case.WholeQuantity, i);
if(w->Type == WQ_EXPRESSION)
return Is_ExpressionPieceWiseDefined(w->Case.Expression.Index);
}
}
return false;
}
/* L i s t e I n d e x d e s D e f i n e Q u a n t i t y */
void Pro_DefineQuantityIndex_1(List_T *WholeQuantity_L, int TraceGroupIndex,
std::vector<std::pair<int, int> > &pairs)
{
struct WholeQuantity *WholeQuantity_P;
WholeQuantity_P = (List_Nbr(WholeQuantity_L) > 0)?
(struct WholeQuantity*)List_Pointer(WholeQuantity_L, 0) : NULL;
for(int i = 0; i < List_Nbr(WholeQuantity_L); i++)
switch ((WholeQuantity_P+i)->Type) {
case WQ_OPERATORANDQUANTITY :
case WQ_OPERATORANDQUANTITYEVAL :
case WQ_SOLIDANGLE :
case WQ_ORDER :
{
std::pair<int, int> p((WholeQuantity_P+i)->Case.OperatorAndQuantity.Index,
TraceGroupIndex);
if(std::find(pairs.begin(), pairs.end(), p) == pairs.end())
pairs.push_back(p);
}
break;
case WQ_MHTRANSFORM :
Pro_DefineQuantityIndex_1
((WholeQuantity_P+i)->Case.MHTransform.WholeQuantity, TraceGroupIndex, pairs);
case WQ_TIMEDERIVATIVE :
Pro_DefineQuantityIndex_1
((WholeQuantity_P+i)->Case.TimeDerivative.WholeQuantity, TraceGroupIndex, pairs);
break;
case WQ_ATANTERIORTIMESTEP :
Pro_DefineQuantityIndex_1
((WholeQuantity_P+i)->Case.AtAnteriorTimeStep.WholeQuantity, TraceGroupIndex, pairs);
break;
case WQ_MAXOVERTIME :
case WQ_FOURIERSTEINMETZ :
Pro_DefineQuantityIndex_1
((WholeQuantity_P+i)->Case.AtAnteriorTimeStep.WholeQuantity, TraceGroupIndex, pairs);
break;
case WQ_CAST :
Pro_DefineQuantityIndex_1
((WholeQuantity_P+i)->Case.Cast.WholeQuantity, TraceGroupIndex, pairs);
break;
case WQ_TRACE :
Pro_DefineQuantityIndex_1
((WholeQuantity_P+i)->Case.Trace.WholeQuantity,
(WholeQuantity_P+i)->Case.Trace.InIndex, pairs);
break;
case WQ_TEST :
Pro_DefineQuantityIndex_1
((WholeQuantity_P+i)->Case.Test.WholeQuantity_True, TraceGroupIndex, pairs);
Pro_DefineQuantityIndex_1
((WholeQuantity_P+i)->Case.Test.WholeQuantity_False, TraceGroupIndex, pairs);
break;
}
std::sort(pairs.begin(), pairs.end());
}
void Pro_DefineQuantityIndex(List_T *WholeQuantity_L,
int DefineQuantityIndexEqu,
int *NbrQuantityIndex, int **QuantityIndexTable,
int **QuantityTraceGroupIndexTable)
{
std::vector<std::pair<int, int> > pairs;
/* special case for the Equ part (right of the comma)
FIXME: change this when we allow a full WholeQuantity expression
there */
Pro_DefineQuantityIndex_1(WholeQuantity_L, -1, pairs);
if(DefineQuantityIndexEqu >= 0){
std::pair<int, int> p(DefineQuantityIndexEqu, -1);
pairs.push_back(p);
}
*NbrQuantityIndex = pairs.size();
*QuantityIndexTable = (int *)Malloc(pairs.size() * sizeof(int));
*QuantityTraceGroupIndexTable = (int *)Malloc(pairs.size() * sizeof(int));
for(unsigned int i = 0; i < pairs.size(); i++){
(*QuantityIndexTable)[i] = pairs[i].first;
(*QuantityTraceGroupIndexTable)[i] = pairs[i].second;
}
}
/* C h e c k _ N a m e O f S t r u c t N o t E x i s t */
int Check_NameOfStructExist(const char *Struct, List_T *List_L, void *data,
int (*fcmp)(const void *a, const void *b),
int level_Append)
{
int i;
if((i=List_ISearchSeq(List_L, data, fcmp)) >= 0 && !level_Append)
vyyerror(0, "Redefinition of %s %s", Struct, (char*)data);
return i;
}
/* P r i n t _ C o n s t a n t */
int Print_ListOfDouble(char *format, List_T *list, char *buffer)
{
// if format does not contain formatting characters, dump the list (useful for
// quick debugging of lists)
int numFormats = 0;
for(unsigned int i = 0; i < strlen(format); i++)
if(format[i] == '%') numFormats++;
if(!numFormats){
strcpy(buffer, format);
for(int i = 0; i < List_Nbr(list); i++){
double d;
List_Read(list, i, &d);
char tmp[256];
sprintf(tmp, " [%d]%g", i, d);
strcat(buffer, tmp);
}
return 0;
}
char tmp1[256], tmp2[256];
int j = 0, k = 0;
buffer[j] = '\0';
while(j < (int)strlen(format) && format[j] != '%') j++;
strncpy(buffer, format, j);
buffer[j] = '\0';
for(int i = 0; i < List_Nbr(list); i++){
k = j;
j++;
if(j < (int)strlen(format)){
if(format[j] == '%'){
strcat(buffer, "%");
j++;
}
while(j < (int)strlen(format) && format[j] != '%') j++;
if(k != j){
strncpy(tmp1, &(format[k]), j-k);
tmp1[j-k] = '\0';
sprintf(tmp2, tmp1, *(double*)List_Pointer(list, i));
strcat(buffer, tmp2);
}
}
else
return List_Nbr(list) - i;
}
if(j != (int)strlen(format))
return -1;
return 0;
}
void Print_Constants()
{
struct Constant *Constant_P;
Message::Check("Constants:\n");
List_T *tmp = Tree2List(ConstantTable_L);
for(int i = 0; i < List_Nbr(tmp); i++){
Constant_P = (struct Constant*)List_Pointer(tmp, i);
switch(Constant_P->Type){
case VAR_FLOAT:
Message::Check("%s = %g;\n", Constant_P->Name, Constant_P->Value.Float);
break;
case VAR_LISTOFFLOAT:
{
std::string str(Constant_P->Name);
str += "() = {";
for(int j = 0; j < List_Nbr(Constant_P->Value.List); j++){
if(j) str += ",";
double d;
List_Read(Constant_P->Value.List, j, &d);
char tmp[32];
sprintf(tmp, "%g", d);
str += tmp;
}
str += "};\n";
Message::Check(str.c_str());
}
break;
case VAR_CHAR:
Message::Check("%s = \"%s\";\n", Constant_P->Name, Constant_P->Value.Char);
break;
case VAR_LISTOFCHAR:
{
std::string str(Constant_P->Name);
str += "() = Str[{";
for(int j = 0; j < List_Nbr(Constant_P->Value.List); j++){
if(j) str += ",";
char *s;
List_Read(Constant_P->Value.List, j, &s);
str += std::string("\"") + s + std::string("\"");
}
str += "}];\n";
Message::Check(str.c_str());
}
break;
}
}
List_Delete(tmp);
Print_Struct();
}
void Print_Struct()
{
std::vector<std::string> strs;
nameSpaces.sprint(strs);
for(unsigned int i = 0; i < strs.size(); i++)
Message::Check(strs[i].c_str());
}
Constant *Get_ParserConstant(char *name)
{
Constant_S.Name = name;
return (Constant*)Tree_PQuery(ConstantTable_L, &Constant_S);
}
/* E r r o r h a n d l i n g */
void yyerror(const char *s)
{
extern char *getdp_yytext;
Message::Error("'%s', line %ld : %s (%s)", getdp_yyname.c_str(),
getdp_yylinenum, s, getdp_yytext);
getdp_yyerrorlevel = 1;
}
void vyyerror(int level, const char *fmt, ...)
{
char str[256];
va_list args;
va_start(args, fmt);
vsprintf(str, fmt, args);
va_end(args);
if(level == 0){
Message::Error("'%s', line %ld : %s", getdp_yyname.c_str(),
getdp_yylinenum, str);
getdp_yyerrorlevel = 1;
}
else{
Message::Warning("'%s', line %ld : %s", getdp_yyname.c_str(),
getdp_yylinenum, str);
}
}
//
double Treat_Struct_FullName_Float
(char* c1, char* c2, int type_var, int index, double val_default, int type_treat)
{
double out;
Constant_S.Name = c2;
if(!c1 && Tree_Query(ConstantTable_L, &Constant_S)) {
if (type_treat == 1) out = 1.; // Exists (type_treat == 1)
else { // Get (0) or GetForced (2)
if (type_var == 1) {
if(Constant_S.Type == VAR_FLOAT)
out = Constant_S.Value.Float;
else {
out = val_default;
if (type_treat == 0)
vyyerror(0, "Single value Constant needed: %s", struct_name.c_str());
}
}
else if (type_var == 2) {
if(Constant_S.Type == VAR_LISTOFFLOAT) {
if(index >= 0 && index < List_Nbr(Constant_S.Value.List))
List_Read(Constant_S.Value.List, index, &out);
else {
out = val_default;
vyyerror(0, "Index %d out of range", index);
}
}
else {
out = val_default;
if (type_treat == 0)
vyyerror(0, "Multi value Constant needed: %s", struct_name.c_str());
}
}
else {
out = val_default;
}
}
}
else {
if (type_var == 1) {
std::string struct_namespace(c1? c1 : std::string("")), struct_name(c2);
if(nameSpaces.getTag(struct_namespace, struct_name, out)) {
out = val_default;
if (type_treat == 0) vyyerror(0, "Unknown Constant: %s", struct_name.c_str());
}
}
else {
out = val_default;
if (type_treat == 0) vyyerror(0, "Unknown Constant: %s(.)", c2);
}
}
Free(c1); Free(c2);
return out;
}
double Treat_Struct_FullName_dot_tSTRING_Float
(char* c1, char* c2, char* c3, int index, double val_default, int type_treat)
{
double out;
std::string struct_namespace(c1? c1 : std::string("")), struct_name(c2);
std::string key_member(c3);
switch (nameSpaces.getMember
(struct_namespace, struct_name, key_member, out, index)) {
case 0:
if (type_treat == 1) out = 1.; // Exists (type_treat == 1)
break;
case 1:
out = val_default;
if (type_treat == 0)
vyyerror(0, "Unknown Struct: %s", struct_name.c_str());
break;
case 2:
if (type_treat != 0) {
const std::string * out_dummy = NULL;
out = (nameSpaces.getMember
(struct_namespace, struct_name, key_member, out_dummy))?
val_default : 1.;
}
else {
out = val_default;
if (type_treat == 0)
vyyerror(0, "Unknown member '%s' of Struct %s", c3, struct_name.c_str());
}
break;
case 3:
out = val_default;
if (type_treat == 0)
vyyerror(0, "Index %d out of range", index);
break;
}
Free(c1); Free(c2);
if (flag_tSTRING_alloc) Free(c3);
return out;
}
List_T * Treat_Struct_FullName_dot_tSTRING_ListOfFloat
(char* c1, char* c2, char* c3)
{
List_T * out, * val_default = NULL;
const std::vector<double> * out_vector; double val_;
std::string struct_namespace(c1? c1 : std::string("")), struct_name(c2);
std::string key_member(c3);
switch (nameSpaces.getMember_Vector
(struct_namespace, struct_name, key_member, out_vector)) {
case 0:
out = List_Create(out_vector->size(), 1, sizeof(double));
for(int i = 0; i < out_vector->size(); i++) {
val_ = out_vector->at(i);
List_Add(out, &val_);
}
break;
case 1:
vyyerror(0, "Unknown Struct: %s", struct_name.c_str());
out = val_default;
break;
case 2:
out = val_default;
vyyerror(0, "Unknown member '%s' of Struct %s", c3, struct_name.c_str());
break;
}
Free(c1); Free(c2);
if (flag_tSTRING_alloc) Free(c3);
return out;
}
int Treat_Struct_FullName_dot_tSTRING_Float_getDim
(char* c1, char* c2, char* c3)
{
int out;
std::string struct_namespace(c1? c1 : std::string("")), struct_name(c2);
std::string key_member(c3);
switch (nameSpaces.getMember_Dim
(struct_namespace, struct_name, key_member, out)) {
case 0:
break;
case 1:
out = 0;
vyyerror(0, "Unknown Struct: %s", struct_name.c_str());
break;
case 2:
out = 0;
vyyerror(0, "Unknown member '%s' of Struct %s", c3, struct_name.c_str());
break;
}
Free(c1); Free(c2);
if (flag_tSTRING_alloc) Free(c3);
return out;
}
char * Treat_Struct_FullName_String
(char* c1, char* c2, int type_var, int index, char * val_default, int type_treat)
{
const char * out = NULL;
Constant_S.Name = c2;
if(!c1 && Tree_Query(ConstantTable_L, &Constant_S)) {
if (type_var == 1) {
if(Constant_S.Type == VAR_CHAR)
out = Constant_S.Value.Char;
else {
out = val_default;
if (type_treat == 0)
vyyerror(0, "String Constant needed: %s", c2);
}
}
else if (type_var == 2) {
if(Constant_S.Type == VAR_LISTOFCHAR) {
if(index >= 0 && index < List_Nbr(Constant_S.Value.List))
List_Read(Constant_S.Value.List, index, &out);
else {
out = val_default;
vyyerror(0, "Index %d out of range", index);
}
}
else {
out = val_default;
if (type_treat == 0)
vyyerror(0, "List of string Constant needed: %s", struct_name.c_str());
}
}
else {
out = val_default;
}
}
else {
out = val_default;
if (type_treat == 0)
vyyerror(0, "Unknown Constant: %s", c2);
}
char* out_c = strSave(out);
Free(c1); Free(c2);
return out_c;
}
char* Treat_Struct_FullName_dot_tSTRING_String
(char* c1, char* c2, char* c3, int index, char * val_default, int type_treat)
{
std::string string_default(val_default? val_default : std::string(""));
const std::string * out = NULL;
std::string struct_namespace(c1? c1 : std::string("")), struct_name(c2);
std::string key_member(c3);
switch (nameSpaces.getMember
(struct_namespace, struct_name, key_member, out, index)) {
case 0:
break;
case 1:
out = &string_default;
if (type_treat == 0)
vyyerror(0, "Unknown Struct: %s", struct_name.c_str());
break;
case 2:
out = &string_default;
if (type_treat == 0)
vyyerror(0, "Unknown member '%s' of Struct %s", c3, struct_name.c_str());
break;
case 3:
out = &string_default;
if (type_treat == 0)
vyyerror(0, "Index %d out of range", index);
break;
}
char* out_c = strSave(out->c_str());
Free(c1); Free(c2);
if (flag_tSTRING_alloc) Free(c3);
return out_c;
}
List_T * Treat_Struct_FullName_dot_tSTRING_ListOfString
(char* c1, char* c2, char* c3)
{
List_T * out, * val_default = NULL;
const std::vector<std::string> * out_vector; char * val_;
std::string struct_namespace(c1? c1 : std::string("")), struct_name(c2);
std::string key_member(c3);
switch (nameSpaces.getMember_Vector
(struct_namespace, struct_name, key_member, out_vector)) {
case 0:
out = List_Create(out_vector->size(), 1, sizeof(char *));
for(int i = 0; i < out_vector->size(); i++) {
val_ = strSave(out_vector->at(i).c_str());
List_Add(out, &val_);
}
break;
case 1:
vyyerror(0, "Unknown Struct: %s", struct_name.c_str());
out = val_default;
break;
case 2:
out = val_default;
vyyerror(0, "Unknown member '%s' of Struct %s", c3, struct_name.c_str());
break;
}
Free(c1); Free(c2);
if (flag_tSTRING_alloc) Free(c3);
return out;
}