diff --git a/pkg/catalog/secondary_index_utils.go b/pkg/catalog/secondary_index_utils.go index 0f84dd346c8c3..a92e67be2a069 100644 --- a/pkg/catalog/secondary_index_utils.go +++ b/pkg/catalog/secondary_index_utils.go @@ -85,6 +85,7 @@ const ( HnswEfConstruction = "ef_construction" HnswQuantization = "quantization" HnswEfSearch = "ef_search" + Async = "async" ) /* 1. ToString Functions */ @@ -133,6 +134,12 @@ func IndexParamsToStringList(indexParams string) (string, error) { res += fmt.Sprintf(" %s '%s' ", IndexAlgoParamOpType, opType) } + if val, ok := result[Async]; ok { + if val == "true" { + res += fmt.Sprintf(" %s ", Async) + } + } + return res, nil } @@ -179,10 +186,16 @@ func fullTextIndexParamsToMap(def *tree.FullTextIndex) (map[string]string, error // fulltext index here if def.IndexOption != nil { parsername := strings.ToLower(def.IndexOption.ParserName) - if parsername != "ngram" && parsername != "default" && parsername != "json" && parsername != "json_value" { - return nil, moerr.NewInternalErrorNoCtx(fmt.Sprintf("invalid parser %s", parsername)) + if len(parsername) > 0 { + if parsername != "ngram" && parsername != "default" && parsername != "json" && parsername != "json_value" { + return nil, moerr.NewInternalErrorNoCtx(fmt.Sprintf("invalid parser %s", parsername)) + } + res["parser"] = parsername + } + + if def.IndexOption.Async { + res[Async] = "true" } - res["parser"] = parsername } return res, nil } @@ -224,6 +237,10 @@ func indexParamsToMap(def interface{}) (map[string]string, error) { } else { res[IndexAlgoParamOpType] = metric.OpType_L2Distance // set l2 as default } + + if idx.IndexOption.Async { + res[Async] = "true" + } case tree.INDEX_TYPE_HNSW: if idx.IndexOption.HnswM < 0 { return nil, moerr.NewInternalErrorNoCtx("invalid M. hnsw.M must be > 0") @@ -265,6 +282,10 @@ func indexParamsToMap(def interface{}) (map[string]string, error) { } else { res[IndexAlgoParamOpType] = metric.OpType_L2Distance // set l2 as default } + + if idx.IndexOption.Async { + res[Async] = "true" + } default: return nil, moerr.NewInternalErrorNoCtx("invalid index alogorithm type") } @@ -281,6 +302,20 @@ func DefaultIvfIndexAlgoOptions() map[string]string { return res } +func IsIndexAsync(indexAlgoParams string) (bool, error) { + if len(indexAlgoParams) > 0 { + param, err := IndexParamsStringToMap(indexAlgoParams) + if err != nil { + return false, err + } + v, ok := param[Async] + if ok { + return v == "true", nil + } + } + return false, nil +} + //------------------------[END] IndexAlgoParams------------------------ // ------------------------[START] Aliaser------------------------ diff --git a/pkg/cdc/index_sinker.go b/pkg/cdc/index_sinker.go new file mode 100644 index 0000000000000..7b283ce1ff792 --- /dev/null +++ b/pkg/cdc/index_sinker.go @@ -0,0 +1,550 @@ +// Copyright 2024 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package cdc + +// indexSyncSinker is to update HNSW index via CDC. +// It will read CDC changes and create JSON as input to function hnsw_cdc_update(dbname, tablename, vector_dimenion, json) +// You can refer the JSON format from vectorindex.VectorIndexCdc +// Single batch will split into multiple json objects and each json has maximum 8192 records (see vectorindex.VectorIndexCdc). +// Transaction function ExecTxn() used to make sure single batch (multiple json objects) can be updated in single transaction. + +import ( + "bytes" + "context" + "fmt" + "os" + "sync/atomic" + "time" + + "github.com/matrixorigin/matrixone/pkg/catalog" + "github.com/matrixorigin/matrixone/pkg/common/moerr" + "github.com/matrixorigin/matrixone/pkg/common/runtime" + "github.com/matrixorigin/matrixone/pkg/container/batch" + "github.com/matrixorigin/matrixone/pkg/logutil" + "github.com/matrixorigin/matrixone/pkg/pb/plan" + "github.com/matrixorigin/matrixone/pkg/util/executor" + v2 "github.com/matrixorigin/matrixone/pkg/util/metric/v2" + "github.com/matrixorigin/matrixone/pkg/vectorindex" + "go.uber.org/zap" +) + +var _ Sinker = &indexSyncSinker{} + +var sqlExecutorFactory = _sqlExecutorFactory + +type indexSyncSinker struct { + cnUUID string + accountId uint64 + taskId string + dbTblInfo *DbTableInfo + watermarkUpdater *CDCWatermarkUpdater + ar *ActiveRoutine + tableDef *plan.TableDef + err atomic.Value + sqlWriters []IndexSqlWriter + sqlBufSendCh chan []byte + exec executor.SQLExecutor + rowdata []any + rowdelete []any +} + +type IndexEntry struct { + algo string + indexes []*plan.IndexDef +} + +func _sqlExecutorFactory(cnUUID string) (executor.SQLExecutor, error) { + // sql executor + v, ok := runtime.ServiceRuntime(cnUUID).GetGlobalVariables(runtime.InternalSQLExecutor) + if !ok { + //os.Stderr.WriteString(fmt.Sprintf("sql executor create failed. cnUUID = %s\n", cnUUID)) + return nil, moerr.NewNotSupportedNoCtx("no implement sqlExecutor") + } + exec := v.(executor.SQLExecutor) + return exec, nil +} + +var NewIndexSyncSinker = func( + cnUUID string, + sinkUri UriInfo, + accountId uint64, + taskId string, + dbTblInfo *DbTableInfo, + watermarkUpdater *CDCWatermarkUpdater, + tableDef *plan.TableDef, + retryTimes int, + retryDuration time.Duration, + ar *ActiveRoutine, + maxSqlLength uint64, + sendSqlTimeout string, +) (Sinker, error) { + + // sql executor + exec, err := sqlExecutorFactory(cnUUID) + if err != nil { + return nil, err + } + + sqlwriters := make([]IndexSqlWriter, 0, 5) + indexmap := make(map[string]*IndexEntry) + + for _, idx := range tableDef.Indexes { + if idx.TableExist && (catalog.IsHnswIndexAlgo(idx.IndexAlgo) || catalog.IsIvfIndexAlgo(idx.IndexAlgo) || catalog.IsFullTextIndexAlgo(idx.IndexAlgo)) { + key := idx.IndexName + sidx, ok := indexmap[key] + if ok { + sidx.indexes = append(sidx.indexes, idx) + } else { + ie := &IndexEntry{algo: idx.IndexAlgo, indexes: make([]*plan.IndexDef, 0, 3)} + ie.indexes = append(ie.indexes, idx) + indexmap[key] = ie + } + } + + } + + for _, ie := range indexmap { + sqlwriter, err := NewIndexSqlWriter(ie.algo, dbTblInfo, tableDef, ie.indexes) + if err != nil { + return nil, err + } + sqlwriters = append(sqlwriters, sqlwriter) + os.Stderr.WriteString(fmt.Sprintf("sql writer %T\n", sqlwriter)) + } + + s := &indexSyncSinker{ + cnUUID: cnUUID, + dbTblInfo: dbTblInfo, + accountId: accountId, + taskId: taskId, + watermarkUpdater: watermarkUpdater, + ar: ar, + tableDef: tableDef, + sqlBufSendCh: make(chan []byte), + err: atomic.Value{}, + exec: exec, + sqlWriters: sqlwriters, + rowdata: make([]any, len(tableDef.Cols)), + rowdelete: make([]any, 1), // delete row only have one column pk + } + return s, nil + +} + +func (s *indexSyncSinker) Run(ctx context.Context, ar *ActiveRoutine) { + logutil.Infof("cdc indexSyncSinker(%v).Run: start", s.dbTblInfo) + defer func() { + logutil.Infof("cdc indexSyncSinker(%v).Run: end", s.dbTblInfo) + }() + + closed := false + for !closed { + + txnbegin := false + // make sure there is a BEGIN before start transaction + for !txnbegin { + + select { + case <-ctx.Done(): + return + case sqlBuf, ok := <-s.sqlBufSendCh: + if !ok { + closed = true + return + } + if bytes.Equal(sqlBuf, begin) { + txnbegin = true + } else if bytes.Equal(sqlBuf, commit) { + // pass + } else if bytes.Equal(sqlBuf, rollback) { + // pass + } else if bytes.Equal(sqlBuf, dummy) { + // pass + } else { + func() { + newctx, cancel := context.WithTimeout(context.Background(), 12*time.Hour) + defer cancel() + //os.Stderr.WriteString("Wait for BEGIN but sql. execute anyway\n") + opts := executor.Options{} + res, err := s.exec.Exec(newctx, string(sqlBuf), opts) + if err != nil { + logutil.Errorf("cdc indexSyncSinker(%v) send sql failed, err: %v, sql: %s", s.dbTblInfo, err, sqlBuf[sqlBufReserved:]) + os.Stderr.WriteString(fmt.Sprintf("sql executor run failed. %s\n", string(sqlBuf))) + os.Stderr.WriteString(fmt.Sprintf("err :%v\n", err)) + s.SetError(err) + } + res.Close() + }() + } + } + } + + func() { + newctx, cancel := context.WithTimeout(context.Background(), 12*time.Hour) + defer cancel() + opts := executor.Options{} + err := s.exec.ExecTxn(newctx, + func(exec executor.TxnExecutor) error { + + for { + select { + case <-ctx.Done(): + return ctx.Err() + case sqlBuf, ok := <-s.sqlBufSendCh: + if !ok { + // channel closed + closed = true + return nil + } + + if bytes.Equal(sqlBuf, dummy) { + + } else if bytes.Equal(sqlBuf, begin) { + // BEGIN + } else if bytes.Equal(sqlBuf, commit) { + // COMMIT - end of data + return nil + } else if bytes.Equal(sqlBuf, rollback) { + // ROLLBACK + return moerr.NewQueryInterrupted(ctx) + } else { + res, err := exec.Exec(string(sqlBuf), opts.StatementOption()) + if err != nil { + logutil.Errorf("cdc indexSyncSinker(%v) send sql failed, err: %v, sql: %s", s.dbTblInfo, err, sqlBuf[sqlBufReserved:]) + os.Stderr.WriteString(fmt.Sprintf("sql executor run failed. %s\n", string(sqlBuf))) + os.Stderr.WriteString(fmt.Sprintf("err :%v\n", err)) + return err + } + res.Close() + } + } + } + + }, + opts) + if err != nil { + moe, ok := err.(*moerr.Error) + if ok { + if moe.ErrorCode() == moerr.ErrQueryInterrupted { + // skip rollback error + //os.Stderr.WriteString("error QueryInterrupted....rollback\n") + logutil.Errorf("cdc indexSyncSinker(%v) parent rollback", s.dbTblInfo) + } else { + s.SetError(err) + } + } else if uw, ok := err.(interface{ Unwrap() []error }); ok { + rollbackfound := false + for _, e := range uw.Unwrap() { + //os.Stderr.WriteString(fmt.Sprintf("errors... %v\n", e)) + moe, ok := e.(*moerr.Error) + if ok && moe.ErrorCode() == moerr.ErrQueryInterrupted { + rollbackfound = true + } + } + + //os.Stderr.WriteString(fmt.Sprintf("rollback found %v\n", rollbackfound)) + if !rollbackfound { + s.SetError(err) + } + } else { + s.SetError(err) + } + } + }() + } +} + +func (s *indexSyncSinker) Sink(ctx context.Context, data *DecoderOutput) { + // TODO: IMPORTANT: check the indexdef here so that Add/Drop index can be reflected here + + key := WatermarkKey{ + AccountId: s.accountId, + TaskId: s.taskId, + DBName: s.dbTblInfo.SourceDbName, + TableName: s.dbTblInfo.SourceTblName, + } + watermark, err := s.watermarkUpdater.GetFromCache(ctx, &key) + if err != nil { + logutil.Error( + "CDC-MySQLSinker-GetWatermarkFailed", + zap.String("info", s.dbTblInfo.String()), + zap.String("key", key.String()), + zap.Error(err), + ) + return + } + + if data.toTs.LE(&watermark) { + logutil.Errorf("cdc indexSyncSinker(%v): unexpected watermark: %s, current watermark: %s", + s.dbTblInfo, data.toTs.ToString(), watermark.ToString()) + return + } + + if data.noMoreData { + // complete sql statement + err := s.flushCdc() + if err != nil { + s.SetError(err) + } + return + } + + start := time.Now() + defer func() { + v2.CdcSinkDurationHistogram.Observe(time.Since(start).Seconds()) + }() + + if data.outputTyp == OutputTypeSnapshot { + //os.Stderr.WriteString(fmt.Sprintf("sinkSnapshot batlen %d\n", batchRowCount(data.checkpointBat))) + s.sinkSnapshot(ctx, data.checkpointBat) + } else if data.outputTyp == OutputTypeTail { + //os.Stderr.WriteString(fmt.Sprintf("sinkTail insertBat %d, deletBat = %d\n", data.insertAtmBatch.RowCount(), data.deleteAtmBatch.RowCount())) + s.sinkTail(ctx, data.insertAtmBatch, data.deleteAtmBatch) + } else { + s.SetError(moerr.NewInternalError(ctx, fmt.Sprintf("cdc indexSyncSinker unexpected output type: %v", data.outputTyp))) + } +} + +func (s *indexSyncSinker) SendBegin() { + s.sqlBufSendCh <- begin +} + +func (s *indexSyncSinker) SendCommit() { + s.sqlBufSendCh <- commit +} + +func (s *indexSyncSinker) SendRollback() { + s.sqlBufSendCh <- rollback +} + +func (s *indexSyncSinker) SendDummy() { + s.sqlBufSendCh <- dummy +} + +func (s *indexSyncSinker) Error() error { + if ptr := s.err.Load(); ptr != nil { + errPtr := ptr.(*error) + if errPtr != nil { + if moErr, ok := (*errPtr).(*moerr.Error); !ok { + return moerr.ConvertGoError(context.Background(), *errPtr) + } else { + if moErr == nil { + return nil + } + return moErr + } + } + } + return nil +} + +func (s *indexSyncSinker) SetError(err error) { + s.err.Store(&err) +} + +func (s *indexSyncSinker) ClearError() { + var err *moerr.Error + s.SetError(err) +} + +func (s *indexSyncSinker) Reset() { + for _, writer := range s.sqlWriters { + writer.Reset() + } + s.err = atomic.Value{} +} + +func (s *indexSyncSinker) Close() { + // stop Run goroutine + close(s.sqlBufSendCh) +} + +func (s *indexSyncSinker) sinkSnapshot(ctx context.Context, bat *batch.Batch) { + var err error + + for i := 0; i < batchRowCount(bat); i++ { + if err = extractRowFromEveryVector(ctx, bat, i, s.rowdata); err != nil { + s.SetError(err) + return + } + + for _, writer := range s.sqlWriters { + err = writer.Upsert(ctx, s.rowdata) + if err != nil { + s.SetError(err) + return + } + + if writer.Full() { + err = s.sendSql(writer) + if err != nil { + s.SetError(err) + return + } + } + } + } +} + +// upsertBatch and deleteBatch is sorted by ts +// for the same ts, delete first, then upsert +func (s *indexSyncSinker) sinkTail(ctx context.Context, upsertBatch, deleteBatch *AtomicBatch) { + var err error + + upsertIter := upsertBatch.GetRowIterator().(*atomicBatchRowIter) + deleteIter := deleteBatch.GetRowIterator().(*atomicBatchRowIter) + defer func() { + upsertIter.Close() + deleteIter.Close() + }() + + // output sql until one iterator reach the end + upsertIterHasNext, deleteIterHasNext := upsertIter.Next(), deleteIter.Next() + for upsertIterHasNext && deleteIterHasNext { + upsertItem, deleteItem := upsertIter.Item(), deleteIter.Item() + // compare ts, ignore pk + if upsertItem.Ts.LT(&deleteItem.Ts) { + if err = s.sinkUpsert(ctx, upsertIter); err != nil { + s.SetError(err) + return + } + // get next item + upsertIterHasNext = upsertIter.Next() + } else { + if err = s.sinkDelete(ctx, deleteIter); err != nil { + s.SetError(err) + return + } + // get next item + deleteIterHasNext = deleteIter.Next() + } + } + + // output the rest of upsert iterator + for upsertIterHasNext { + if err = s.sinkUpsert(ctx, upsertIter); err != nil { + s.SetError(err) + return + } + // get next item + upsertIterHasNext = upsertIter.Next() + } + + // output the rest of delete iterator + for deleteIterHasNext { + if err = s.sinkDelete(ctx, deleteIter); err != nil { + s.SetError(err) + return + } + // get next item + deleteIterHasNext = deleteIter.Next() + } + s.flushCdc() +} + +func (s *indexSyncSinker) sinkUpsert(ctx context.Context, upsertIter *atomicBatchRowIter) (err error) { + + // get row from the batch + if err = upsertIter.Row(ctx, s.rowdata); err != nil { + return err + } + + for _, writer := range s.sqlWriters { + if !writer.CheckLastOp(vectorindex.CDC_UPSERT) { + // last op is not UPSERT, sendSql first + // send SQL + err = s.sendSql(writer) + if err != nil { + return err + } + + } + + writer.Upsert(ctx, s.rowdata) + + if writer.Full() { + // send SQL + err = s.sendSql(writer) + if err != nil { + return err + } + } + } + + return nil +} + +func (s *indexSyncSinker) sinkDelete(ctx context.Context, deleteIter *atomicBatchRowIter) (err error) { + + // get row from the batch + if err = deleteIter.Row(ctx, s.rowdelete); err != nil { + return err + } + + for _, writer := range s.sqlWriters { + if !writer.CheckLastOp(vectorindex.CDC_DELETE) { + // last op is not DELETE, sendSql first + // send SQL + err = s.sendSql(writer) + if err != nil { + return err + } + + } + + writer.Delete(ctx, s.rowdelete) + + if writer.Full() { + // send SQL + err = s.sendSql(writer) + if err != nil { + return err + } + } + } + + return nil +} + +func (s *indexSyncSinker) flushCdc() (err error) { + for _, writer := range s.sqlWriters { + err = s.sendSql(writer) + if err != nil { + return err + } + } + return nil +} + +func (s *indexSyncSinker) sendSql(writer IndexSqlWriter) error { + if writer.Empty() { + return nil + } + + // generate sql from cdc + sql, err := writer.ToSql() + if err != nil { + return err + } + + s.sqlBufSendCh <- sql + os.Stderr.WriteString(string(sql)) + os.Stderr.WriteString("\n") + + // reset + writer.Reset() + + return nil +} diff --git a/pkg/cdc/index_sinker_test.go b/pkg/cdc/index_sinker_test.go new file mode 100644 index 0000000000000..6c3c298057aa9 --- /dev/null +++ b/pkg/cdc/index_sinker_test.go @@ -0,0 +1,727 @@ +// Copyright 2024 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package cdc + +import ( + "context" + "errors" + "fmt" + "strings" + "sync" + "testing" + "time" + + "github.com/matrixorigin/matrixone/pkg/catalog" + "github.com/matrixorigin/matrixone/pkg/common/moerr" + "github.com/matrixorigin/matrixone/pkg/container/batch" + "github.com/matrixorigin/matrixone/pkg/container/types" + "github.com/matrixorigin/matrixone/pkg/container/vector" + "github.com/matrixorigin/matrixone/pkg/pb/plan" + "github.com/matrixorigin/matrixone/pkg/testutil" + "github.com/matrixorigin/matrixone/pkg/txn/client" + "github.com/matrixorigin/matrixone/pkg/util/executor" + "github.com/prashantv/gostub" + "github.com/stretchr/testify/require" + "github.com/tidwall/btree" +) + +func newTestTableDef(pkName string, pkType types.T, vecColName string, vecType types.T, vecWidth int32) *plan.TableDef { + return &plan.TableDef{ + Name: "test_orig_tbl", + Name2ColIndex: map[string]int32{ + pkName: 0, + vecColName: 1, + "dummy": 2, // Add another col to make sure pk/vec col indices are used + }, + Cols: []*plan.ColDef{ + {Name: pkName, Typ: plan.Type{Id: int32(pkType)}}, + {Name: vecColName, Typ: plan.Type{Id: int32(vecType), Width: vecWidth}}, + {Name: "dummy", Typ: plan.Type{Id: int32(types.T_int32)}}, + }, + Pkey: &plan.PrimaryKeyDef{ + Names: []string{pkName}, + PkeyColName: pkName, + }, + Indexes: []*plan.IndexDef{ + { + IndexName: "hnsw_idx", + TableExist: true, + IndexAlgo: catalog.MoIndexHnswAlgo.ToString(), + IndexAlgoTableType: catalog.Hnsw_TblType_Metadata, + IndexTableName: "meta_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"m":"16","ef_construction":"200","ef_search":"100","op_type":"vector_l2_ops"}`, + }, + { + IndexName: "hnsw_idx", + TableExist: true, + IndexAlgo: catalog.MoIndexHnswAlgo.ToString(), + IndexAlgoTableType: catalog.Hnsw_TblType_Storage, + IndexTableName: "storage_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"m":"16","ef_construction":"200","ef_search":"100","op_type":"vector_l2_ops"}`, + }, + }, + } +} + +func newTestDbTableInfo() *DbTableInfo { + return &DbTableInfo{ + SourceDbName: "test_db", + SourceTblName: "test_tbl", + SinkDbName: "sink_db", + SinkTblName: "sink_tbl", + } +} + +func newTestActiveRoutine() *ActiveRoutine { + ar := NewCdcActiveRoutine() + // ar.Start() // Don't start by default, let tests control + return ar +} + +type MockSQLExecutor struct { +} + +// Exec exec a sql in a exists txn. +func (exec MockSQLExecutor) Exec(ctx context.Context, sql string, opts executor.Options) (executor.Result, error) { + + return executor.Result{}, nil +} + +// ExecTxn executor sql in a txn. execFunc can use TxnExecutor to exec multiple sql +// in a transaction. +// NOTE: Pass SQL stmts one by one to TxnExecutor.Exec(). If you pass multiple SQL stmts to +// TxnExecutor.Exec() as `\n` seperated string, it will only execute the first SQL statement causing Bug. +func (exec MockSQLExecutor) ExecTxn(ctx context.Context, execFunc func(txn executor.TxnExecutor) error, opts executor.Options) error { + return nil +} + +type MockErrorTxnExecutor struct { + database string + ctx context.Context +} + +func (exec *MockErrorTxnExecutor) Use(db string) { + exec.database = db +} + +func (exec *MockErrorTxnExecutor) Exec( + sql string, + statementOption executor.StatementOption, +) (executor.Result, error) { + if strings.Contains(sql, "FAILSQL") { + return executor.Result{}, moerr.NewInternalErrorNoCtx("db error") + } else if strings.Contains(sql, "MULTI_ERROR_NO_ROLLBACK") { + var errs error + errs = errors.Join(errs, moerr.NewInternalErrorNoCtx("db error")) + errs = errors.Join(errs, moerr.NewInternalErrorNoCtx("db error 2")) + return executor.Result{}, errs + } else if strings.Contains(sql, "MULTI_ERROR_ROLLBACK") { + var errs error + errs = errors.Join(errs, moerr.NewInternalErrorNoCtx("db error")) + errs = errors.Join(errs, moerr.NewQueryInterrupted(exec.ctx)) + return executor.Result{}, errs + } + + return executor.Result{}, nil +} + +func (exec *MockErrorTxnExecutor) LockTable(table string) error { + return nil +} + +func (exec *MockErrorTxnExecutor) Txn() client.TxnOperator { + return nil +} + +/* +func (exec *MockErrorTxnExecutor) commit() error { + return nil +} + +func (exec *MockErrorTxnExecutor) getDatabase() string { + return "" +} + +func (exec *MockErrorTxnExecutor) rollback(err error) error { + return nil +} +*/ + +var _ executor.TxnExecutor = new(MockErrorTxnExecutor) + +type MockErrorSQLExecutor struct { +} + +// Exec exec a sql in a exists txn. +func (exec MockErrorSQLExecutor) Exec(ctx context.Context, sql string, opts executor.Options) (executor.Result, error) { + if strings.Contains(sql, "FAILSQL") { + return executor.Result{}, moerr.NewInternalError(ctx, "db error") + } + return executor.Result{}, nil +} + +// ExecTxn executor sql in a txn. execFunc can use TxnExecutor to exec multiple sql +// in a transaction. +// NOTE: Pass SQL stmts one by one to TxnExecutor.Exec(). If you pass multiple SQL stmts to +// TxnExecutor.Exec() as `\n` seperated string, it will only execute the first SQL statement causing Bug. +func (exec MockErrorSQLExecutor) ExecTxn(ctx context.Context, execFunc func(txn executor.TxnExecutor) error, opts executor.Options) error { + + txnexec := &MockErrorTxnExecutor{ctx: ctx} + err := execFunc(txnexec) + if moerr.IsMoErrCode(err, moerr.ErrQueryInterrupted) { + fmt.Printf("ROLLBACK...\n") + return nil // Simulating successful handling of rollback signal + } + return err +} + +var _ executor.SQLExecutor = new(MockSQLExecutor) +var _ executor.SQLExecutor = new(MockErrorSQLExecutor) + +func mockSqlExecutorFactory(uuid string) (executor.SQLExecutor, error) { + return MockSQLExecutor{}, nil +} + +func mockErrorSqlExecutorFactory(uuid string) (executor.SQLExecutor, error) { + return MockErrorSQLExecutor{}, nil +} + +func NewMockWatermarkUpdater(ctx context.Context) *CDCWatermarkUpdater { + ie := newWmMockSQLExecutor() + u := NewCDCWatermarkUpdater("test", ie) + key1 := new(WatermarkKey) + key1.AccountId = 0 + key1.TaskId = "taskid" + key1.DBName = "test_db" + key1.TableName = "test_tbl" + wm1 := types.BuildTS(1, 1) + err := u.UpdateWatermarkOnly(ctx, key1, &wm1) + if err != nil { + fmt.Printf("ERIC %v", err) + } + + key2 := new(WatermarkKey) + key2.AccountId = 0 + key2.TaskId = "taskid" + key2.DBName = "test_db" + key2.TableName = "test_tbl" + watermark, err := u.GetFromCache(ctx, key2) + if err != nil { + fmt.Printf("ERIC2 %v", err) + } + + var _ = watermark + + return u +} + +// Constants that might be missing in the test context +//const sqlBufReserved = 0 // Assuming 0 for tests, original code might have a value + +var ( +// Define these if they are not exported or available in the test package context +// For this test, we'll assume they are defined as in the original package. +// If not, they would be: +// begin = []byte("BEGIN") +// commit = []byte("COMMIT") +// rollback = []byte("ROLLBACK") +// dummy = []byte("DUMMY") +) + +// --- Test Cases --- + +func TestNewIndexSyncSinker(t *testing.T) { + ctx, cancel := context.WithCancel(context.Background()) + defer cancel() + + dbTblInfo := newTestDbTableInfo() + ar := newTestActiveRoutine() + watermarkUpdater := NewMockWatermarkUpdater(ctx) + + sqlexecstub := gostub.Stub(&sqlExecutorFactory, mockSqlExecutorFactory) + defer sqlexecstub.Reset() + + t.Run("success float32", func(t *testing.T) { + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 128) + sinker, err := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", dbTblInfo, watermarkUpdater, tblDef, 3, time.Second, ar, 1024, "10s") + require.NoError(t, err) + require.NotNil(t, sinker) + sinker.Close() + }) + + /* + t.Run("success float64", func(t *testing.T) { + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float64, 128) + sinker, err := NewIndexSyncSinker("test-uuid", UriInfo{}, dbTblInfo, watermarkUpdater, tblDef, 3, time.Second, ar, 1024, "10s") + require.NoError(t, err) + require.NotNil(t, sinker) + sinker.Close() + }) + */ + + t.Run("invalid pkey count", func(t *testing.T) { + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 128) + tblDef.Pkey.Names = []string{"pk1", "pk2"} + _, err := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", dbTblInfo, watermarkUpdater, tblDef, 3, time.Second, ar, 1024, "10s") + require.Error(t, err) + require.True(t, moerr.IsMoErrCode(err, moerr.ErrInternal)) + }) + + t.Run("invalid hnsw index count", func(t *testing.T) { + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 128) + tblDef.Indexes = []*plan.IndexDef{tblDef.Indexes[0]} // Only one index + _, err := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", dbTblInfo, watermarkUpdater, tblDef, 3, time.Second, ar, 1024, "10s") + require.Error(t, err) + require.True(t, moerr.IsMoErrCode(err, moerr.ErrInternal)) + }) + + t.Run("invalid index parts count", func(t *testing.T) { + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 128) + tblDef.Indexes[0].Parts = []string{"vec1", "vec2"} + _, err := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", dbTblInfo, watermarkUpdater, tblDef, 3, time.Second, ar, 1024, "10s") + require.Error(t, err) + require.True(t, moerr.IsMoErrCode(err, moerr.ErrInternal)) + }) + + t.Run("invalid pkey type", func(t *testing.T) { + tblDef := newTestTableDef("pk", types.T_int32, "vec", types.T_array_float32, 128) // PK is int32 + _, err := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", dbTblInfo, watermarkUpdater, tblDef, 3, time.Second, ar, 1024, "10s") + require.Error(t, err) + require.True(t, moerr.IsMoErrCode(err, moerr.ErrInternal)) + }) + + t.Run("missing meta index", func(t *testing.T) { + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 128) + tblDef.Indexes[0].IndexAlgoTableType = "invalid" // Corrupt meta index type + _, err := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", dbTblInfo, watermarkUpdater, tblDef, 3, time.Second, ar, 1024, "10s") + require.Error(t, err) + require.True(t, moerr.IsMoErrCode(err, moerr.ErrInternal)) + }) + + t.Run("invalid hnsw params json", func(t *testing.T) { + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 128) + tblDef.Indexes[0].IndexAlgoParams = `{"M":16, efConstruction":200 ...` // Invalid JSON + _, err := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", dbTblInfo, watermarkUpdater, tblDef, 3, time.Second, ar, 1024, "10s") + require.Error(t, err) + require.True(t, moerr.IsMoErrCode(err, moerr.ErrInternal)) + }) + + t.Run("unsupported vector type", func(t *testing.T) { + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_int32, 128) // Vector is int32 + _, err := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", dbTblInfo, watermarkUpdater, tblDef, 3, time.Second, ar, 1024, "10s") + require.Error(t, err) + require.True(t, moerr.IsMoErrCode(err, moerr.ErrInternal)) + }) +} + +func TestHnswSyncSinker_Run(t *testing.T) { + ctx, cancel := context.WithCancel(context.Background()) + defer cancel() + sqlexecstub := gostub.Stub(&sqlExecutorFactory, mockSqlExecutorFactory) + defer sqlexecstub.Reset() + watermarkUpdater := NewMockWatermarkUpdater(ctx) + + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 4) + sinker, err := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", newTestDbTableInfo(), watermarkUpdater, tblDef, 0, 0, newTestActiveRoutine(), 1024, "1s") + require.NoError(t, err) + defer sinker.Close() + + s := sinker.(*indexSyncSinker) + + var wg sync.WaitGroup + wg.Add(1) + go func() { + defer wg.Done() + s.Run(ctx, nil) // ActiveRoutine not used by Run directly + }() + + t.Run("happy path commit", func(t *testing.T) { + s.ClearError() + //var executedSqls []string + + s.SendBegin() + s.sqlBufSendCh <- []byte("SELECT 1") + s.SendCommit() + + // Wait for processing or timeout + time.Sleep(100 * time.Millisecond) + require.NoError(t, s.Error()) + //require.Contains(t, executedSqls, "SELECT 1") + }) + + // To properly test sinker.Close() and stop the Run goroutine: + cancel() // Signal Run to stop its loop if it checks ctx.Done() + // Closing sqlBufSendCh is done by sinker.Close(), which should cause Run to exit. + wg.Wait() // Wait for Run goroutine to finish +} + +func TestHnswSyncSinker_RunError(t *testing.T) { + ctx, cancel := context.WithCancel(context.Background()) + defer cancel() + sqlexecstub := gostub.Stub(&sqlExecutorFactory, mockErrorSqlExecutorFactory) + defer sqlexecstub.Reset() + watermarkUpdater := NewMockWatermarkUpdater(ctx) + + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 4) + sinker, err := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", newTestDbTableInfo(), watermarkUpdater, tblDef, 0, 0, newTestActiveRoutine(), 1024, "1s") + require.NoError(t, err) + defer sinker.Close() + + s := sinker.(*indexSyncSinker) + + var wg sync.WaitGroup + wg.Add(1) + go func() { + defer wg.Done() + s.Run(ctx, nil) // ActiveRoutine not used by Run directly + }() + + t.Run("exec error", func(t *testing.T) { + s.ClearError() + s.SendBegin() + s.sqlBufSendCh <- []byte("FAILSQL") + s.SendCommit() // This commit might not be reached if error handling is strict + + time.Sleep(100 * time.Millisecond) + err := s.Error() + require.Error(t, err) + }) + + t.Run("multi-error no rollback error", func(t *testing.T) { + s.ClearError() + s.SendBegin() + s.sqlBufSendCh <- []byte("MULTI_ERROR_NO_ROLLBACK") + s.SendCommit() // This commit might not be reached if error handling is strict + + time.Sleep(100 * time.Millisecond) + err := s.Error() + require.Error(t, err) + }) + + t.Run("multi-error with rollback error", func(t *testing.T) { + s.ClearError() + s.SendBegin() + s.sqlBufSendCh <- []byte("MULTI_ERROR_ROLLBACK") + s.SendCommit() // This commit might not be reached if error handling is strict + + time.Sleep(100 * time.Millisecond) + err := s.Error() + require.NoError(t, err) + }) + + t.Run("rollback", func(t *testing.T) { + s.ClearError() + s.SendBegin() + s.SendRollback() + + time.Sleep(100 * time.Millisecond) + require.NoError(t, s.Error()) + //require.True(t, rolledBack, "Rollback was not processed as expected") + }) + + fmt.Printf("finihsed......\n") + // To properly test sinker.Close() and stop the Run goroutine: + cancel() // Signal Run to stop its loop if it checks ctx.Done() + // Closing sqlBufSendCh is done by sinker.Close(), which should cause Run to exit. + // We already defer sinker.Close(), but for this test, let's be explicit. + wg.Wait() // Wait for Run goroutine to finish +} + +func TestHnswSyncSinker_Sink(t *testing.T) { + + ctx := context.Background() + proc := testutil.NewProcess(t) + + sqlexecstub := gostub.Stub(&sqlExecutorFactory, mockSqlExecutorFactory) + defer sqlexecstub.Reset() + + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 2) + watermarkUpdater := NewMockWatermarkUpdater(ctx) + sinker, err := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", newTestDbTableInfo(), watermarkUpdater, tblDef, 0, 0, newTestActiveRoutine(), 1024, "1s") + require.NoError(t, err) + defer sinker.Close() + + s := sinker.(*indexSyncSinker) + + t.Run("snapshot", func(t *testing.T) { + s.Reset() + + bat := testutil.NewBatchWithVectors( + []*vector.Vector{ + testutil.NewVector(2, types.T_int64.ToType(), proc.Mp(), false, []int64{1, 2}), + testutil.NewVector(2, types.T_array_float32.ToType(), proc.Mp(), false, [][]float32{{0.1, 0.2}, {0.3, 0.4}}), + testutil.NewVector(2, types.T_int32.ToType(), proc.Mp(), false, []int32{1, 2}), + }, nil) + + defer bat.Clean(testutil.TestUtilMp) + + output := &DecoderOutput{ + fromTs: types.BuildTS(1, 0), + toTs: types.BuildTS(2, 0), + outputTyp: OutputTypeSnapshot, + checkpointBat: bat, + insertAtmBatch: nil, // Not used for snapshot + deleteAtmBatch: nil, // Not used for snapshot + noMoreData: false, + } + s.Sink(ctx, output) + require.NoError(t, s.Error()) + sql, err := s.sqlWriters[0].ToSql() + require.NoError(t, err) + require.Equal(t, string(sql), `SELECT hnsw_cdc_update('sink_db', 'sink_tbl', 2, '{"cdc":[{"t":"U","pk":1,"v":[0.1,0.2]},{"t":"U","pk":2,"v":[0.3,0.4]}]}');`) + }) + + t.Run("noMoreData", func(t *testing.T) { + rowdata := []any{int64(100), []float32{1.0, 2.0}} + s.Reset() + s.sqlWriters[0].Upsert(ctx, rowdata) // Add some data + require.False(t, s.sqlWriters[0].Empty()) + + var sqlSent bool + doneCh := make(chan struct{}) + go func() { + // Need to consume from sqlBufSendCh or Sink will block + for range s.sqlBufSendCh { + sqlSent = true + close(doneCh) // Signal that SQL was processed + return // Assume only one SQL for this test + } + }() + + output := &DecoderOutput{ + fromTs: types.BuildTS(3, 0), + toTs: types.BuildTS(4, 0), + outputTyp: OutputTypeSnapshot, // Can be any type + noMoreData: true, + } + s.Sink(ctx, output) + require.NoError(t, s.Error()) + + select { + case <-doneCh: + // SQL was sent and consumed + case <-time.After(1 * time.Second): + t.Fatal("timed out waiting for SQL to be sent on noMoreData") + } + require.True(t, sqlSent) + require.True(t, s.sqlWriters[0].Empty(), "CDC should be reset after noMoreData flush") + }) + +} + +func TestHnswSyncSinker_SendSql(t *testing.T) { + + dbTblInfo := newTestDbTableInfo() + sqlexecstub := gostub.Stub(&sqlExecutorFactory, mockSqlExecutorFactory) + defer sqlexecstub.Reset() + ctx, cancel := context.WithCancel(context.Background()) + defer cancel() + + watermarkUpdater := NewMockWatermarkUpdater(ctx) + + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 2) + sinker, _ := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", newTestDbTableInfo(), watermarkUpdater, tblDef, 0, 0, newTestActiveRoutine(), 1024, "1s") + s := sinker.(*indexSyncSinker) + defer s.Close() // Closes sqlBufSendCh + + t.Run("send sql happy path", func(t *testing.T) { + var err error + row1 := []any{int64(1), []float32{0.1, 0.2}} + row2 := []any{int64(2), []float32{0.3, 0.4}} + + s.Reset() + err = s.sqlWriters[0].Upsert(ctx, row1) + require.NoError(t, err) + err = s.sqlWriters[0].Delete(ctx, row2) + require.NoError(t, err) + /* + s.cdc.Start = "ts1" + s.cdc.End = "ts2" + */ + + var receivedSql []byte + var wg sync.WaitGroup + wg.Add(1) + go func() { + defer wg.Done() + receivedSql = <-s.sqlBufSendCh + }() + + err = s.sendSql(s.sqlWriters[0]) + require.NoError(t, err) + wg.Wait() // Wait for the goroutine to receive the SQL + + require.NotNil(t, receivedSql) + sqlStr := string(receivedSql) + + /* + expectedJsonPayload, _ := json.Marshal(map[string]any{ + "start_ts": s.cdc.Start, // These were reset before json was made + "end_ts": s.cdc.End, + "op_type": "hnsw_cdc_v1", + "upserts": []map[string]any{{"pk": int64(1), "vector": []float32{0.1, 0.2}}}, + "deletes": []int64{int64(2)}, + }) + */ + + // The cdc.Start and cdc.End are part of the ToJson output, but sendSql resets cdc *after* ToJson + // So we need to capture the state of cdc *before* it's reset for the expected JSON. + // Let's reconstruct the expected JSON more carefully. + writer, err := NewHnswSqlWriter("hnsw", dbTblInfo, tblDef, tblDef.Indexes) + require.NoError(t, err) + writer.Upsert(ctx, row1) + writer.Delete(ctx, row2) + /* + cdcForJson.Start = "ts1" + cdcForJson.End = "ts2" + */ + expectedSqlBytes, _ := writer.ToSql() + require.Equal(t, string(expectedSqlBytes), sqlStr) + require.True(t, s.sqlWriters[0].Empty(), "CDC should be reset after sending SQL") + }) + + t.Run("send sql empty cdc", func(t *testing.T) { + s.Reset() // Ensure CDC is empty + err := s.sendSql(s.sqlWriters[0]) + require.NoError(t, err) + select { + case <-s.sqlBufSendCh: + t.Fatal("SQL should not have been sent for empty CDC") + case <-time.After(50 * time.Millisecond): + // Expected behavior + } + }) +} + +func TestHnswSyncSinker_ErrorHandling(t *testing.T) { + sqlexecstub := gostub.Stub(&sqlExecutorFactory, mockSqlExecutorFactory) + defer sqlexecstub.Reset() + + s := &indexSyncSinker{} // Minimal struct for error testing + s.err.Store((*error)(nil)) // Initialize with nil error pointer + + require.Nil(t, s.Error()) + + testErr := moerr.NewInternalErrorNoCtx("test error") + s.SetError(testErr) + err := s.Error() + require.Error(t, err) + require.Equal(t, "internal error: test error", err.Error()) + + // Test with moerr + moTestErr := moerr.NewInternalErrorNoCtx("mo test error") + s.SetError(moTestErr) + err = s.Error() + require.Error(t, err) + require.True(t, moerr.IsMoErrCode(err, moerr.ErrInternal)) + require.Equal(t, moTestErr.Error(), err.Error()) + + s.ClearError() + require.Nil(t, s.Error()) +} + +func TestHnswSyncSinker_Sink_AtomicBatch(t *testing.T) { + + proc := testutil.NewProcess(t) + + dbTblInfo := newTestDbTableInfo() + ctx := context.Background() + sqlexecstub := gostub.Stub(&sqlExecutorFactory, mockSqlExecutorFactory) + defer sqlexecstub.Reset() + + watermarkUpdater := NewMockWatermarkUpdater(ctx) + + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 2) + sinker, _ := NewIndexSyncSinker("test-uuid", UriInfo{}, 0, "taskid", newTestDbTableInfo(), watermarkUpdater, tblDef, 0, 0, newTestActiveRoutine(), 1024, "1s") + s := sinker.(*indexSyncSinker) + defer s.Close() // Closes sqlBufSendCh + + bat := testutil.NewBatchWithVectors( + []*vector.Vector{ + testutil.NewVector(2, types.T_int64.ToType(), proc.Mp(), false, []int64{1, 2}), + testutil.NewVector(2, types.T_array_float32.ToType(), proc.Mp(), false, [][]float32{{0.1, 0.2}, {0.3, 0.4}}), + testutil.NewVector(2, types.T_int32.ToType(), proc.Mp(), false, []int64{1, 2}), + }, nil) + defer bat.Clean(testutil.TestUtilMp) + + fromTs := types.BuildTS(1, 0) + insertAtomicBat := &AtomicBatch{ + Mp: nil, + Batches: []*batch.Batch{bat}, + Rows: btree.NewBTreeGOptions(AtomicBatchRow.Less, btree.Options{Degree: 64}), + } + insertAtomicBat.Rows.Set(AtomicBatchRow{Ts: fromTs, Pk: []byte{1}, Offset: 0, Src: bat}) + insertAtomicBat.Rows.Set(AtomicBatchRow{Ts: fromTs, Pk: []byte{2}, Offset: 1, Src: bat}) + + delbat := testutil.NewBatchWithVectors( + []*vector.Vector{ + testutil.NewVector(2, types.T_int64.ToType(), proc.Mp(), false, []int64{1, 2}), + testutil.NewVector(2, types.T_array_float32.ToType(), proc.Mp(), false, [][]float32{{0.1, 0.2}, {0.3, 0.4}}), + testutil.NewVector(2, types.T_int32.ToType(), proc.Mp(), false, []int64{1, 2}), + }, nil) + + defer delbat.Clean(testutil.TestUtilMp) + + delfromTs := types.BuildTS(2, 0) + delAtomicBat := &AtomicBatch{ + Mp: nil, + Batches: []*batch.Batch{delbat}, + Rows: btree.NewBTreeGOptions(AtomicBatchRow.Less, btree.Options{Degree: 64}), + } + delAtomicBat.Rows.Set(AtomicBatchRow{Ts: delfromTs, Pk: []byte{1}, Offset: 0, Src: bat}) + delAtomicBat.Rows.Set(AtomicBatchRow{Ts: delfromTs, Pk: []byte{2}, Offset: 1, Src: bat}) + + dout := &DecoderOutput{ + fromTs: types.BuildTS(1, 0), + toTs: types.BuildTS(2, 0), + outputTyp: OutputTypeTail, + insertAtmBatch: insertAtomicBat, + deleteAtmBatch: delAtomicBat, + } + + var receivedSql []byte + var wg sync.WaitGroup + wg.Add(1) + go func() { + defer wg.Done() + receivedSql = <-s.sqlBufSendCh + require.NotNil(t, receivedSql) + }() + + s.Sink(context.Background(), dout) + + wg.Wait() // Wait for the goroutine to receive the SQL + sqlStr := string(receivedSql) + + row1 := []any{int64(1), []float32{0.1, 0.2}} + row2 := []any{int64(2), []float32{0.3, 0.4}} + + writer, _ := NewHnswSqlWriter("hnsw", dbTblInfo, tblDef, tblDef.Indexes) + writer.Upsert(ctx, row1) + writer.Upsert(ctx, row2) + writer.Delete(ctx, row1) + writer.Delete(ctx, row2) + /* + cdcForJson.Start = "1-0" + cdcForJson.End = "2-0" + */ + expectedSqlBytes, _ := writer.ToSql() + + require.Equal(t, string(expectedSqlBytes), sqlStr) + require.True(t, s.sqlWriters[0].Empty(), "CDC should be reset after sending SQL") + +} diff --git a/pkg/cdc/index_sqlwriter.go b/pkg/cdc/index_sqlwriter.go new file mode 100644 index 0000000000000..57c1ce70dee07 --- /dev/null +++ b/pkg/cdc/index_sqlwriter.go @@ -0,0 +1,647 @@ +// Copyright 2024 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package cdc + +import ( + "context" + "encoding/json" + "fmt" + "strings" + + "github.com/matrixorigin/matrixone/pkg/catalog" + "github.com/matrixorigin/matrixone/pkg/common/moerr" + "github.com/matrixorigin/matrixone/pkg/container/types" + "github.com/matrixorigin/matrixone/pkg/pb/plan" + "github.com/matrixorigin/matrixone/pkg/vectorindex" +) + +const ( + MAX_CDC_DATA_SIZE = 8192 +) + +// IndexSqlWriter interface +type IndexSqlWriter interface { + CheckLastOp(op string) bool + Upsert(ctx context.Context, row []any) error + Insert(ctx context.Context, row []any) error + Delete(ctx context.Context, row []any) error + Full() bool + ToSql() ([]byte, error) + Reset() + Empty() bool +} + +// Base implementation of IVFFLAT and FULLTEXT. Their implementation are simliar. +type BaseIndexSqlWriter struct { + lastCdcOp string + vbuf []byte + ndata int + param string + tabledef *plan.TableDef + indexdef []*plan.IndexDef + dbTblInfo *DbTableInfo + algo string + pkPos int32 + pkType *types.Type + partsPos []int32 + partsType []*types.Type + srcPos []int32 + srcType []*types.Type + dbName string +} + +// Fulltext Sql Writer. Only one hidden secondary index table +type FulltextSqlWriter struct { + BaseIndexSqlWriter + indexTableName string +} + +// Ivfflat Sql writer. Three hidden secondary index tables +type IvfflatSqlWriter struct { + BaseIndexSqlWriter + centroids_tbl string + entries_tbl string + meta_tbl string + ivfparam vectorindex.IvfParam +} + +// Hnsw Sql Writer. Use the vectorindex.VectorIndeXCdc JSON format +type HnswSqlWriter[T types.RealNumbers] struct { + cdc *vectorindex.VectorIndexCdc[T] + meta vectorindex.HnswCdcParam + tabledef *plan.TableDef + indexdef []*plan.IndexDef + dbTblInfo *DbTableInfo + pkPos int32 + pkType *types.Type + partsPos []int32 + partsType []*types.Type + srcPos []int32 + srcType []*types.Type + dbName string +} + +// check FulltextSqlWriter is the interface of IndexSqlWriter +var _ IndexSqlWriter = new(FulltextSqlWriter) +var _ IndexSqlWriter = new(IvfflatSqlWriter) +var _ IndexSqlWriter = new(HnswSqlWriter[float32]) + +// check algo type to return the correct sql writer +func NewIndexSqlWriter(algo string, dbTblInfo *DbTableInfo, tabledef *plan.TableDef, indexdef []*plan.IndexDef) (IndexSqlWriter, error) { + algo = catalog.ToLower(algo) + switch algo { + case catalog.MOIndexFullTextAlgo.ToString(): + return NewFulltextSqlWriter(algo, dbTblInfo, tabledef, indexdef) + case catalog.MoIndexIvfFlatAlgo.ToString(): + return NewIvfflatSqlWriter(algo, dbTblInfo, tabledef, indexdef) + case catalog.MoIndexHnswAlgo.ToString(): + return NewHnswSqlWriter(algo, dbTblInfo, tabledef, indexdef) + default: + return IndexSqlWriter(nil), moerr.NewInternalErrorNoCtx("IndexSqlWriter: invalid algo type") + + } +} + +// Implementation of Base Index SqlWriter +func (w *BaseIndexSqlWriter) Full() bool { + return w.ndata >= MAX_CDC_DATA_SIZE +} + +// return true when last op is empty or last op == current op +func (w *BaseIndexSqlWriter) CheckLastOp(op string) bool { + return len(w.lastCdcOp) == 0 || w.lastCdcOp == op +} + +func (w *BaseIndexSqlWriter) writeRow(ctx context.Context, row []any) error { + var err error + + w.vbuf = appendString(w.vbuf, "ROW(") + + // pk + if w.tabledef.Pkey.PkeyColName == catalog.CPrimaryKeyColName { + cpkType := &types.Type{Oid: types.T_varbinary, Width: w.pkType.Width, Scale: w.pkType.Scale} + w.vbuf, err = convertColIntoSql(ctx, row[w.pkPos], cpkType, w.vbuf) + if err != nil { + return err + } + } else { + w.vbuf, err = convertColIntoSql(ctx, row[w.pkPos], w.pkType, w.vbuf) + if err != nil { + return err + } + } + + for i, t := range w.partsType { + w.vbuf = appendString(w.vbuf, ",") + pos := w.partsPos[i] + w.vbuf, err = convertColIntoSql(ctx, row[pos], t, w.vbuf) + if err != nil { + return err + } + } + + w.vbuf = appendString(w.vbuf, ")") + w.ndata += 1 + return nil +} + +func (w *BaseIndexSqlWriter) writeDeleteRow(ctx context.Context, row []any) error { + var err error + + if w.tabledef.Pkey.PkeyColName == catalog.CPrimaryKeyColName { + cpkType := &types.Type{Oid: types.T_varbinary, Width: w.pkType.Width, Scale: w.pkType.Scale} + w.vbuf, err = convertColIntoSql(ctx, row[0], cpkType, w.vbuf) + if err != nil { + return err + } + } else { + w.vbuf, err = convertColIntoSql(ctx, row[0], w.pkType, w.vbuf) + if err != nil { + return err + } + + } + w.ndata += 1 + return nil +} + +func (w *BaseIndexSqlWriter) Upsert(ctx context.Context, row []any) error { + + if len(w.lastCdcOp) == 0 { + // init + w.lastCdcOp = vectorindex.CDC_UPSERT + return w.writeRow(ctx, row) + + } + + if w.lastCdcOp != vectorindex.CDC_UPSERT { + // different from previous operation and generate SQL before append new UPSERT + return moerr.NewInternalErrorNoCtx("FulltextSqlWriter.Upsert: append different op") + } + + // same as previous operation and append to VALUES ROW(), ROW(),... + w.vbuf = appendString(w.vbuf, ",") + return w.writeRow(ctx, row) +} + +func (w *BaseIndexSqlWriter) Insert(ctx context.Context, row []any) error { + + if len(w.lastCdcOp) == 0 { + // init + w.lastCdcOp = vectorindex.CDC_INSERT + return w.writeRow(ctx, row) + + } + + if w.lastCdcOp != vectorindex.CDC_INSERT { + // different from previous operation and generate SQL before append new UPSERT + return moerr.NewInternalErrorNoCtx("FulltextSqlWriter.Insert: append different op") + } + + // same as previous operation and append to VALUES ROW(), ROW(),... + w.vbuf = appendString(w.vbuf, ",") + return w.writeRow(ctx, row) +} + +func (w *BaseIndexSqlWriter) Delete(ctx context.Context, row []any) error { + + if len(w.lastCdcOp) == 0 { + // init + w.lastCdcOp = vectorindex.CDC_DELETE + return w.writeDeleteRow(ctx, row) + } + + if w.lastCdcOp != vectorindex.CDC_DELETE { + // different from previous operation and generate SQL before append new UPSERT + return moerr.NewInternalErrorNoCtx("FulltextSqlWriter.Delete: append different op") + } + + // same as previous operation and append to IN () + w.vbuf = appendString(w.vbuf, ",") + return w.writeDeleteRow(ctx, row) +} + +func (w *BaseIndexSqlWriter) Reset() { + w.lastCdcOp = "" + w.vbuf = w.vbuf[:0] + w.ndata = 0 +} + +func (w *BaseIndexSqlWriter) Empty() bool { + return len(w.vbuf) == 0 +} + +// New Fulltext Sql Writer +func NewFulltextSqlWriter(algo string, dbTblInfo *DbTableInfo, tabledef *plan.TableDef, indexdef []*plan.IndexDef) (IndexSqlWriter, error) { + w := &FulltextSqlWriter{BaseIndexSqlWriter: BaseIndexSqlWriter{algo: algo, tabledef: tabledef, indexdef: indexdef, dbTblInfo: dbTblInfo, vbuf: make([]byte, 0, 1024)}} + + w.pkPos = tabledef.Name2ColIndex[tabledef.Pkey.PkeyColName] + typ := tabledef.Cols[w.pkPos].Typ + w.pkType = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + + nparts := len(w.indexdef[0].Parts) + w.partsPos = make([]int32, nparts) + w.partsType = make([]*types.Type, nparts) + + for i, part := range w.indexdef[0].Parts { + w.partsPos[i] = tabledef.Name2ColIndex[part] + typ = tabledef.Cols[w.partsPos[i]].Typ + w.partsType[i] = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + } + + w.srcPos = make([]int32, nparts+1) + w.srcType = make([]*types.Type, nparts+1) + + w.srcPos[0] = w.pkPos + w.srcType[0] = w.pkType + for i := range w.partsType { + w.srcPos[i+1] = w.partsPos[i] + w.srcType[i+1] = w.partsType[i] + } + + w.indexTableName = w.indexdef[0].IndexTableName + w.dbName = tabledef.DbName + + return w, nil +} + +// with src as (select cast(serial(cast(column_0 as bigint), cast(column_1 as bigint)) as varchar) as id, column_2 as body, column_3 as title from +// (values row(1, 2, 'body', 'title'), row(2, 3, 'body is heavy', 'I do not know'))) select f.* from src +// cross apply fulltext_index_tokenize('{"parser":"ngram"}', 61, id, body, title) as f; +func (w *FulltextSqlWriter) ToSql() ([]byte, error) { + defer w.Reset() + + if len(w.lastCdcOp) == 0 { + return nil, nil + } + + switch w.lastCdcOp { + case vectorindex.CDC_DELETE: + return w.toFulltextDelete() + case vectorindex.CDC_UPSERT: + return w.toFulltextUpsert(true) + case vectorindex.CDC_INSERT: + return w.toFulltextUpsert(false) + default: + return nil, moerr.NewInternalErrorNoCtx("FulltextSqlWriter: invalid CDC type") + } +} + +func (w *FulltextSqlWriter) toFulltextDelete() ([]byte, error) { + sql := fmt.Sprintf("DELETE FROM `%s`.`%s` WHERE `%s` IN (%s)", w.dbTblInfo.SinkDbName, w.indexTableName, catalog.FullTextIndex_TabCol_Id, string(w.vbuf)) + return []byte(sql), nil +} + +func (w *FulltextSqlWriter) toFulltextUpsert(upsert bool) ([]byte, error) { + + var sql string + + coldefs := make([]string, 0, len(w.srcPos)) + cnames := make([]string, 0, len(w.srcPos)) + for i, pos := range w.srcPos { + typstr := w.srcType[i].DescString() + coldefs = append(coldefs, fmt.Sprintf("CAST(column_%d as %s) as `%s`", i, typstr, w.tabledef.Cols[pos].Name)) + cnames = append(cnames, w.tabledef.Cols[pos].Name) + } + + cols := strings.Join(coldefs, ", ") + cnames_str := strings.Join(cnames, ", ") + + if !upsert { + sql += fmt.Sprintf("REPLACE INTO `%s`.`%s` ", w.dbName, w.indexTableName) + } else { + sql += fmt.Sprintf("INSERT INTO `%s`.`%s` ", w.dbName, w.indexTableName) + } + + sql += fmt.Sprintf("WITH src as (SELECT %s FROM (VALUES %s)) ", cols, string(w.vbuf)) + sql += fmt.Sprintf("SELECT f.* FROM src CROSS APPLY fulltext_index_tokenize('%s', %d, %s) as f", w.param, w.pkType.Oid, cnames_str) + + return []byte(sql), nil +} + +// Implementation of HNSW Sql writer +func NewHnswSqlWriter(algo string, dbTblInfo *DbTableInfo, tabledef *plan.TableDef, indexdef []*plan.IndexDef) (IndexSqlWriter, error) { + w := &HnswSqlWriter[float32]{tabledef: tabledef, indexdef: indexdef, dbTblInfo: dbTblInfo, cdc: vectorindex.NewVectorIndexCdc[float32]()} + + // check the tabledef and indexdef + if len(tabledef.Pkey.Names) != 1 { + return nil, moerr.NewInternalErrorNoCtx("hnsw index table only have one primary key") + } + + if len(indexdef) != 2 { + return nil, moerr.NewInternalErrorNoCtx("hnsw index table must have 2 secondary tables") + } + + idxdef := indexdef[0] + if len(idxdef.Parts) != 1 { + return nil, moerr.NewInternalErrorNoCtx("hnsw index table only have one vector part") + } + + paramstr := idxdef.IndexAlgoParams + var meta, storage string + for _, idx := range indexdef { + if idx.IndexAlgoTableType == catalog.Hnsw_TblType_Metadata { + meta = idx.IndexTableName + } + if idx.IndexAlgoTableType == catalog.Hnsw_TblType_Storage { + storage = idx.IndexTableName + } + } + + if len(meta) == 0 || len(storage) == 0 { + return nil, moerr.NewInternalErrorNoCtx("hnsw index table either meta or storage hidden index table not exist") + } + + var hnswparam vectorindex.HnswParam + if len(paramstr) > 0 { + err := json.Unmarshal([]byte(paramstr), &hnswparam) + if err != nil { + return nil, moerr.NewInternalErrorNoCtx("hnsw sync sinker. failed to convert hnsw param json") + } + } + + w.pkPos = tabledef.Name2ColIndex[tabledef.Pkey.PkeyColName] + typ := tabledef.Cols[w.pkPos].Typ + w.pkType = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + + if w.pkType.Oid != types.T_int64 { + return nil, moerr.NewInternalErrorNoCtx("NewHnswSqlWriter: primary key is not bigint") + } + + nparts := len(idxdef.Parts) + w.partsPos = make([]int32, nparts) + w.partsType = make([]*types.Type, nparts) + + for i, part := range idxdef.Parts { + w.partsPos[i] = tabledef.Name2ColIndex[part] + typ = tabledef.Cols[w.partsPos[i]].Typ + w.partsType[i] = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + } + + if w.partsType[0].Oid != types.T_array_float32 { + return nil, moerr.NewInternalErrorNoCtx("NewHnswSqlWriter: part is not vecf32") + } + + w.srcPos = make([]int32, nparts+1) + w.srcType = make([]*types.Type, nparts+1) + + w.srcPos[0] = w.pkPos + w.srcType[0] = w.pkType + for i := range w.partsType { + w.srcPos[i+1] = w.partsPos[i] + w.srcType[i+1] = w.partsType[i] + } + + w.dbName = tabledef.DbName + + w.meta = vectorindex.HnswCdcParam{ + MetaTbl: meta, + IndexTbl: storage, + DbName: dbTblInfo.SinkDbName, + Table: dbTblInfo.SinkTblName, + Params: hnswparam, + Dimension: tabledef.Cols[w.partsPos[0]].Typ.Width, + } + + return w, nil +} + +func (w *HnswSqlWriter[T]) Reset() { + w.cdc.Data = w.cdc.Data[:0] +} + +func (w *HnswSqlWriter[T]) Full() bool { + return len(w.cdc.Data) >= cap(w.cdc.Data) +} + +func (w *HnswSqlWriter[T]) Empty() bool { + return len(w.cdc.Data) == 0 +} + +func (w *HnswSqlWriter[T]) CheckLastOp(op string) bool { + return true +} + +func (w *HnswSqlWriter[T]) Insert(ctx context.Context, row []any) error { + key, ok := row[w.pkPos].(int64) + if !ok { + return moerr.NewInternalError(ctx, "invalid key type. not int64") + } + v, ok := row[w.partsPos[0]].([]T) + if !ok { + return moerr.NewInternalError(ctx, "invalid vector type. not []float32") + } + + if v == nil { + // vector is nil, do Delete + w.cdc.Delete(key) + return nil + } + + w.cdc.Insert(key, v) + return nil +} + +func (w *HnswSqlWriter[T]) Upsert(ctx context.Context, row []any) error { + key, ok := row[w.pkPos].(int64) + if !ok { + return moerr.NewInternalError(ctx, "invalid key type. not int64") + } + v, ok := row[w.partsPos[0]].([]T) + if !ok { + return moerr.NewInternalError(ctx, "invalid vector type. not []float32") + } + + if v == nil { + // vector is nil, do Delete + w.cdc.Delete(key) + return nil + } + + w.cdc.Upsert(key, v) + return nil +} + +func (w *HnswSqlWriter[T]) Delete(ctx context.Context, row []any) error { + // first column is the primary key + key, ok := row[0].(int64) + if !ok { + return moerr.NewInternalError(ctx, "invalid key type. not int64") + } + w.cdc.Delete(key) + return nil +} + +func (w *HnswSqlWriter[T]) ToSql() ([]byte, error) { + + // generate sql from cdc + js, err := w.cdc.ToJson() + if err != nil { + return nil, err + } + // pad extra space at the front and send SQL + sql := fmt.Sprintf("SELECT hnsw_cdc_update('%s', '%s', %d, '%s');", w.meta.DbName, w.meta.Table, w.meta.Dimension, js) + + return []byte(sql), nil +} + +// Implementation of Ivfflat Sql writer +func NewIvfflatSqlWriter(algo string, dbTblInfo *DbTableInfo, tabledef *plan.TableDef, indexdef []*plan.IndexDef) (IndexSqlWriter, error) { + w := &IvfflatSqlWriter{BaseIndexSqlWriter: BaseIndexSqlWriter{algo: algo, tabledef: tabledef, indexdef: indexdef, dbTblInfo: dbTblInfo, vbuf: make([]byte, 0, 1024)}} + + if len(indexdef) != 3 { + return nil, moerr.NewInternalErrorNoCtx("ivf index table must have 3 secondary tables") + } + + idxdef := indexdef[0] + if len(idxdef.Parts) != 1 { + return nil, moerr.NewInternalErrorNoCtx("ivf index table only have one vector part") + } + + paramstr := idxdef.IndexAlgoParams + var centroids_tbl, entries_tbl, meta_tbl string + for _, idx := range indexdef { + if idx.IndexAlgoTableType == catalog.SystemSI_IVFFLAT_TblType_Metadata { + meta_tbl = idx.IndexTableName + } + if idx.IndexAlgoTableType == catalog.SystemSI_IVFFLAT_TblType_Centroids { + centroids_tbl = idx.IndexTableName + } + if idx.IndexAlgoTableType == catalog.SystemSI_IVFFLAT_TblType_Entries { + entries_tbl = idx.IndexTableName + } + } + + if len(centroids_tbl) == 0 || len(entries_tbl) == 0 || len(meta_tbl) == 0 { + return nil, moerr.NewInternalErrorNoCtx("ivf index table either meta or centroids or entries hidden index table not exist") + } + + var ivfparam vectorindex.IvfParam + if len(paramstr) > 0 { + err := json.Unmarshal([]byte(paramstr), &ivfparam) + if err != nil { + return nil, moerr.NewInternalErrorNoCtx("ivf sync sinker. failed to convert ivf param json") + } + } + + w.ivfparam = ivfparam + + w.pkPos = tabledef.Name2ColIndex[tabledef.Pkey.PkeyColName] + typ := tabledef.Cols[w.pkPos].Typ + w.pkType = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + + nparts := len(w.indexdef[0].Parts) + w.partsPos = make([]int32, nparts) + w.partsType = make([]*types.Type, nparts) + + for i, part := range w.indexdef[0].Parts { + w.partsPos[i] = tabledef.Name2ColIndex[part] + typ = tabledef.Cols[w.partsPos[i]].Typ + w.partsType[i] = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + } + + w.srcPos = make([]int32, nparts+1) + w.srcType = make([]*types.Type, nparts+1) + + w.srcPos[0] = w.pkPos + w.srcType[0] = w.pkType + for i := range w.partsType { + w.srcPos[i+1] = w.partsPos[i] + w.srcType[i+1] = w.partsType[i] + } + + w.centroids_tbl = centroids_tbl + w.entries_tbl = entries_tbl + w.meta_tbl = meta_tbl + + return w, nil +} + +// REPLACE INTO __mo_index_secondary_0197786c-285f-70cb-9337-e484a3ff92c4(__mo_index_centroid_fk_version, __mo_index_centroid_fk_id, __mo_index_pri_col, __mo_index_centroid_fk_entry) +// with centroid as (select * from __mo_index_secondary_0197786c-285f-70bb-b277-2cef56da590a where __mo_index_centroid_version = 0), +// src as (select column_0 as id, cast(column_1 as vecf32(3)) as embed from (values row(2005,'[0.4532634, 0.7297859, 0.48885703]'), row(2009, '[0.68150306, 0.6950923, 0.16590895] '))) +// select __mo_index_centroid_version, __mo_index_centroid_id, id, embed from src centroidx('vector_l2_ops') join centroid using (__mo_index_centroid, embed); +func (w *IvfflatSqlWriter) ToSql() ([]byte, error) { + defer w.Reset() + + if len(w.lastCdcOp) == 0 { + return nil, nil + } + + switch w.lastCdcOp { + case vectorindex.CDC_DELETE: + return w.toIvfflatDelete() + case vectorindex.CDC_UPSERT: + return w.toIvfflatUpsert(true) + case vectorindex.CDC_INSERT: + return w.toIvfflatUpsert(false) + default: + return nil, moerr.NewInternalErrorNoCtx("IvfflatSqlWriter: invalid CDC type") + } +} + +// catalog.SystemSI_IVFFLAT_TblCol_Entries_version +// catalog.SystemSI_IVFFLAT_TblCol_Entries_pk +// catalog.CPrimaryKeyColName +func (w *IvfflatSqlWriter) toIvfflatDelete() ([]byte, error) { + sql := fmt.Sprintf("DELETE FROM `%s`.`%s` WHERE `%s` IN (%s)", w.dbTblInfo.SinkDbName, w.entries_tbl, + catalog.SystemSI_IVFFLAT_TblCol_Entries_pk, + string(w.vbuf)) + return []byte(sql), nil + +} + +func (w *IvfflatSqlWriter) toIvfflatUpsert(upsert bool) ([]byte, error) { + + var sql string + + coldefs := make([]string, 0, len(w.srcPos)) + cnames := make([]string, 0, len(w.srcPos)) + for i := range w.srcPos { + typstr := w.srcType[i].DescString() + cnames = append(cnames, fmt.Sprintf("src%d", i)) + coldefs = append(coldefs, fmt.Sprintf("CAST(column_%d as %s) as `%s`", i, typstr, cnames[i])) + } + + cols := strings.Join(coldefs, ", ") + cnames_str := strings.Join(cnames, ", ") + + if !upsert { + sql += fmt.Sprintf("REPLACE INTO `%s`.`%s` ", w.dbTblInfo.SinkDbName, w.entries_tbl) + } else { + sql += fmt.Sprintf("INSERT INTO `%s`.`%s` ", w.dbTblInfo.SinkDbName, w.entries_tbl) + } + + sql += fmt.Sprintf("(`%s`, `%s`, `%s`, `%s`) ", + catalog.SystemSI_IVFFLAT_TblCol_Entries_version, + catalog.SystemSI_IVFFLAT_TblCol_Entries_id, + catalog.SystemSI_IVFFLAT_TblCol_Entries_pk, + catalog.SystemSI_IVFFLAT_TblCol_Entries_entry) + + versql := fmt.Sprintf("SELECT CAST(%s as BIGINT) FROM `%s`.`%s` WHERE `%s` = 'version'", catalog.SystemSI_IVFFLAT_TblCol_Metadata_val, + w.dbTblInfo.SinkDbName, w.meta_tbl, catalog.SystemSI_IVFFLAT_TblCol_Metadata_key) + + sql += fmt.Sprintf("WITH centroid as (SELECT * FROM `%s`.`%s` WHERE `%s` = (%s) ), ", w.dbTblInfo.SinkDbName, w.centroids_tbl, catalog.SystemSI_IVFFLAT_TblCol_Centroids_version, versql) + sql += fmt.Sprintf("src as (SELECT %s FROM (VALUES %s)) ", cols, string(w.vbuf)) + sql += fmt.Sprintf("SELECT `%s`, `%s`, %s FROM src CENTROIDX('%s') JOIN centroid using (`%s`, `%s`)", + catalog.SystemSI_IVFFLAT_TblCol_Centroids_version, + catalog.SystemSI_IVFFLAT_TblCol_Centroids_id, + cnames_str, + w.ivfparam.OpType, + catalog.SystemSI_IVFFLAT_TblCol_Centroids_centroid, + cnames[1]) + + return []byte(sql), nil +} diff --git a/pkg/cdc/index_sqlwriter_test.go b/pkg/cdc/index_sqlwriter_test.go new file mode 100644 index 0000000000000..b43ef851fb085 --- /dev/null +++ b/pkg/cdc/index_sqlwriter_test.go @@ -0,0 +1,238 @@ +// Copyright 2024 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package cdc + +import ( + "context" + "fmt" + "testing" + + "github.com/matrixorigin/matrixone/pkg/catalog" + "github.com/matrixorigin/matrixone/pkg/container/types" + "github.com/matrixorigin/matrixone/pkg/pb/plan" + "github.com/stretchr/testify/require" +) + +func newTestIvfflatTableDef(pkName string, pkType types.T, vecColName string, vecType types.T, vecWidth int32) *plan.TableDef { + return &plan.TableDef{ + Name: "test_orig_tbl", + Name2ColIndex: map[string]int32{ + pkName: 0, + vecColName: 1, + "dummy": 2, // Add another col to make sure pk/vec col indices are used + }, + Cols: []*plan.ColDef{ + {Name: pkName, Typ: plan.Type{Id: int32(pkType)}}, + {Name: vecColName, Typ: plan.Type{Id: int32(vecType), Width: vecWidth}}, + {Name: "dummy", Typ: plan.Type{Id: int32(types.T_int32)}}, + }, + Pkey: &plan.PrimaryKeyDef{ + Names: []string{pkName}, + PkeyColName: pkName, + }, + Indexes: []*plan.IndexDef{ + { + IndexName: "ivfidx", + TableExist: true, + IndexAlgo: catalog.MoIndexIvfFlatAlgo.ToString(), + IndexAlgoTableType: catalog.SystemSI_IVFFLAT_TblType_Metadata, + IndexTableName: "meta_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"lists":"16","op_type":"vector_l2_ops"}`, + }, + { + IndexName: "ivfidx", + TableExist: true, + IndexAlgo: catalog.MoIndexIvfFlatAlgo.ToString(), + IndexAlgoTableType: catalog.SystemSI_IVFFLAT_TblType_Centroids, + IndexTableName: "centroids_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"lists":"16","op_type":"vector_l2_ops"}`, + }, + { + IndexName: "ivfidx", + TableExist: true, + IndexAlgo: catalog.MoIndexIvfFlatAlgo.ToString(), + IndexAlgoTableType: catalog.SystemSI_IVFFLAT_TblType_Entries, + IndexTableName: "entries_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"lists":"16","op_type":"vector_l2_ops"}`, + }, + }, + DbName: "mydb", + } +} + +func newTestFulltextTableDef(pkName string, pkType types.T, vecColName string, vecType types.T, vecWidth int32) *plan.TableDef { + return &plan.TableDef{ + Name: "test_orig_tbl", + Name2ColIndex: map[string]int32{ + pkName: 0, + vecColName: 1, + "dummy": 2, // Add another col to make sure pk/vec col indices are used + }, + Cols: []*plan.ColDef{ + {Name: pkName, Typ: plan.Type{Id: int32(pkType)}}, + {Name: vecColName, Typ: plan.Type{Id: int32(vecType), Width: vecWidth}}, + {Name: "dummy", Typ: plan.Type{Id: int32(types.T_int32)}}, + }, + Pkey: &plan.PrimaryKeyDef{ + Names: []string{pkName}, + PkeyColName: pkName, + }, + Indexes: []*plan.IndexDef{ + { + IndexName: "fulltext_idx", + TableExist: true, + IndexAlgo: catalog.MOIndexFullTextAlgo.ToString(), + IndexAlgoTableType: "", + IndexTableName: "fulltext_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"parser":"ngram"}`, + }, + }, + DbName: "mydb", + } +} + +func newTestFulltextTableDef2Parts(pkName string, pkType types.T, vecColName string, vecColName2 string, vecType types.T, vecWidth int32) *plan.TableDef { + return &plan.TableDef{ + Name: "test_orig_tbl", + Name2ColIndex: map[string]int32{ + pkName: 0, + vecColName: 1, + vecColName2: 2, + "dummy": 3, // Add another col to make sure pk/vec col indices are used + }, + Cols: []*plan.ColDef{ + {Name: pkName, Typ: plan.Type{Id: int32(pkType)}}, + {Name: vecColName, Typ: plan.Type{Id: int32(vecType), Width: vecWidth}}, + {Name: vecColName2, Typ: plan.Type{Id: int32(vecType), Width: vecWidth}}, + {Name: "dummy", Typ: plan.Type{Id: int32(types.T_int32)}}, + }, + Pkey: &plan.PrimaryKeyDef{ + Names: []string{pkName}, + PkeyColName: pkName, + }, + Indexes: []*plan.IndexDef{ + { + IndexName: "fulltext_idx", + TableExist: true, + IndexAlgo: catalog.MOIndexFullTextAlgo.ToString(), + IndexAlgoTableType: "", + IndexTableName: "fulltext_tbl", + Parts: []string{vecColName, vecColName2}, + IndexAlgoParams: `{"parser":"ngram"}`, + }, + }, + DbName: "mydb", + } +} + +func TestNewFulltextSqlWriter(t *testing.T) { + var ctx context.Context + + tabledef := newTestFulltextTableDef("id", types.T_int64, "body", types.T_varchar, 256) + dbTableInfo := newTestDbTableInfo() + + writer, err := NewIndexSqlWriter("fulltext", dbTableInfo, tabledef, tabledef.Indexes) + require.Nil(t, err) + + row := []any{int64(1000), []uint8("hello world"), nil} + err = writer.Upsert(ctx, row) + require.Nil(t, err) + + row = []any{int64(2000), []uint8("hello world"), nil} + err = writer.Upsert(ctx, row) + require.Nil(t, err) + + bytes, err := writer.ToSql() + require.Nil(t, err) + fmt.Println(string(bytes)) + +} + +func TestNewFulltextSqlWriterCPkey(t *testing.T) { + var ctx context.Context + + tabledef := newTestFulltextTableDef2Parts("__mo_cpkey", types.T_varbinary, "body", "title", types.T_varchar, 256) + dbTableInfo := newTestDbTableInfo() + + writer, err := NewIndexSqlWriter("fulltext", dbTableInfo, tabledef, tabledef.Indexes) + require.Nil(t, err) + + row := []any{[]uint8("abcdef12"), []uint8("hello world"), []uint8("one title"), nil} + err = writer.Upsert(ctx, row) + require.Nil(t, err) + + row = []any{[]uint8("abc"), []uint8("hello world"), []uint8("two title"), nil} + err = writer.Upsert(ctx, row) + require.Nil(t, err) + + bytes, err := writer.ToSql() + require.Nil(t, err) + fmt.Println(string(bytes)) + +} + +func TestNewHnswSqlWriter(t *testing.T) { + var ctx context.Context + + tabledef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 3) + dbTableInfo := newTestDbTableInfo() + + writer, err := NewHnswSqlWriter("fulltext", dbTableInfo, tabledef, tabledef.Indexes) + require.Nil(t, err) + row := []any{int64(1000), []float32{1, 2, 3}, nil} + err = writer.Upsert(ctx, row) + require.Nil(t, err) + + row = []any{int64(2000), []float32{5, 6, 7}, nil} + err = writer.Insert(ctx, row) + require.Nil(t, err) + + row = []any{int64(3000), []float32{5, 6, 7}, nil} + err = writer.Delete(ctx, row) + require.Nil(t, err) + + bytes, err := writer.ToSql() + require.Nil(t, err) + fmt.Println(string(bytes)) +} + +func TestNewIvfflatSqlWriter(t *testing.T) { + var ctx context.Context + + tabledef := newTestIvfflatTableDef("pk", types.T_int64, "vec", types.T_array_float64, 3) + dbTableInfo := newTestDbTableInfo() + + writer, err := NewIvfflatSqlWriter("ivfflat", dbTableInfo, tabledef, tabledef.Indexes) + require.Nil(t, err) + row := []any{int64(1000), []float64{1, 2, 3}, nil} + err = writer.Insert(ctx, row) + require.Nil(t, err) + + row = []any{int64(2000), []float64{5, 6, 7}, nil} + err = writer.Insert(ctx, row) + require.Nil(t, err) + + row = []any{int64(3000), []float64{5, 6, 7}, nil} + err = writer.Insert(ctx, row) + require.Nil(t, err) + + bytes, err := writer.ToSql() + require.Nil(t, err) + fmt.Println(string(bytes)) +} diff --git a/pkg/cdc/sinker.go b/pkg/cdc/sinker.go index b9147b9f47486..835b307f8b3ed 100644 --- a/pkg/cdc/sinker.go +++ b/pkg/cdc/sinker.go @@ -54,6 +54,7 @@ var ( ) var NewSinker = func( + cnUUID string, sinkUri UriInfo, accountId uint64, taskId string, @@ -71,6 +72,10 @@ var NewSinker = func( return NewConsoleSinker(dbTblInfo, watermarkUpdater), nil } + if sinkUri.SinkTyp == CDCSinkType_IndexSync { + return NewIndexSyncSinker(cnUUID, sinkUri, accountId, taskId, dbTblInfo, watermarkUpdater, tableDef, retryTimes, retryDuration, ar, maxSqlLength, sendSqlTimeout) + } + var ( err error sink Sink @@ -511,7 +516,8 @@ func (s *mysqlSinker) SendDummy() { } func (s *mysqlSinker) Error() error { - if errPtr := s.err.Load().(*error); *errPtr != nil { + if ptr := s.err.Load(); ptr != nil { + errPtr := ptr.(*error) if moErr, ok := (*errPtr).(*moerr.Error); !ok { return moerr.ConvertGoError(context.Background(), *errPtr) } else { diff --git a/pkg/cdc/sinker_test.go b/pkg/cdc/sinker_test.go index c3a59ae655023..677047bb161d3 100644 --- a/pkg/cdc/sinker_test.go +++ b/pkg/cdc/sinker_test.go @@ -147,6 +147,7 @@ func TestNewSinker(t *testing.T) { defer sinkerStub.Reset() got, err := NewSinker( + "", tt.args.sinkUri, tt.args.accountId, tt.args.taskId, diff --git a/pkg/cdc/types.go b/pkg/cdc/types.go index ed94a337ea4ec..4dedf35bfcf42 100644 --- a/pkg/cdc/types.go +++ b/pkg/cdc/types.go @@ -52,9 +52,10 @@ const ( ) const ( - CDCSinkType_MySQL = "mysql" - CDCSinkType_MO = "matrixone" - CDCSinkType_Console = "console" + CDCSinkType_MySQL = "mysql" + CDCSinkType_MO = "matrixone" + CDCSinkType_Console = "console" + CDCSinkType_IndexSync = "indexsync" ) const ( diff --git a/pkg/container/types/types.go b/pkg/container/types/types.go index e4eaedd653144..275cc93cfa25a 100644 --- a/pkg/container/types/types.go +++ b/pkg/container/types/types.go @@ -557,6 +557,10 @@ func (t Type) DescString() string { return fmt.Sprintf("DECIMAL(%d,%d)", t.Width, t.Scale) case T_decimal128: return fmt.Sprintf("DECIMAL(%d,%d)", t.Width, t.Scale) + case T_array_float32: + return fmt.Sprintf("VECF32(%d)", t.Width) + case T_array_float64: + return fmt.Sprintf("VECF64(%d)", t.Width) } return t.Oid.String() } diff --git a/pkg/frontend/cdc_exector.go b/pkg/frontend/cdc_exector.go index b6f0bab9e4ee4..a71be8620d700 100644 --- a/pkg/frontend/cdc_exector.go +++ b/pkg/frontend/cdc_exector.go @@ -562,6 +562,7 @@ func (exec *CDCTaskExecutor) addExecPipelineForTable( // step 2. new sinker sinker, err := cdc.NewSinker( + exec.cnUUID, exec.sinkUri, uint64(exec.spec.Accounts[0].GetId()), exec.spec.TaskId, diff --git a/pkg/frontend/cdc_options.go b/pkg/frontend/cdc_options.go index 6578754c3fdaf..e9049528f3ef2 100644 --- a/pkg/frontend/cdc_options.go +++ b/pkg/frontend/cdc_options.go @@ -124,7 +124,7 @@ func (opts *CDCCreateTaskOptions) ValidateAndFill( if cdc.EnableConsoleSink && opts.SinkType == cdc.CDCSinkType_Console { opts.UseConsole = true } - if !opts.UseConsole && opts.SinkType != cdc.CDCSinkType_MySQL && opts.SinkType != cdc.CDCSinkType_MO { + if !opts.UseConsole && opts.SinkType != cdc.CDCSinkType_MySQL && opts.SinkType != cdc.CDCSinkType_MO && opts.SinkType != cdc.CDCSinkType_IndexSync { err = moerr.NewInternalErrorf(ctx, "unsupported sink type: %s", req.SinkType) return } diff --git a/pkg/frontend/cdc_test.go b/pkg/frontend/cdc_test.go index aba0ee7de649e..3277b1c09fe86 100644 --- a/pkg/frontend/cdc_test.go +++ b/pkg/frontend/cdc_test.go @@ -3081,6 +3081,7 @@ func TestCdcTask_addExecPipelineForTable(t *testing.T) { stubSinker := gostub.Stub( &cdc.NewSinker, func( + string, cdc.UriInfo, uint64, string, diff --git a/pkg/fulltext/types.go b/pkg/fulltext/types.go index 40b7a1c9ec8ef..9c475f1f9119a 100644 --- a/pkg/fulltext/types.go +++ b/pkg/fulltext/types.go @@ -102,6 +102,7 @@ Run Eval() to get final answer and score // Parser parameters type FullTextParserParam struct { Parser string `json:"parser"` + Async string `json:"async"` } // Search accumulator is to parse the search string into list of pattern and each pattern will associate with WordAccum by pattern.Text diff --git a/pkg/iscp/consumer.go b/pkg/iscp/consumer.go index c5f74ac7902e1..62e3e42808a34 100644 --- a/pkg/iscp/consumer.go +++ b/pkg/iscp/consumer.go @@ -26,6 +26,9 @@ func NewConsumer( if info.ConsumerType == int8(ConsumerType_CNConsumer) { return NewInteralSqlConsumer(cnUUID, tableDef, jobID, info) } + if info.ConsumerType == int8(ConsumerType_IndexSync) { + return NewIndexConsumer(cnUUID, tableDef, jobID, info) + } panic("todo") } diff --git a/pkg/iscp/index_consumer.go b/pkg/iscp/index_consumer.go new file mode 100644 index 0000000000000..91c1a972cc18f --- /dev/null +++ b/pkg/iscp/index_consumer.go @@ -0,0 +1,424 @@ +// Copyright 2024 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package iscp + +import ( + "context" + "fmt" + "os" + "sync" + "time" + + "github.com/matrixorigin/matrixone/pkg/catalog" + "github.com/matrixorigin/matrixone/pkg/common/moerr" + "github.com/matrixorigin/matrixone/pkg/common/runtime" + "github.com/matrixorigin/matrixone/pkg/logutil" + "github.com/matrixorigin/matrixone/pkg/pb/plan" + "github.com/matrixorigin/matrixone/pkg/util/executor" + "github.com/matrixorigin/matrixone/pkg/vectorindex" +) + +/* IndexConsumer */ +type IndexEntry struct { + algo string + indexes []*plan.IndexDef +} + +var sqlExecutorFactory = _sqlExecutorFactory + +func _sqlExecutorFactory(cnUUID string) (executor.SQLExecutor, error) { + // sql executor + v, ok := runtime.ServiceRuntime(cnUUID).GetGlobalVariables(runtime.InternalSQLExecutor) + if !ok { + //os.Stderr.WriteString(fmt.Sprintf("sql executor create failed. cnUUID = %s\n", cnUUID)) + return nil, moerr.NewNotSupportedNoCtx("no implement sqlExecutor") + } + exec := v.(executor.SQLExecutor) + return exec, nil +} + +/* IndexConsumer */ +type IndexConsumer struct { + cnUUID string + jobID JobID + info *ConsumerInfo + tableDef *plan.TableDef + sqlWriter IndexSqlWriter + exec executor.SQLExecutor + rowdata []any + rowdelete []any + sqlBufSendCh chan []byte +} + +var _ Consumer = new(IndexConsumer) + +func NewIndexConsumer(cnUUID string, + tableDef *plan.TableDef, + jobID JobID, + info *ConsumerInfo) (Consumer, error) { + + exec, err := sqlExecutorFactory(cnUUID) + if err != nil { + return nil, err + } + + ie := &IndexEntry{indexes: make([]*plan.IndexDef, 0, 3)} + + for _, idx := range tableDef.Indexes { + if idx.TableExist && (catalog.IsHnswIndexAlgo(idx.IndexAlgo) || catalog.IsIvfIndexAlgo(idx.IndexAlgo) || catalog.IsFullTextIndexAlgo(idx.IndexAlgo)) { + key := idx.IndexName + if key == info.IndexName { + if len(ie.algo) == 0 { + ie.algo = idx.IndexAlgo + } + ie.indexes = append(ie.indexes, idx) + } + } + + } + + sqlwriter, err := NewIndexSqlWriter(ie.algo, jobID, info, tableDef, ie.indexes) + if err != nil { + return nil, err + } + + c := &IndexConsumer{cnUUID: cnUUID, + jobID: jobID, + info: info, + tableDef: tableDef, + sqlWriter: sqlwriter, + exec: exec, + rowdata: make([]any, len(tableDef.Cols)), + rowdelete: make([]any, 1), + //sqlBufSendCh: make(chan []byte), + } + + return c, nil +} + +func (c *IndexConsumer) run(ctx context.Context, errch chan error, r DataRetriever) { + + datatype := r.GetDataType() + + if datatype == ISCPDataType_Snapshot { + // SNAPSHOT + for { + select { + case <-ctx.Done(): + return + case e2 := <-errch: + errch <- e2 + return + case sql, ok := <-c.sqlBufSendCh: + if !ok { + return + } + func() { + newctx, cancel := context.WithTimeout(context.Background(), time.Hour) + defer cancel() + //os.Stderr.WriteString("Wait for BEGIN but sql. execute anyway\n") + opts := executor.Options{} + res, err := c.exec.Exec(newctx, string(sql), opts) + if err != nil { + logutil.Errorf("cdc indexConsumer(%v) send sql failed, err: %v, sql: %s", c.info, err, string(sql)) + os.Stderr.WriteString(fmt.Sprintf("sql executor run failed. %s\n", string(sql))) + os.Stderr.WriteString(fmt.Sprintf("err :%v\n", err)) + errch <- err + } + res.Close() + }() + } + } + + } else { + // TAIL + newctx, cancel := context.WithTimeout(context.Background(), time.Hour) + defer cancel() + opts := executor.Options{} + err := c.exec.ExecTxn(newctx, + func(exec executor.TxnExecutor) error { + for { + select { + case <-ctx.Done(): + return nil + case e2 := <-errch: + return e2 + case sql, ok := <-c.sqlBufSendCh: + if !ok { + // channel closed + return r.UpdateWatermark(exec, opts.StatementOption()) + } + + // update SQL + res, err := exec.Exec(string(sql), opts.StatementOption()) + if err != nil { + return err + } + res.Close() + } + } + }, opts) + if err != nil { + errch <- err + return + } + } + +} + +func (c *IndexConsumer) processISCPData(ctx context.Context, data *ISCPData, datatype int8, errch chan error) bool { + // release the data + defer data.Done() + + insertBatch := data.insertBatch + deleteBatch := data.deleteBatch + noMoreData := data.noMoreData + err := data.err + if err != nil { + errch <- err + return true + } + + if noMoreData { + err := c.flushCdc() + if err != nil { + errch <- err + } + close(c.sqlBufSendCh) + return noMoreData + } + + // update index + + if datatype == ISCPDataType_Snapshot { + // SNAPSHOT + err := c.sinkSnapshot(ctx, insertBatch) + if err != nil { + // error out + errch <- err + noMoreData = true + } + + } else { + // sinkTail will save sql to the slice + err := c.sinkTail(ctx, insertBatch, deleteBatch) + if err != nil { + // error out + errch <- err + noMoreData = true + } + } + + return noMoreData + +} + +func (c *IndexConsumer) Consume(ctx context.Context, r DataRetriever) error { + noMoreData := false + errch := make(chan error, 2) + c.sqlBufSendCh = make(chan []byte) + defer func() { + c.sqlBufSendCh = nil + c.sqlWriter.Reset() + }() + + datatype := r.GetDataType() + + // create thread to poll sql + var wg sync.WaitGroup + wg.Add(1) + go func() { + defer wg.Done() + c.run(ctx, errch, r) + }() + + // read data + for !noMoreData { + data := r.Next() + noMoreData = c.processISCPData(ctx, data, datatype, errch) + } + + wg.Wait() + + if len(errch) > 0 { + return <-errch + } + + return nil +} + +func (c *IndexConsumer) sinkSnapshot(ctx context.Context, upsertBatch *AtomicBatch) error { + var err error + + for _, bat := range upsertBatch.Batches { + for i := 0; i < batchRowCount(bat); i++ { + if err = extractRowFromEveryVector(ctx, bat, i, c.rowdata); err != nil { + return err + } + + err = c.sqlWriter.Upsert(ctx, c.rowdata) + if err != nil { + return err + } + + if c.sqlWriter.Full() { + err = c.sendSql(c.sqlWriter) + if err != nil { + return err + } + } + } + } + + return nil +} + +// upsertBatch and deleteBatch is sorted by ts +// for the same ts, delete first, then upsert +func (c *IndexConsumer) sinkTail(ctx context.Context, upsertBatch, deleteBatch *AtomicBatch) error { + var err error + + upsertIter := upsertBatch.GetRowIterator().(*atomicBatchRowIter) + deleteIter := deleteBatch.GetRowIterator().(*atomicBatchRowIter) + defer func() { + upsertIter.Close() + deleteIter.Close() + }() + + // output sql until one iterator reach the end + upsertIterHasNext, deleteIterHasNext := upsertIter.Next(), deleteIter.Next() + for upsertIterHasNext && deleteIterHasNext { + upsertItem, deleteItem := upsertIter.Item(), deleteIter.Item() + // compare ts, ignore pk + if upsertItem.Ts.LT(&deleteItem.Ts) { + if err = c.sinkInsert(ctx, upsertIter); err != nil { + return err + } + // get next item + upsertIterHasNext = upsertIter.Next() + } else { + if err = c.sinkDelete(ctx, deleteIter); err != nil { + return err + } + // get next item + deleteIterHasNext = deleteIter.Next() + } + } + + // output the rest of upsert iterator + for upsertIterHasNext { + if err = c.sinkInsert(ctx, upsertIter); err != nil { + return err + } + // get next item + upsertIterHasNext = upsertIter.Next() + } + + // output the rest of delete iterator + for deleteIterHasNext { + if err = c.sinkDelete(ctx, deleteIter); err != nil { + return err + } + // get next item + deleteIterHasNext = deleteIter.Next() + } + c.flushCdc() + return nil +} + +func (c *IndexConsumer) sinkInsert(ctx context.Context, upsertIter *atomicBatchRowIter) (err error) { + + // get row from the batch + if err = upsertIter.Row(ctx, c.rowdata); err != nil { + return err + } + + if !c.sqlWriter.CheckLastOp(vectorindex.CDC_INSERT) { + // last op is not INSERT, sendSql first + // send SQL + err = c.sendSql(c.sqlWriter) + if err != nil { + return err + } + + } + + c.sqlWriter.Insert(ctx, c.rowdata) + + if c.sqlWriter.Full() { + // send SQL + err = c.sendSql(c.sqlWriter) + if err != nil { + return err + } + } + + return nil +} + +func (c *IndexConsumer) sinkDelete(ctx context.Context, deleteIter *atomicBatchRowIter) (err error) { + + // get row from the batch + if err = deleteIter.Row(ctx, c.rowdelete); err != nil { + return err + } + + if !c.sqlWriter.CheckLastOp(vectorindex.CDC_DELETE) { + // last op is not DELETE, sendSql first + // send SQL + err = c.sendSql(c.sqlWriter) + if err != nil { + return err + } + + } + + c.sqlWriter.Delete(ctx, c.rowdelete) + + if c.sqlWriter.Full() { + // send SQL + err = c.sendSql(c.sqlWriter) + if err != nil { + return err + } + } + + return nil +} + +func (c *IndexConsumer) sendSql(writer IndexSqlWriter) error { + if writer.Empty() { + return nil + } + + // generate sql from cdc + sql, err := writer.ToSql() + if err != nil { + return err + } + + c.sqlBufSendCh <- sql + os.Stderr.WriteString(string(sql)) + os.Stderr.WriteString("\n") + + // reset + writer.Reset() + + return nil +} + +func (c *IndexConsumer) flushCdc() error { + return c.sendSql(c.sqlWriter) +} diff --git a/pkg/iscp/index_consumer_test.go b/pkg/iscp/index_consumer_test.go new file mode 100644 index 0000000000000..8ccc7e0f8a23a --- /dev/null +++ b/pkg/iscp/index_consumer_test.go @@ -0,0 +1,373 @@ +// Copyright 2024 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package iscp + +import ( + "context" + "errors" + "fmt" + "strings" + "testing" + + "github.com/matrixorigin/matrixone/pkg/catalog" + "github.com/matrixorigin/matrixone/pkg/common/moerr" + "github.com/matrixorigin/matrixone/pkg/container/batch" + "github.com/matrixorigin/matrixone/pkg/container/types" + "github.com/matrixorigin/matrixone/pkg/container/vector" + "github.com/matrixorigin/matrixone/pkg/logutil" + "github.com/matrixorigin/matrixone/pkg/pb/plan" + "github.com/matrixorigin/matrixone/pkg/testutil" + "github.com/matrixorigin/matrixone/pkg/txn/client" + "github.com/matrixorigin/matrixone/pkg/util/executor" + "github.com/prashantv/gostub" + "github.com/stretchr/testify/require" + "github.com/tidwall/btree" +) + +type MockRetriever struct { + insertBatch *AtomicBatch + deleteBatch *AtomicBatch + noMoreData bool + dtype int8 +} + +func (r *MockRetriever) Next() *ISCPData { + logutil.Infof("TxRetriever Next()") + if !r.noMoreData { + r.noMoreData = true + d := &ISCPData{insertBatch: r.insertBatch, deleteBatch: r.deleteBatch, noMoreData: false, err: nil} + d.Set(0) // never close + return d + } + d := &ISCPData{insertBatch: nil, deleteBatch: nil, noMoreData: r.noMoreData, err: nil} + d.Set(0) // never close + return d +} + +func (r *MockRetriever) UpdateWatermark(executor.TxnExecutor, executor.StatementOption) error { + logutil.Infof("TxnRetriever.UpdateWatermark()") + return nil +} + +func (r *MockRetriever) GetDataType() int8 { + return r.dtype +} + +var _ DataRetriever = new(MockRetriever) + +func newTestTableDef(pkName string, pkType types.T, vecColName string, vecType types.T, vecWidth int32) *plan.TableDef { + return &plan.TableDef{ + Name: "test_orig_tbl", + Name2ColIndex: map[string]int32{ + pkName: 0, + vecColName: 1, + "dummy": 2, // Add another col to make sure pk/vec col indices are used + }, + Cols: []*plan.ColDef{ + {Name: pkName, Typ: plan.Type{Id: int32(pkType)}}, + {Name: vecColName, Typ: plan.Type{Id: int32(vecType), Width: vecWidth}}, + {Name: "dummy", Typ: plan.Type{Id: int32(types.T_int32)}}, + }, + Pkey: &plan.PrimaryKeyDef{ + Names: []string{pkName}, + PkeyColName: pkName, + }, + Indexes: []*plan.IndexDef{ + { + IndexName: "hnsw_idx", + TableExist: true, + IndexAlgo: catalog.MoIndexHnswAlgo.ToString(), + IndexAlgoTableType: catalog.Hnsw_TblType_Metadata, + IndexTableName: "meta_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"m":"16","ef_construction":"200","ef_search":"100","op_type":"vector_l2_ops"}`, + }, + { + IndexName: "hnsw_idx", + TableExist: true, + IndexAlgo: catalog.MoIndexHnswAlgo.ToString(), + IndexAlgoTableType: catalog.Hnsw_TblType_Storage, + IndexTableName: "storage_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"m":"16","ef_construction":"200","ef_search":"100","op_type":"vector_l2_ops"}`, + }, + }, + } +} + +func newTestConsumerInfo() *ConsumerInfo { + return &ConsumerInfo{ + ConsumerType: 0, + DBName: "test_db", + TableName: "test_tbl", + IndexName: "hnsw_idx", + } +} + +func newTestJobID() JobID { + return JobID{ + DBName: "test_db", + TableName: "test_tbl", + JobName: "index_hnsw_idx", + } +} + +type MockSQLExecutor struct { + txnexec executor.TxnExecutor + sqls []string +} + +// Exec exec a sql in a exists txn. +func (exec *MockSQLExecutor) Exec(ctx context.Context, sql string, opts executor.Options) (executor.Result, error) { + exec.sqls = append(exec.sqls, sql) + //fmt.Printf("Exec %p %v\n", exec.sqls, exec.sqls) + return executor.Result{}, nil +} + +var _ executor.SQLExecutor = new(MockSQLExecutor) + +func mockSqlExecutorFactory(uuid string) (executor.SQLExecutor, error) { + return &MockSQLExecutor{}, nil +} + +type MockErrorTxnExecutor struct { + database string + ctx context.Context + sqls []string +} + +func (exec *MockErrorTxnExecutor) Use(db string) { + exec.database = db +} + +func (exec *MockErrorTxnExecutor) Exec( + sql string, + statementOption executor.StatementOption, +) (executor.Result, error) { + if strings.Contains(sql, "FAILSQL") { + return executor.Result{}, moerr.NewInternalErrorNoCtx("db error") + } else if strings.Contains(sql, "MULTI_ERROR_NO_ROLLBACK") { + var errs error + errs = errors.Join(errs, moerr.NewInternalErrorNoCtx("db error")) + errs = errors.Join(errs, moerr.NewInternalErrorNoCtx("db error 2")) + return executor.Result{}, errs + } else if strings.Contains(sql, "MULTI_ERROR_ROLLBACK") { + var errs error + errs = errors.Join(errs, moerr.NewInternalErrorNoCtx("db error")) + errs = errors.Join(errs, moerr.NewQueryInterrupted(exec.ctx)) + return executor.Result{}, errs + } + + exec.sqls = append(exec.sqls, sql) + //fmt.Printf("APPEND %s", sql) + return executor.Result{}, nil +} + +func (exec *MockErrorTxnExecutor) LockTable(table string) error { + return nil +} + +func (exec *MockErrorTxnExecutor) Txn() client.TxnOperator { + return nil +} + +// ExecTxn executor sql in a txn. execFunc can use TxnExecutor to exec multiple sql +// in a transaction. +// NOTE: Pass SQL stmts one by one to TxnExecutor.Exec(). If you pass multiple SQL stmts to +// TxnExecutor.Exec() as `\n` seperated string, it will only execute the first SQL statement causing Bug. +func (exec *MockSQLExecutor) ExecTxn(ctx context.Context, execFunc func(txn executor.TxnExecutor) error, opts executor.Options) error { + exec.txnexec = &MockErrorTxnExecutor{ctx: ctx} + err := execFunc(exec.txnexec) + exec.sqls = exec.txnexec.(*MockErrorTxnExecutor).sqls + //fmt.Printf("ExecTxn %v\n", exec.sqls) + return err +} + +func TestConsumer(t *testing.T) { + ctx, cancel := context.WithCancel(context.Background()) + defer cancel() + + sqlexecstub := gostub.Stub(&sqlExecutorFactory, mockSqlExecutorFactory) + defer sqlexecstub.Reset() + + r := &MockRetriever{ + insertBatch: nil, + deleteBatch: nil, + noMoreData: true, + dtype: ISCPDataType_Snapshot, + } + + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 4) + cnUUID := "a-b-c-d" + info := newTestConsumerInfo() + job := newTestJobID() + + consumer, err := NewIndexConsumer(cnUUID, tblDef, job, info) + require.NoError(t, err) + err = consumer.Consume(ctx, r) + require.NoError(t, err) +} + +func TestHnswSnapshot(t *testing.T) { + + proc := testutil.NewProcess(t) + + ctx, cancel := context.WithCancel(context.Background()) + defer cancel() + + sqlexecstub := gostub.Stub(&sqlExecutorFactory, mockSqlExecutorFactory) + defer sqlexecstub.Reset() + + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 2) + cnUUID := "a-b-c-d" + info := newTestConsumerInfo() + job := newTestJobID() + + t.Run("snapshot", func(t *testing.T) { + consumer, err := NewIndexConsumer(cnUUID, tblDef, job, info) + require.NoError(t, err) + + bat := testutil.NewBatchWithVectors( + []*vector.Vector{ + testutil.NewVector(2, types.T_int64.ToType(), proc.Mp(), false, []int64{1, 2}), + testutil.NewVector(2, types.T_array_float32.ToType(), proc.Mp(), false, [][]float32{{0.1, 0.2}, {0.3, 0.4}}), + testutil.NewVector(2, types.T_int32.ToType(), proc.Mp(), false, []int32{1, 2}), + }, nil) + + defer bat.Clean(testutil.TestUtilMp) + + insertAtomicBat := &AtomicBatch{ + Mp: nil, + Batches: []*batch.Batch{bat}, + Rows: btree.NewBTreeGOptions(AtomicBatchRow.Less, btree.Options{Degree: 64}), + } + + output := &MockRetriever{ + dtype: ISCPDataType_Snapshot, + insertBatch: insertAtomicBat, + deleteBatch: nil, + noMoreData: false, + } + err = consumer.Consume(ctx, output) + require.NoError(t, err) + sqls := consumer.(*IndexConsumer).exec.(*MockSQLExecutor).sqls + require.Equal(t, len(sqls), 1) + sql := sqls[0] + require.Equal(t, string(sql), `SELECT hnsw_cdc_update('test_db', 'test_tbl', 2, '{"cdc":[{"t":"U","pk":1,"v":[0.1,0.2]},{"t":"U","pk":2,"v":[0.3,0.4]}]}');`) + + //fmt.Printf("Consume %p %v\n", consumer.(*IndexConsumer).exec.(*MockSQLExecutor).sqls, consumer.(*IndexConsumer).exec.(*MockSQLExecutor).sqls) + }) + + t.Run("noMoreData", func(t *testing.T) { + consumer, err := NewIndexConsumer(cnUUID, tblDef, job, info) + require.NoError(t, err) + + output := &MockRetriever{ + dtype: ISCPDataType_Snapshot, + insertBatch: nil, + deleteBatch: nil, + noMoreData: true, + } + err = consumer.Consume(ctx, output) + require.NoError(t, err) + sqls := consumer.(*IndexConsumer).exec.(*MockSQLExecutor).sqls + require.Equal(t, len(sqls), 0) + }) +} + +func TestHnswTail(t *testing.T) { + + proc := testutil.NewProcess(t) + + ctx, cancel := context.WithCancel(context.Background()) + defer cancel() + + sqlexecstub := gostub.Stub(&sqlExecutorFactory, mockSqlExecutorFactory) + defer sqlexecstub.Reset() + + tblDef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 2) + cnUUID := "a-b-c-d" + info := newTestConsumerInfo() + job := newTestJobID() + + consumer, err := NewIndexConsumer(cnUUID, tblDef, job, info) + require.NoError(t, err) + + bat := testutil.NewBatchWithVectors( + []*vector.Vector{ + testutil.NewVector(2, types.T_int64.ToType(), proc.Mp(), false, []int64{1, 2}), + testutil.NewVector(2, types.T_array_float32.ToType(), proc.Mp(), false, [][]float32{{0.1, 0.2}, {0.3, 0.4}}), + testutil.NewVector(2, types.T_int32.ToType(), proc.Mp(), false, []int64{1, 2}), + }, nil) + defer bat.Clean(testutil.TestUtilMp) + + fromTs := types.BuildTS(1, 0) + insertAtomicBat := &AtomicBatch{ + Mp: nil, + Batches: []*batch.Batch{bat}, + Rows: btree.NewBTreeGOptions(AtomicBatchRow.Less, btree.Options{Degree: 64}), + } + insertAtomicBat.Rows.Set(AtomicBatchRow{Ts: fromTs, Pk: []byte{1}, Offset: 0, Src: bat}) + insertAtomicBat.Rows.Set(AtomicBatchRow{Ts: fromTs, Pk: []byte{2}, Offset: 1, Src: bat}) + + delbat := testutil.NewBatchWithVectors( + []*vector.Vector{ + testutil.NewVector(2, types.T_int64.ToType(), proc.Mp(), false, []int64{1, 2}), + testutil.NewVector(2, types.T_array_float32.ToType(), proc.Mp(), false, [][]float32{{0.1, 0.2}, {0.3, 0.4}}), + testutil.NewVector(2, types.T_int32.ToType(), proc.Mp(), false, []int64{1, 2}), + }, nil) + + defer delbat.Clean(testutil.TestUtilMp) + + delfromTs := types.BuildTS(2, 0) + delAtomicBat := &AtomicBatch{ + Mp: nil, + Batches: []*batch.Batch{delbat}, + Rows: btree.NewBTreeGOptions(AtomicBatchRow.Less, btree.Options{Degree: 64}), + } + delAtomicBat.Rows.Set(AtomicBatchRow{Ts: delfromTs, Pk: []byte{1}, Offset: 0, Src: bat}) + delAtomicBat.Rows.Set(AtomicBatchRow{Ts: delfromTs, Pk: []byte{2}, Offset: 1, Src: bat}) + + output := &MockRetriever{ + dtype: ISCPDataType_Tail, + insertBatch: insertAtomicBat, + deleteBatch: delAtomicBat, + noMoreData: false, + } + + err = consumer.Consume(ctx, output) + require.NoError(t, err) + sqls := consumer.(*IndexConsumer).exec.(*MockSQLExecutor).txnexec.(*MockErrorTxnExecutor).sqls + + require.Equal(t, len(sqls), 1) + fmt.Printf("RES: %v\n", sqls) + + row1 := []any{int64(1), []float32{0.1, 0.2}} + row2 := []any{int64(2), []float32{0.3, 0.4}} + + writer, _ := NewHnswSqlWriter("hnsw", job, info, tblDef, tblDef.Indexes) + writer.Insert(ctx, row1) + writer.Insert(ctx, row2) + writer.Delete(ctx, row1) + writer.Delete(ctx, row2) + /* + cdcForJson.Start = "1-0" + cdcForJson.End = "2-0" + */ + expectedSqlBytes, _ := writer.ToSql() + + require.Equal(t, string(expectedSqlBytes), sqls[0]) + +} diff --git a/pkg/iscp/index_sqlwriter.go b/pkg/iscp/index_sqlwriter.go new file mode 100644 index 0000000000000..0f12db2c62205 --- /dev/null +++ b/pkg/iscp/index_sqlwriter.go @@ -0,0 +1,649 @@ +// Copyright 2024 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package iscp + +import ( + "context" + "encoding/json" + "fmt" + "strings" + + "github.com/matrixorigin/matrixone/pkg/catalog" + "github.com/matrixorigin/matrixone/pkg/common/moerr" + "github.com/matrixorigin/matrixone/pkg/container/types" + "github.com/matrixorigin/matrixone/pkg/pb/plan" + "github.com/matrixorigin/matrixone/pkg/vectorindex" +) + +const ( + MAX_CDC_DATA_SIZE = 8192 +) + +// IndexSqlWriter interface +type IndexSqlWriter interface { + CheckLastOp(op string) bool + Upsert(ctx context.Context, row []any) error + Insert(ctx context.Context, row []any) error + Delete(ctx context.Context, row []any) error + Full() bool + ToSql() ([]byte, error) + Reset() + Empty() bool +} + +// Base implementation of IVFFLAT and FULLTEXT. Their implementation are simliar. +type BaseIndexSqlWriter struct { + lastCdcOp string + vbuf []byte + ndata int + param string + tabledef *plan.TableDef + indexdef []*plan.IndexDef + jobID JobID + info *ConsumerInfo + algo string + pkPos int32 + pkType *types.Type + partsPos []int32 + partsType []*types.Type + srcPos []int32 + srcType []*types.Type + dbName string +} + +// Fulltext Sql Writer. Only one hidden secondary index table +type FulltextSqlWriter struct { + BaseIndexSqlWriter + indexTableName string +} + +// Ivfflat Sql writer. Three hidden secondary index tables +type IvfflatSqlWriter struct { + BaseIndexSqlWriter + centroids_tbl string + entries_tbl string + meta_tbl string + ivfparam vectorindex.IvfParam +} + +// Hnsw Sql Writer. Use the vectorindex.VectorIndeXCdc JSON format +type HnswSqlWriter[T types.RealNumbers] struct { + cdc *vectorindex.VectorIndexCdc[T] + meta vectorindex.HnswCdcParam + tabledef *plan.TableDef + indexdef []*plan.IndexDef + jobID JobID + info *ConsumerInfo + pkPos int32 + pkType *types.Type + partsPos []int32 + partsType []*types.Type + srcPos []int32 + srcType []*types.Type + dbName string +} + +// check FulltextSqlWriter is the interface of IndexSqlWriter +var _ IndexSqlWriter = new(FulltextSqlWriter) +var _ IndexSqlWriter = new(IvfflatSqlWriter) +var _ IndexSqlWriter = new(HnswSqlWriter[float32]) + +// check algo type to return the correct sql writer +func NewIndexSqlWriter(algo string, jobID JobID, info *ConsumerInfo, tabledef *plan.TableDef, indexdef []*plan.IndexDef) (IndexSqlWriter, error) { + algo = catalog.ToLower(algo) + switch algo { + case catalog.MOIndexFullTextAlgo.ToString(): + return NewFulltextSqlWriter(algo, jobID, info, tabledef, indexdef) + case catalog.MoIndexIvfFlatAlgo.ToString(): + return NewIvfflatSqlWriter(algo, jobID, info, tabledef, indexdef) + case catalog.MoIndexHnswAlgo.ToString(): + return NewHnswSqlWriter(algo, jobID, info, tabledef, indexdef) + default: + return IndexSqlWriter(nil), moerr.NewInternalErrorNoCtx("IndexSqlWriter: invalid algo type") + + } +} + +// Implementation of Base Index SqlWriter +func (w *BaseIndexSqlWriter) Full() bool { + return w.ndata >= MAX_CDC_DATA_SIZE +} + +// return true when last op is empty or last op == current op +func (w *BaseIndexSqlWriter) CheckLastOp(op string) bool { + return len(w.lastCdcOp) == 0 || w.lastCdcOp == op +} + +func (w *BaseIndexSqlWriter) writeRow(ctx context.Context, row []any) error { + var err error + + w.vbuf = appendString(w.vbuf, "ROW(") + + // pk + if w.tabledef.Pkey.PkeyColName == catalog.CPrimaryKeyColName { + cpkType := &types.Type{Oid: types.T_varbinary, Width: w.pkType.Width, Scale: w.pkType.Scale} + w.vbuf, err = convertColIntoSql(ctx, row[w.pkPos], cpkType, w.vbuf) + if err != nil { + return err + } + } else { + w.vbuf, err = convertColIntoSql(ctx, row[w.pkPos], w.pkType, w.vbuf) + if err != nil { + return err + } + } + + for i, t := range w.partsType { + w.vbuf = appendString(w.vbuf, ",") + pos := w.partsPos[i] + w.vbuf, err = convertColIntoSql(ctx, row[pos], t, w.vbuf) + if err != nil { + return err + } + } + + w.vbuf = appendString(w.vbuf, ")") + w.ndata += 1 + return nil +} + +func (w *BaseIndexSqlWriter) writeDeleteRow(ctx context.Context, row []any) error { + var err error + + if w.tabledef.Pkey.PkeyColName == catalog.CPrimaryKeyColName { + cpkType := &types.Type{Oid: types.T_varbinary, Width: w.pkType.Width, Scale: w.pkType.Scale} + w.vbuf, err = convertColIntoSql(ctx, row[0], cpkType, w.vbuf) + if err != nil { + return err + } + } else { + w.vbuf, err = convertColIntoSql(ctx, row[0], w.pkType, w.vbuf) + if err != nil { + return err + } + + } + w.ndata += 1 + return nil +} + +func (w *BaseIndexSqlWriter) Upsert(ctx context.Context, row []any) error { + + if len(w.lastCdcOp) == 0 { + // init + w.lastCdcOp = vectorindex.CDC_UPSERT + return w.writeRow(ctx, row) + + } + + if w.lastCdcOp != vectorindex.CDC_UPSERT { + // different from previous operation and generate SQL before append new UPSERT + return moerr.NewInternalErrorNoCtx("FulltextSqlWriter.Upsert: append different op") + } + + // same as previous operation and append to VALUES ROW(), ROW(),... + w.vbuf = appendString(w.vbuf, ",") + return w.writeRow(ctx, row) +} + +func (w *BaseIndexSqlWriter) Insert(ctx context.Context, row []any) error { + + if len(w.lastCdcOp) == 0 { + // init + w.lastCdcOp = vectorindex.CDC_INSERT + return w.writeRow(ctx, row) + + } + + if w.lastCdcOp != vectorindex.CDC_INSERT { + // different from previous operation and generate SQL before append new UPSERT + return moerr.NewInternalErrorNoCtx("FulltextSqlWriter.Insert: append different op") + } + + // same as previous operation and append to VALUES ROW(), ROW(),... + w.vbuf = appendString(w.vbuf, ",") + return w.writeRow(ctx, row) +} + +func (w *BaseIndexSqlWriter) Delete(ctx context.Context, row []any) error { + + if len(w.lastCdcOp) == 0 { + // init + w.lastCdcOp = vectorindex.CDC_DELETE + return w.writeDeleteRow(ctx, row) + } + + if w.lastCdcOp != vectorindex.CDC_DELETE { + // different from previous operation and generate SQL before append new UPSERT + return moerr.NewInternalErrorNoCtx("FulltextSqlWriter.Delete: append different op") + } + + // same as previous operation and append to IN () + w.vbuf = appendString(w.vbuf, ",") + return w.writeDeleteRow(ctx, row) +} + +func (w *BaseIndexSqlWriter) Reset() { + w.lastCdcOp = "" + w.vbuf = w.vbuf[:0] + w.ndata = 0 +} + +func (w *BaseIndexSqlWriter) Empty() bool { + return len(w.vbuf) == 0 +} + +// New Fulltext Sql Writer +func NewFulltextSqlWriter(algo string, jobID JobID, info *ConsumerInfo, tabledef *plan.TableDef, indexdef []*plan.IndexDef) (IndexSqlWriter, error) { + w := &FulltextSqlWriter{BaseIndexSqlWriter: BaseIndexSqlWriter{algo: algo, tabledef: tabledef, indexdef: indexdef, jobID: jobID, info: info, vbuf: make([]byte, 0, 1024)}} + + w.pkPos = tabledef.Name2ColIndex[tabledef.Pkey.PkeyColName] + typ := tabledef.Cols[w.pkPos].Typ + w.pkType = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + + nparts := len(w.indexdef[0].Parts) + w.partsPos = make([]int32, nparts) + w.partsType = make([]*types.Type, nparts) + + for i, part := range w.indexdef[0].Parts { + w.partsPos[i] = tabledef.Name2ColIndex[part] + typ = tabledef.Cols[w.partsPos[i]].Typ + w.partsType[i] = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + } + + w.srcPos = make([]int32, nparts+1) + w.srcType = make([]*types.Type, nparts+1) + + w.srcPos[0] = w.pkPos + w.srcType[0] = w.pkType + for i := range w.partsType { + w.srcPos[i+1] = w.partsPos[i] + w.srcType[i+1] = w.partsType[i] + } + + w.indexTableName = w.indexdef[0].IndexTableName + w.dbName = tabledef.DbName + + return w, nil +} + +// with src as (select cast(serial(cast(column_0 as bigint), cast(column_1 as bigint)) as varchar) as id, column_2 as body, column_3 as title from +// (values row(1, 2, 'body', 'title'), row(2, 3, 'body is heavy', 'I do not know'))) select f.* from src +// cross apply fulltext_index_tokenize('{"parser":"ngram"}', 61, id, body, title) as f; +func (w *FulltextSqlWriter) ToSql() ([]byte, error) { + defer w.Reset() + + if len(w.lastCdcOp) == 0 { + return nil, nil + } + + switch w.lastCdcOp { + case vectorindex.CDC_DELETE: + return w.toFulltextDelete() + case vectorindex.CDC_UPSERT: + return w.toFulltextUpsert(true) + case vectorindex.CDC_INSERT: + return w.toFulltextUpsert(false) + default: + return nil, moerr.NewInternalErrorNoCtx("FulltextSqlWriter: invalid CDC type") + } +} + +func (w *FulltextSqlWriter) toFulltextDelete() ([]byte, error) { + sql := fmt.Sprintf("DELETE FROM `%s`.`%s` WHERE `%s` IN (%s)", w.info.DBName, w.indexTableName, catalog.FullTextIndex_TabCol_Id, string(w.vbuf)) + return []byte(sql), nil +} + +func (w *FulltextSqlWriter) toFulltextUpsert(upsert bool) ([]byte, error) { + + var sql string + + coldefs := make([]string, 0, len(w.srcPos)) + cnames := make([]string, 0, len(w.srcPos)) + for i, pos := range w.srcPos { + typstr := w.srcType[i].DescString() + coldefs = append(coldefs, fmt.Sprintf("CAST(column_%d as %s) as `%s`", i, typstr, w.tabledef.Cols[pos].Name)) + cnames = append(cnames, w.tabledef.Cols[pos].Name) + } + + cols := strings.Join(coldefs, ", ") + cnames_str := strings.Join(cnames, ", ") + + if upsert { + sql += fmt.Sprintf("REPLACE INTO `%s`.`%s` ", w.dbName, w.indexTableName) + } else { + sql += fmt.Sprintf("INSERT INTO `%s`.`%s` ", w.dbName, w.indexTableName) + } + + sql += fmt.Sprintf("WITH src as (SELECT %s FROM (VALUES %s)) ", cols, string(w.vbuf)) + sql += fmt.Sprintf("SELECT f.* FROM src CROSS APPLY fulltext_index_tokenize('%s', %d, %s) as f", w.param, w.pkType.Oid, cnames_str) + + return []byte(sql), nil +} + +// Implementation of HNSW Sql writer +func NewHnswSqlWriter(algo string, jobID JobID, info *ConsumerInfo, tabledef *plan.TableDef, indexdef []*plan.IndexDef) (IndexSqlWriter, error) { + w := &HnswSqlWriter[float32]{tabledef: tabledef, indexdef: indexdef, jobID: jobID, info: info, cdc: vectorindex.NewVectorIndexCdc[float32]()} + + // check the tabledef and indexdef + if len(tabledef.Pkey.Names) != 1 { + return nil, moerr.NewInternalErrorNoCtx("hnsw index table only have one primary key") + } + + if len(indexdef) != 2 { + return nil, moerr.NewInternalErrorNoCtx("hnsw index table must have 2 secondary tables") + } + + idxdef := indexdef[0] + if len(idxdef.Parts) != 1 { + return nil, moerr.NewInternalErrorNoCtx("hnsw index table only have one vector part") + } + + paramstr := idxdef.IndexAlgoParams + var meta, storage string + for _, idx := range indexdef { + if idx.IndexAlgoTableType == catalog.Hnsw_TblType_Metadata { + meta = idx.IndexTableName + } + if idx.IndexAlgoTableType == catalog.Hnsw_TblType_Storage { + storage = idx.IndexTableName + } + } + + if len(meta) == 0 || len(storage) == 0 { + return nil, moerr.NewInternalErrorNoCtx("hnsw index table either meta or storage hidden index table not exist") + } + + var hnswparam vectorindex.HnswParam + if len(paramstr) > 0 { + err := json.Unmarshal([]byte(paramstr), &hnswparam) + if err != nil { + return nil, moerr.NewInternalErrorNoCtx("hnsw sync sinker. failed to convert hnsw param json") + } + } + + w.pkPos = tabledef.Name2ColIndex[tabledef.Pkey.PkeyColName] + typ := tabledef.Cols[w.pkPos].Typ + w.pkType = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + + if w.pkType.Oid != types.T_int64 { + return nil, moerr.NewInternalErrorNoCtx("NewHnswSqlWriter: primary key is not bigint") + } + + nparts := len(idxdef.Parts) + w.partsPos = make([]int32, nparts) + w.partsType = make([]*types.Type, nparts) + + for i, part := range idxdef.Parts { + w.partsPos[i] = tabledef.Name2ColIndex[part] + typ = tabledef.Cols[w.partsPos[i]].Typ + w.partsType[i] = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + } + + if w.partsType[0].Oid != types.T_array_float32 { + return nil, moerr.NewInternalErrorNoCtx("NewHnswSqlWriter: part is not vecf32") + } + + w.srcPos = make([]int32, nparts+1) + w.srcType = make([]*types.Type, nparts+1) + + w.srcPos[0] = w.pkPos + w.srcType[0] = w.pkType + for i := range w.partsType { + w.srcPos[i+1] = w.partsPos[i] + w.srcType[i+1] = w.partsType[i] + } + + w.dbName = tabledef.DbName + + w.meta = vectorindex.HnswCdcParam{ + MetaTbl: meta, + IndexTbl: storage, + DbName: info.DBName, + Table: info.TableName, + Params: hnswparam, + Dimension: tabledef.Cols[w.partsPos[0]].Typ.Width, + } + + return w, nil +} + +func (w *HnswSqlWriter[T]) Reset() { + w.cdc.Data = w.cdc.Data[:0] +} + +func (w *HnswSqlWriter[T]) Full() bool { + return len(w.cdc.Data) >= cap(w.cdc.Data) +} + +func (w *HnswSqlWriter[T]) Empty() bool { + return len(w.cdc.Data) == 0 +} + +func (w *HnswSqlWriter[T]) CheckLastOp(op string) bool { + return true +} + +func (w *HnswSqlWriter[T]) Insert(ctx context.Context, row []any) error { + key, ok := row[w.pkPos].(int64) + if !ok { + return moerr.NewInternalError(ctx, "invalid key type. not int64") + } + v, ok := row[w.partsPos[0]].([]T) + if !ok { + return moerr.NewInternalError(ctx, "invalid vector type. not []float32") + } + + if v == nil { + // vector is nil, do Delete + w.cdc.Delete(key) + return nil + } + + w.cdc.Insert(key, v) + return nil +} + +func (w *HnswSqlWriter[T]) Upsert(ctx context.Context, row []any) error { + key, ok := row[w.pkPos].(int64) + if !ok { + return moerr.NewInternalError(ctx, "invalid key type. not int64") + } + v, ok := row[w.partsPos[0]].([]T) + if !ok { + return moerr.NewInternalError(ctx, "invalid vector type. not []float32") + } + + if v == nil { + // vector is nil, do Delete + w.cdc.Delete(key) + return nil + } + + w.cdc.Upsert(key, v) + return nil +} + +func (w *HnswSqlWriter[T]) Delete(ctx context.Context, row []any) error { + // first column is the primary key + key, ok := row[0].(int64) + if !ok { + return moerr.NewInternalError(ctx, "invalid key type. not int64") + } + w.cdc.Delete(key) + return nil +} + +func (w *HnswSqlWriter[T]) ToSql() ([]byte, error) { + + // generate sql from cdc + js, err := w.cdc.ToJson() + if err != nil { + return nil, err + } + // pad extra space at the front and send SQL + sql := fmt.Sprintf("SELECT hnsw_cdc_update('%s', '%s', %d, '%s');", w.meta.DbName, w.meta.Table, w.meta.Dimension, js) + + return []byte(sql), nil +} + +// Implementation of Ivfflat Sql writer +func NewIvfflatSqlWriter(algo string, jobID JobID, info *ConsumerInfo, tabledef *plan.TableDef, indexdef []*plan.IndexDef) (IndexSqlWriter, error) { + w := &IvfflatSqlWriter{BaseIndexSqlWriter: BaseIndexSqlWriter{algo: algo, tabledef: tabledef, indexdef: indexdef, jobID: jobID, info: info, vbuf: make([]byte, 0, 1024)}} + + if len(indexdef) != 3 { + return nil, moerr.NewInternalErrorNoCtx("ivf index table must have 3 secondary tables") + } + + idxdef := indexdef[0] + if len(idxdef.Parts) != 1 { + return nil, moerr.NewInternalErrorNoCtx("ivf index table only have one vector part") + } + + paramstr := idxdef.IndexAlgoParams + var centroids_tbl, entries_tbl, meta_tbl string + for _, idx := range indexdef { + if idx.IndexAlgoTableType == catalog.SystemSI_IVFFLAT_TblType_Metadata { + meta_tbl = idx.IndexTableName + } + if idx.IndexAlgoTableType == catalog.SystemSI_IVFFLAT_TblType_Centroids { + centroids_tbl = idx.IndexTableName + } + if idx.IndexAlgoTableType == catalog.SystemSI_IVFFLAT_TblType_Entries { + entries_tbl = idx.IndexTableName + } + } + + if len(centroids_tbl) == 0 || len(entries_tbl) == 0 || len(meta_tbl) == 0 { + return nil, moerr.NewInternalErrorNoCtx("ivf index table either meta or centroids or entries hidden index table not exist") + } + + var ivfparam vectorindex.IvfParam + if len(paramstr) > 0 { + err := json.Unmarshal([]byte(paramstr), &ivfparam) + if err != nil { + return nil, moerr.NewInternalErrorNoCtx("ivf sync sinker. failed to convert ivf param json") + } + } + + w.ivfparam = ivfparam + + w.pkPos = tabledef.Name2ColIndex[tabledef.Pkey.PkeyColName] + typ := tabledef.Cols[w.pkPos].Typ + w.pkType = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + + nparts := len(w.indexdef[0].Parts) + w.partsPos = make([]int32, nparts) + w.partsType = make([]*types.Type, nparts) + + for i, part := range w.indexdef[0].Parts { + w.partsPos[i] = tabledef.Name2ColIndex[part] + typ = tabledef.Cols[w.partsPos[i]].Typ + w.partsType[i] = &types.Type{Oid: types.T(typ.Id), Width: typ.Width, Scale: typ.Scale} + } + + w.srcPos = make([]int32, nparts+1) + w.srcType = make([]*types.Type, nparts+1) + + w.srcPos[0] = w.pkPos + w.srcType[0] = w.pkType + for i := range w.partsType { + w.srcPos[i+1] = w.partsPos[i] + w.srcType[i+1] = w.partsType[i] + } + + w.centroids_tbl = centroids_tbl + w.entries_tbl = entries_tbl + w.meta_tbl = meta_tbl + + return w, nil +} + +// REPLACE INTO __mo_index_secondary_0197786c-285f-70cb-9337-e484a3ff92c4(__mo_index_centroid_fk_version, __mo_index_centroid_fk_id, __mo_index_pri_col, __mo_index_centroid_fk_entry) +// with centroid as (select * from __mo_index_secondary_0197786c-285f-70bb-b277-2cef56da590a where __mo_index_centroid_version = 0), +// src as (select column_0 as id, cast(column_1 as vecf32(3)) as embed from (values row(2005,'[0.4532634, 0.7297859, 0.48885703]'), row(2009, '[0.68150306, 0.6950923, 0.16590895] '))) +// select __mo_index_centroid_version, __mo_index_centroid_id, id, embed from src centroidx('vector_l2_ops') join centroid using (__mo_index_centroid, embed); +func (w *IvfflatSqlWriter) ToSql() ([]byte, error) { + defer w.Reset() + + if len(w.lastCdcOp) == 0 { + return nil, nil + } + + switch w.lastCdcOp { + case vectorindex.CDC_DELETE: + return w.toIvfflatDelete() + case vectorindex.CDC_UPSERT: + return w.toIvfflatUpsert(true) + case vectorindex.CDC_INSERT: + return w.toIvfflatUpsert(false) + default: + return nil, moerr.NewInternalErrorNoCtx("IvfflatSqlWriter: invalid CDC type") + } +} + +// catalog.SystemSI_IVFFLAT_TblCol_Entries_version +// catalog.SystemSI_IVFFLAT_TblCol_Entries_pk +// catalog.CPrimaryKeyColName +func (w *IvfflatSqlWriter) toIvfflatDelete() ([]byte, error) { + sql := fmt.Sprintf("DELETE FROM `%s`.`%s` WHERE `%s` IN (%s)", w.info.DBName, w.entries_tbl, + catalog.SystemSI_IVFFLAT_TblCol_Entries_pk, + string(w.vbuf)) + return []byte(sql), nil + +} + +func (w *IvfflatSqlWriter) toIvfflatUpsert(upsert bool) ([]byte, error) { + + var sql string + + coldefs := make([]string, 0, len(w.srcPos)) + cnames := make([]string, 0, len(w.srcPos)) + for i := range w.srcPos { + typstr := w.srcType[i].DescString() + cnames = append(cnames, fmt.Sprintf("src%d", i)) + coldefs = append(coldefs, fmt.Sprintf("CAST(column_%d as %s) as `%s`", i, typstr, cnames[i])) + } + + cols := strings.Join(coldefs, ", ") + cnames_str := strings.Join(cnames, ", ") + + if upsert { + sql += fmt.Sprintf("REPLACE INTO `%s`.`%s` ", w.info.DBName, w.entries_tbl) + } else { + sql += fmt.Sprintf("INSERT INTO `%s`.`%s` ", w.info.DBName, w.entries_tbl) + } + + sql += fmt.Sprintf("(`%s`, `%s`, `%s`, `%s`) ", + catalog.SystemSI_IVFFLAT_TblCol_Entries_version, + catalog.SystemSI_IVFFLAT_TblCol_Entries_id, + catalog.SystemSI_IVFFLAT_TblCol_Entries_pk, + catalog.SystemSI_IVFFLAT_TblCol_Entries_entry) + + versql := fmt.Sprintf("SELECT CAST(%s as BIGINT) FROM `%s`.`%s` WHERE `%s` = 'version'", catalog.SystemSI_IVFFLAT_TblCol_Metadata_val, + w.info.DBName, w.meta_tbl, catalog.SystemSI_IVFFLAT_TblCol_Metadata_key) + + sql += fmt.Sprintf("WITH centroid as (SELECT * FROM `%s`.`%s` WHERE `%s` = (%s) ), ", w.info.DBName, w.centroids_tbl, catalog.SystemSI_IVFFLAT_TblCol_Centroids_version, versql) + sql += fmt.Sprintf("src as (SELECT %s FROM (VALUES %s)) ", cols, string(w.vbuf)) + sql += fmt.Sprintf("SELECT `%s`, `%s`, %s FROM src CENTROIDX('%s') JOIN centroid using (`%s`, `%s`)", + catalog.SystemSI_IVFFLAT_TblCol_Centroids_version, + catalog.SystemSI_IVFFLAT_TblCol_Centroids_id, + cnames_str, + w.ivfparam.OpType, + catalog.SystemSI_IVFFLAT_TblCol_Centroids_centroid, + cnames[1]) + + return []byte(sql), nil +} diff --git a/pkg/iscp/index_sqlwriter_test.go b/pkg/iscp/index_sqlwriter_test.go new file mode 100644 index 0000000000000..bf75164a255a2 --- /dev/null +++ b/pkg/iscp/index_sqlwriter_test.go @@ -0,0 +1,242 @@ +// Copyright 2024 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package iscp + +import ( + "context" + "fmt" + "testing" + + "github.com/matrixorigin/matrixone/pkg/catalog" + "github.com/matrixorigin/matrixone/pkg/container/types" + "github.com/matrixorigin/matrixone/pkg/pb/plan" + "github.com/stretchr/testify/require" +) + +func newTestIvfflatTableDef(pkName string, pkType types.T, vecColName string, vecType types.T, vecWidth int32) *plan.TableDef { + return &plan.TableDef{ + Name: "test_orig_tbl", + Name2ColIndex: map[string]int32{ + pkName: 0, + vecColName: 1, + "dummy": 2, // Add another col to make sure pk/vec col indices are used + }, + Cols: []*plan.ColDef{ + {Name: pkName, Typ: plan.Type{Id: int32(pkType)}}, + {Name: vecColName, Typ: plan.Type{Id: int32(vecType), Width: vecWidth}}, + {Name: "dummy", Typ: plan.Type{Id: int32(types.T_int32)}}, + }, + Pkey: &plan.PrimaryKeyDef{ + Names: []string{pkName}, + PkeyColName: pkName, + }, + Indexes: []*plan.IndexDef{ + { + IndexName: "ivfidx", + TableExist: true, + IndexAlgo: catalog.MoIndexIvfFlatAlgo.ToString(), + IndexAlgoTableType: catalog.SystemSI_IVFFLAT_TblType_Metadata, + IndexTableName: "meta_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"lists":"16","op_type":"vector_l2_ops"}`, + }, + { + IndexName: "ivfidx", + TableExist: true, + IndexAlgo: catalog.MoIndexIvfFlatAlgo.ToString(), + IndexAlgoTableType: catalog.SystemSI_IVFFLAT_TblType_Centroids, + IndexTableName: "centroids_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"lists":"16","op_type":"vector_l2_ops"}`, + }, + { + IndexName: "ivfidx", + TableExist: true, + IndexAlgo: catalog.MoIndexIvfFlatAlgo.ToString(), + IndexAlgoTableType: catalog.SystemSI_IVFFLAT_TblType_Entries, + IndexTableName: "entries_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"lists":"16","op_type":"vector_l2_ops"}`, + }, + }, + DbName: "mydb", + } +} + +func newTestFulltextTableDef(pkName string, pkType types.T, vecColName string, vecType types.T, vecWidth int32) *plan.TableDef { + return &plan.TableDef{ + Name: "test_orig_tbl", + Name2ColIndex: map[string]int32{ + pkName: 0, + vecColName: 1, + "dummy": 2, // Add another col to make sure pk/vec col indices are used + }, + Cols: []*plan.ColDef{ + {Name: pkName, Typ: plan.Type{Id: int32(pkType)}}, + {Name: vecColName, Typ: plan.Type{Id: int32(vecType), Width: vecWidth}}, + {Name: "dummy", Typ: plan.Type{Id: int32(types.T_int32)}}, + }, + Pkey: &plan.PrimaryKeyDef{ + Names: []string{pkName}, + PkeyColName: pkName, + }, + Indexes: []*plan.IndexDef{ + { + IndexName: "fulltext_idx", + TableExist: true, + IndexAlgo: catalog.MOIndexFullTextAlgo.ToString(), + IndexAlgoTableType: "", + IndexTableName: "fulltext_tbl", + Parts: []string{vecColName}, + IndexAlgoParams: `{"parser":"ngram"}`, + }, + }, + DbName: "mydb", + } +} + +func newTestFulltextTableDef2Parts(pkName string, pkType types.T, vecColName string, vecColName2 string, vecType types.T, vecWidth int32) *plan.TableDef { + return &plan.TableDef{ + Name: "test_orig_tbl", + Name2ColIndex: map[string]int32{ + pkName: 0, + vecColName: 1, + vecColName2: 2, + "dummy": 3, // Add another col to make sure pk/vec col indices are used + }, + Cols: []*plan.ColDef{ + {Name: pkName, Typ: plan.Type{Id: int32(pkType)}}, + {Name: vecColName, Typ: plan.Type{Id: int32(vecType), Width: vecWidth}}, + {Name: vecColName2, Typ: plan.Type{Id: int32(vecType), Width: vecWidth}}, + {Name: "dummy", Typ: plan.Type{Id: int32(types.T_int32)}}, + }, + Pkey: &plan.PrimaryKeyDef{ + Names: []string{pkName}, + PkeyColName: pkName, + }, + Indexes: []*plan.IndexDef{ + { + IndexName: "fulltext_idx", + TableExist: true, + IndexAlgo: catalog.MOIndexFullTextAlgo.ToString(), + IndexAlgoTableType: "", + IndexTableName: "fulltext_tbl", + Parts: []string{vecColName, vecColName2}, + IndexAlgoParams: `{"parser":"ngram"}`, + }, + }, + DbName: "mydb", + } +} + +func TestNewFulltextSqlWriter(t *testing.T) { + var ctx context.Context + + tabledef := newTestFulltextTableDef("id", types.T_int64, "body", types.T_varchar, 256) + consumerInfo := newTestConsumerInfo() + jobID := newTestJobID() + + writer, err := NewIndexSqlWriter("fulltext", jobID, consumerInfo, tabledef, tabledef.Indexes) + require.Nil(t, err) + + row := []any{int64(1000), []uint8("hello world"), nil} + err = writer.Upsert(ctx, row) + require.Nil(t, err) + + row = []any{int64(2000), []uint8("hello world"), nil} + err = writer.Upsert(ctx, row) + require.Nil(t, err) + + bytes, err := writer.ToSql() + require.Nil(t, err) + fmt.Println(string(bytes)) + +} + +func TestNewFulltextSqlWriterCPkey(t *testing.T) { + var ctx context.Context + + tabledef := newTestFulltextTableDef2Parts("__mo_cpkey", types.T_varbinary, "body", "title", types.T_varchar, 256) + consumerInfo := newTestConsumerInfo() + jobID := newTestJobID() + + writer, err := NewIndexSqlWriter("fulltext", jobID, consumerInfo, tabledef, tabledef.Indexes) + require.Nil(t, err) + + row := []any{[]uint8("abcdef12"), []uint8("hello world"), []uint8("one title"), nil} + err = writer.Upsert(ctx, row) + require.Nil(t, err) + + row = []any{[]uint8("abc"), []uint8("hello world"), []uint8("two title"), nil} + err = writer.Upsert(ctx, row) + require.Nil(t, err) + + bytes, err := writer.ToSql() + require.Nil(t, err) + fmt.Println(string(bytes)) + +} + +func TestNewHnswSqlWriter(t *testing.T) { + var ctx context.Context + + tabledef := newTestTableDef("pk", types.T_int64, "vec", types.T_array_float32, 3) + consumerInfo := newTestConsumerInfo() + jobID := newTestJobID() + + writer, err := NewHnswSqlWriter("fulltext", jobID, consumerInfo, tabledef, tabledef.Indexes) + require.Nil(t, err) + row := []any{int64(1000), []float32{1, 2, 3}, nil} + err = writer.Upsert(ctx, row) + require.Nil(t, err) + + row = []any{int64(2000), []float32{5, 6, 7}, nil} + err = writer.Insert(ctx, row) + require.Nil(t, err) + + row = []any{int64(3000), []float32{5, 6, 7}, nil} + err = writer.Delete(ctx, row) + require.Nil(t, err) + + bytes, err := writer.ToSql() + require.Nil(t, err) + fmt.Println(string(bytes)) +} + +func TestNewIvfflatSqlWriter(t *testing.T) { + var ctx context.Context + + tabledef := newTestIvfflatTableDef("pk", types.T_int64, "vec", types.T_array_float64, 3) + consumerInfo := newTestConsumerInfo() + jobID := newTestJobID() + + writer, err := NewIvfflatSqlWriter("ivfflat", jobID, consumerInfo, tabledef, tabledef.Indexes) + require.Nil(t, err) + row := []any{int64(1000), []float64{1, 2, 3}, nil} + err = writer.Insert(ctx, row) + require.Nil(t, err) + + row = []any{int64(2000), []float64{5, 6, 7}, nil} + err = writer.Insert(ctx, row) + require.Nil(t, err) + + row = []any{int64(3000), []float64{5, 6, 7}, nil} + err = writer.Insert(ctx, row) + require.Nil(t, err) + + bytes, err := writer.ToSql() + require.Nil(t, err) + fmt.Println(string(bytes)) +} diff --git a/pkg/iscp/util.go b/pkg/iscp/util.go index 50dd4eed40f03..7abb3be197d15 100644 --- a/pkg/iscp/util.go +++ b/pkg/iscp/util.go @@ -16,6 +16,8 @@ package iscp import ( "context" + "encoding/hex" + "slices" // "encoding/hex" "math" // "slices" @@ -28,6 +30,8 @@ import ( "github.com/matrixorigin/matrixone/pkg/common/moerr" "github.com/matrixorigin/matrixone/pkg/common/mpool" "github.com/matrixorigin/matrixone/pkg/container/batch" + "github.com/matrixorigin/matrixone/pkg/container/bytejson" + // "github.com/matrixorigin/matrixone/pkg/container/bytejson" "github.com/matrixorigin/matrixone/pkg/container/types" "github.com/matrixorigin/matrixone/pkg/container/vector" @@ -74,12 +78,12 @@ func extractRowFromVector(ctx context.Context, vec *vector.Vector, i int, row [] } switch vec.GetType().Oid { //get col - // case types.T_json: - // row[i] = types.DecodeJson(copyBytes(vec.GetBytesAt(rowIndex))) + case types.T_json: + row[i] = types.DecodeJson(copyBytes(vec.GetBytesAt(rowIndex))) case types.T_bool: row[i] = vector.GetFixedAtWithTypeCheck[bool](vec, rowIndex) - // case types.T_bit: - // row[i] = vector.GetFixedAtWithTypeCheck[uint64](vec, rowIndex) + case types.T_bit: + row[i] = vector.GetFixedAtWithTypeCheck[uint64](vec, rowIndex) case types.T_int8: row[i] = vector.GetFixedAtWithTypeCheck[int8](vec, rowIndex) case types.T_uint8: @@ -102,46 +106,46 @@ func extractRowFromVector(ctx context.Context, vec *vector.Vector, i int, row [] row[i] = vector.GetFixedAtWithTypeCheck[float64](vec, rowIndex) case types.T_char, types.T_varchar, types.T_blob, types.T_text, types.T_binary, types.T_varbinary, types.T_datalink: row[i] = copyBytes(vec.GetBytesAt(rowIndex)) - // case types.T_array_float32: - // // NOTE: Don't merge it with T_varchar. You will get raw binary in the SQL output - // //+------------------------------+ - // //| abs(cast([1,2,3] as vecf32)) | - // //+------------------------------+ - // //| �? @ @@ | - // //+------------------------------+ - // row[i] = vector.GetArrayAt[float32](vec, rowIndex) - // case types.T_array_float64: - // row[i] = vector.GetArrayAt[float64](vec, rowIndex) - // case types.T_date: - // row[i] = vector.GetFixedAtWithTypeCheck[types.Date](vec, rowIndex) - // case types.T_datetime: - // scale := vec.GetType().Scale - // row[i] = vector.GetFixedAtWithTypeCheck[types.Datetime](vec, rowIndex).String2(scale) - // case types.T_time: - // scale := vec.GetType().Scale - // row[i] = vector.GetFixedAtWithTypeCheck[types.Time](vec, rowIndex).String2(scale) + case types.T_array_float32: + // NOTE: Don't merge it with T_varchar. You will get raw binary in the SQL output + //+------------------------------+ + //| abs(cast([1,2,3] as vecf32)) | + //+------------------------------+ + //| �? @ @@ | + //+------------------------------+ + row[i] = vector.GetArrayAt[float32](vec, rowIndex) + case types.T_array_float64: + row[i] = vector.GetArrayAt[float64](vec, rowIndex) + case types.T_date: + row[i] = vector.GetFixedAtWithTypeCheck[types.Date](vec, rowIndex) + case types.T_datetime: + scale := vec.GetType().Scale + row[i] = vector.GetFixedAtWithTypeCheck[types.Datetime](vec, rowIndex).String2(scale) + case types.T_time: + scale := vec.GetType().Scale + row[i] = vector.GetFixedAtWithTypeCheck[types.Time](vec, rowIndex).String2(scale) case types.T_timestamp: scale := vec.GetType().Scale //TODO:get the right timezone //timeZone := ses.GetTimeZone() timeZone := time.UTC row[i] = vector.GetFixedAtWithTypeCheck[types.Timestamp](vec, rowIndex).String2(timeZone, scale) - // case types.T_decimal64: - // scale := vec.GetType().Scale - // row[i] = vector.GetFixedAtWithTypeCheck[types.Decimal64](vec, rowIndex).Format(scale) - // case types.T_decimal128: - // scale := vec.GetType().Scale - // row[i] = vector.GetFixedAtWithTypeCheck[types.Decimal128](vec, rowIndex).Format(scale) - // case types.T_uuid: - // row[i] = vector.GetFixedAtWithTypeCheck[types.Uuid](vec, rowIndex).String() - // case types.T_Rowid: - // row[i] = vector.GetFixedAtWithTypeCheck[types.Rowid](vec, rowIndex) - // case types.T_Blockid: - // row[i] = vector.GetFixedAtWithTypeCheck[types.Blockid](vec, rowIndex) - // case types.T_TS: - // row[i] = vector.GetFixedAtWithTypeCheck[types.TS](vec, rowIndex) - // case types.T_enum: - // row[i] = vector.GetFixedAtWithTypeCheck[types.Enum](vec, rowIndex) + case types.T_decimal64: + scale := vec.GetType().Scale + row[i] = vector.GetFixedAtWithTypeCheck[types.Decimal64](vec, rowIndex).Format(scale) + case types.T_decimal128: + scale := vec.GetType().Scale + row[i] = vector.GetFixedAtWithTypeCheck[types.Decimal128](vec, rowIndex).Format(scale) + case types.T_uuid: + row[i] = vector.GetFixedAtWithTypeCheck[types.Uuid](vec, rowIndex).String() + case types.T_Rowid: + row[i] = vector.GetFixedAtWithTypeCheck[types.Rowid](vec, rowIndex) + case types.T_Blockid: + row[i] = vector.GetFixedAtWithTypeCheck[types.Blockid](vec, rowIndex) + case types.T_TS: + row[i] = vector.GetFixedAtWithTypeCheck[types.TS](vec, rowIndex) + case types.T_enum: + row[i] = vector.GetFixedAtWithTypeCheck[types.Enum](vec, rowIndex) default: logutil.Error( "Failed to extract row from vector, unsupported type", @@ -172,11 +176,11 @@ func convertColIntoSql( } var temp string switch typ.Oid { //get col - // case types.T_json: - // sqlBuff = appendByte(sqlBuff, '\'') - // temp = data.(bytejson.ByteJson).String() - // sqlBuff = appendString(sqlBuff, temp) - // sqlBuff = appendByte(sqlBuff, '\'') + case types.T_json: + sqlBuff = appendByte(sqlBuff, '\'') + temp = data.(bytejson.ByteJson).String() + sqlBuff = appendString(sqlBuff, temp) + sqlBuff = appendByte(sqlBuff, '\'') case types.T_bool: b := data.(bool) if b { @@ -185,15 +189,15 @@ func convertColIntoSql( temp = "false" } sqlBuff = appendString(sqlBuff, temp) - // case types.T_bit: - // value := data.(uint64) - // bitLength := typ.Width - // byteLength := (bitLength + 7) / 8 - // b := types.EncodeUint64(&value)[:byteLength] - // slices.Reverse(b) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendBytes(sqlBuff, b) - // sqlBuff = appendByte(sqlBuff, '\'') + case types.T_bit: + value := data.(uint64) + bitLength := typ.Width + byteLength := (bitLength + 7) / 8 + b := types.EncodeUint64(&value)[:byteLength] + slices.Reverse(b) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendBytes(sqlBuff, b) + sqlBuff = appendByte(sqlBuff, '\'') case types.T_int8: value := data.(int8) sqlBuff = appendInt64(sqlBuff, int64(value)) @@ -224,8 +228,8 @@ func convertColIntoSql( case types.T_float64: value := data.(float64) sqlBuff = appendFloat64(sqlBuff, value, 64) - // case types.T_binary, types.T_varbinary, types.T_blob: - // sqlBuff = appendHex(sqlBuff, data.([]byte)) + case types.T_binary, types.T_varbinary, types.T_blob: + sqlBuff = appendHex(sqlBuff, data.([]byte)) case types.T_char, types.T_varchar, types.T_text, @@ -236,77 +240,77 @@ func convertColIntoSql( sqlBuff = appendByte(sqlBuff, '\'') sqlBuff = appendBytes(sqlBuff, []byte(value)) sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_array_float32: - // // NOTE: Don't merge it with T_varchar. You will get raw binary in the SQL output - // //+------------------------------+ - // //| abs(cast([1,2,3] as vecf32)) | - // //+------------------------------+ - // //| �? @ @@ | - // //+------------------------------+ - // value := data.([]float32) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, types.ArrayToString(value)) - // sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_array_float64: - // value := data.([]float64) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, types.ArrayToString(value)) - // sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_date: - // value := data.(types.Date) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, value.String()) - // sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_datetime: - // value := data.(string) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, value) - // sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_time: - // value := data.(string) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, value) - // sqlBuff = appendByte(sqlBuff, '\'') + case types.T_array_float32: + // NOTE: Don't merge it with T_varchar. You will get raw binary in the SQL output + //+------------------------------+ + //| abs(cast([1,2,3] as vecf32)) | + //+------------------------------+ + //| �? @ @@ | + //+------------------------------+ + value := data.([]float32) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, types.ArrayToString(value)) + sqlBuff = appendByte(sqlBuff, '\'') + case types.T_array_float64: + value := data.([]float64) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, types.ArrayToString(value)) + sqlBuff = appendByte(sqlBuff, '\'') + case types.T_date: + value := data.(types.Date) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, value.String()) + sqlBuff = appendByte(sqlBuff, '\'') + case types.T_datetime: + value := data.(string) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, value) + sqlBuff = appendByte(sqlBuff, '\'') + case types.T_time: + value := data.(string) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, value) + sqlBuff = appendByte(sqlBuff, '\'') case types.T_timestamp: value := data.(string) sqlBuff = appendByte(sqlBuff, '\'') sqlBuff = appendString(sqlBuff, value) sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_decimal64: - // value := data.(string) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, value) - // sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_decimal128: - // value := data.(string) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, value) - // sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_uuid: - // value := data.(string) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, value) - // sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_Rowid: - // value := data.(types.Rowid) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, value.String()) - // sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_Blockid: - // value := data.(types.Blockid) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, value.String()) - // sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_TS: - // value := data.(types.TS) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, value.ToString()) - // sqlBuff = appendByte(sqlBuff, '\'') - // case types.T_enum: - // value := data.(types.Enum) - // sqlBuff = appendByte(sqlBuff, '\'') - // sqlBuff = appendString(sqlBuff, value.String()) - // sqlBuff = appendByte(sqlBuff, '\'') + case types.T_decimal64: + value := data.(string) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, value) + sqlBuff = appendByte(sqlBuff, '\'') + case types.T_decimal128: + value := data.(string) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, value) + sqlBuff = appendByte(sqlBuff, '\'') + case types.T_uuid: + value := data.(string) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, value) + sqlBuff = appendByte(sqlBuff, '\'') + case types.T_Rowid: + value := data.(types.Rowid) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, value.String()) + sqlBuff = appendByte(sqlBuff, '\'') + case types.T_Blockid: + value := data.(types.Blockid) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, value.String()) + sqlBuff = appendByte(sqlBuff, '\'') + case types.T_TS: + value := data.(types.TS) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, value.ToString()) + sqlBuff = appendByte(sqlBuff, '\'') + case types.T_enum: + value := data.(types.Enum) + sqlBuff = appendByte(sqlBuff, '\'') + sqlBuff = appendString(sqlBuff, value.String()) + sqlBuff = appendByte(sqlBuff, '\'') default: logutil.Error( "Failed to extract row from vector, unsupported type", @@ -317,12 +321,12 @@ func convertColIntoSql( return sqlBuff, nil } -// func appendHex(dst []byte, src []byte) []byte { -// dst = append(dst, "x'"...) -// dst = hex.AppendEncode(dst, src) -// dst = append(dst, '\'') -// return dst -// } +func appendHex(dst []byte, src []byte) []byte { + dst = append(dst, "x'"...) + dst = hex.AppendEncode(dst, src) + dst = append(dst, '\'') + return dst +} func appendByte(buf []byte, d byte) []byte { return append(buf, d) diff --git a/pkg/sql/compile/cdc_util.go b/pkg/sql/compile/cdc_util.go new file mode 100644 index 0000000000000..06535dabe5c1f --- /dev/null +++ b/pkg/sql/compile/cdc_util.go @@ -0,0 +1,256 @@ +// Copyright 2023 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package compile + +import ( + "context" + "fmt" + + "github.com/matrixorigin/matrixone/pkg/catalog" + "github.com/matrixorigin/matrixone/pkg/iscp" + "github.com/matrixorigin/matrixone/pkg/logutil" + "github.com/matrixorigin/matrixone/pkg/pb/plan" + "github.com/matrixorigin/matrixone/pkg/txn/client" +) + +/* CDC APIs */ +func RegisterJob(ctx context.Context, cnUUID string, txn client.TxnOperator, pitr_name string, spec *iscp.JobSpec, job *iscp.JobID) (bool, error) { + //dummyurl := "mysql://root:111@127.0.0.1:6001" + // sql = fmt.Sprintf("CREATE CDC `%s` '%s' 'indexsync' '%s' '%s.%s' {'Level'='table'};", cdcname, dummyurl, dummyurl, qryDatabase, srctbl) + return iscp.RegisterJob(ctx, cnUUID, txn, pitr_name, spec, job) +} + +func UnregisterJob(ctx context.Context, cnUUID string, txn client.TxnOperator, job *iscp.JobID) (bool, error) { + return iscp.UnregisterJob(ctx, cnUUID, txn, job) +} + +/* start here */ +func CreateCdcTask(c *Compile, pitr_name string, spec *iscp.JobSpec, job *iscp.JobID) (bool, error) { + logutil.Infof("Create Index Task %v", spec) + + return RegisterJob(c.proc.Ctx, c.proc.GetService(), c.proc.GetTxnOperator(), pitr_name, spec, job) +} + +func DeleteCdcTask(c *Compile, job *iscp.JobID) (bool, error) { + logutil.Infof("Delete Index Task %v", job) + return UnregisterJob(c.proc.Ctx, c.proc.GetService(), c.proc.GetTxnOperator(), job) +} + +func getIndexPitrName(dbname string, tablename string) string { + return fmt.Sprintf("__mo_idxpitr_%s_%s", dbname, tablename) +} + +func CreateIndexPitr(c *Compile, dbname string, tablename string) (string, error) { + var sql string + pitr_name := getIndexPitrName(dbname, tablename) + sql = fmt.Sprintf("CREATE PITR IF NOT EXISTS `%s` FOR TABLE `%s` `%s` range 2 'h' INTERNAL;", pitr_name, dbname, tablename) + logutil.Infof("Create Index Pitr %s. sql: %s:", pitr_name, sql) + err := c.runSql(sql) + if err != nil { + return pitr_name, err + } + + return pitr_name, nil +} + +func DeleteIndexPitr(c *Compile, dbname string, tablename string) error { + pitr_name := getIndexPitrName(dbname, tablename) + // remove pitr + sql := fmt.Sprintf("DROP PITR IF EXISTS `%s` INTERNAL;", pitr_name) + logutil.Infof("Delete Index Pitr %s: %s", pitr_name, sql) + err := c.runSql(sql) + if err != nil { + return err + } + + return nil +} + +func checkValidIndexCdc(tableDef *plan.TableDef, indexname string) bool { + for _, idx := range tableDef.Indexes { + if idx.IndexName == indexname { + if idx.TableExist && + (catalog.IsHnswIndexAlgo(idx.IndexAlgo) || + catalog.IsIvfIndexAlgo(idx.IndexAlgo) || + catalog.IsFullTextIndexAlgo(idx.IndexAlgo)) { + return true + } + } + } + return false +} + +// NOTE: CreateIndexCdcTask will create CDC task without any checking. Original TableDef may be empty +func CreateIndexCdcTask(c *Compile, dbname string, tablename string, indexname string, sinker_type int8) error { + var err error + + // create table pitr if not exists and return pitr_name + pitr_name, err := CreateIndexPitr(c, dbname, tablename) + if err != nil { + return err + } + + spec := &iscp.JobSpec{ + ConsumerInfo: iscp.ConsumerInfo{ConsumerType: sinker_type, + DBName: dbname, + TableName: tablename, + IndexName: indexname}, + } + job := &iscp.JobID{DBName: dbname, TableName: tablename, JobName: genCdcTaskJobID(indexname)} + + // create index cdc task + ok, err := CreateCdcTask(c, pitr_name, spec, job) + if err != nil { + return err + } + + if !ok { + // cdc task already exist. ignore it. IVFFLAT alter reindex will call CreateIndexCdcTask multiple times. + logutil.Infof("index cdc task (%s, %s, %s) already exists", dbname, tablename, indexname) + return nil + } + return nil +} + +func genCdcTaskJobID(indexname string) string { + return "index_" + indexname +} + +func DropIndexCdcTask(c *Compile, tableDef *plan.TableDef, dbname string, tablename string, indexname string) error { + var err error + + if !checkValidIndexCdc(tableDef, indexname) { + // index name is not valid cdc task. ignore it + return nil + } + + // delete index cdc task + _, err = DeleteCdcTask(c, &iscp.JobID{DBName: dbname, TableName: tablename, JobName: genCdcTaskJobID(indexname)}) + if err != nil { + return err + } + + // remove pitr if no index uses the pitr + nindex := 0 + for _, idx := range tableDef.Indexes { + if idx.TableExist && + (catalog.IsHnswIndexAlgo(idx.IndexAlgo) || + catalog.IsIvfIndexAlgo(idx.IndexAlgo) || + catalog.IsFullTextIndexAlgo(idx.IndexAlgo)) { + + if idx.IndexName != indexname { + nindex++ + } + } + + } + + if nindex == 0 { + // remove pitr + err = DeleteIndexPitr(c, dbname, tablename) + if err != nil { + return err + } + } + + return nil +} + +// drop all cdc tasks according to tableDef +func DropAllIndexCdcTasks(c *Compile, tabledef *plan.TableDef, dbname string, tablename string) error { + idxmap := make(map[string]bool) + var err error + hasindex := false + for _, idx := range tabledef.Indexes { + if idx.TableExist && + (catalog.IsHnswIndexAlgo(idx.IndexAlgo) || + catalog.IsIvfIndexAlgo(idx.IndexAlgo) || + catalog.IsFullTextIndexAlgo(idx.IndexAlgo)) { + _, ok := idxmap[idx.IndexName] + if !ok { + idxmap[idx.IndexName] = true + async := false + if catalog.IsHnswIndexAlgo(idx.IndexAlgo) { + // HNSW always async + async = true + } else { + async, err = catalog.IsIndexAsync(idx.IndexAlgoParams) + if err != nil { + return err + } + } + if async { + hasindex = true + _, e := DeleteCdcTask(c, &iscp.JobID{DBName: dbname, TableName: tablename, JobName: genCdcTaskJobID(idx.IndexName)}) + if e != nil { + return e + } + } + } + } + } + + // remove pitr + if hasindex { + return DeleteIndexPitr(c, dbname, tablename) + } + return nil +} + +func getSinkerTypeFromAlgo(algo string) int8 { + if catalog.IsHnswIndexAlgo(algo) { + return int8(iscp.ConsumerType_IndexSync) + } else if catalog.IsIvfIndexAlgo(algo) { + return int8(iscp.ConsumerType_IndexSync) + } else if catalog.IsFullTextIndexAlgo(algo) { + return int8(iscp.ConsumerType_IndexSync) + } + panic("getSinkerTypeFromAlgo: invalid sinker type") +} + +// NOTE: CreateAllIndexCdcTasks will create CDC task according to existing tableDef +func CreateAllIndexCdcTasks(c *Compile, indexes []*plan.IndexDef, dbname string, tablename string) error { + idxmap := make(map[string]bool) + var err error + for _, idx := range indexes { + if idx.TableExist && + (catalog.IsHnswIndexAlgo(idx.IndexAlgo) || + catalog.IsIvfIndexAlgo(idx.IndexAlgo) || + catalog.IsFullTextIndexAlgo(idx.IndexAlgo)) { + _, ok := idxmap[idx.IndexName] + if !ok { + idxmap[idx.IndexName] = true + async := false + if catalog.IsHnswIndexAlgo(idx.IndexAlgo) { + // HNSW always async + async = true + } else { + async, err = catalog.IsIndexAsync(idx.IndexAlgoParams) + if err != nil { + return err + } + } + if async { + sinker_type := getSinkerTypeFromAlgo(idx.IndexAlgo) + e := CreateIndexCdcTask(c, dbname, tablename, idx.IndexName, sinker_type) + if e != nil { + return e + } + } + } + } + } + return nil +} diff --git a/pkg/sql/compile/ddl.go b/pkg/sql/compile/ddl.go index 89739ba5374e6..5dbef901db2b9 100644 --- a/pkg/sql/compile/ddl.go +++ b/pkg/sql/compile/ddl.go @@ -29,6 +29,7 @@ import ( "github.com/matrixorigin/matrixone/pkg/container/vector" "github.com/matrixorigin/matrixone/pkg/defines" "github.com/matrixorigin/matrixone/pkg/incrservice" + "github.com/matrixorigin/matrixone/pkg/logutil" "github.com/matrixorigin/matrixone/pkg/partitionservice" "github.com/matrixorigin/matrixone/pkg/pb/api" "github.com/matrixorigin/matrixone/pkg/pb/lock" @@ -705,9 +706,8 @@ func (s *Scope) AlterTableInplace(c *Compile) error { if err != nil { return err } - case catalog.MoIndexHnswAlgo.ToString(): - // PASS: keep option unchange for incremental update + // PASS default: return moerr.NewInternalError(c.proc.Ctx, "invalid index algo type for alter reindex") } @@ -1417,6 +1417,21 @@ func (s *Scope) CreateTable(c *Compile) error { ) return err } + + // TODO: HNSWCDC create PITR and CDC for index async update + ct, err := GetConstraintDef(c.proc.Ctx, newRelation) + if err != nil { + return err + } + for _, constraint := range ct.Cts { + if idxdef, ok := constraint.(*engine.IndexDef); ok && len(idxdef.Indexes) > 0 { + err = CreateAllIndexCdcTasks(c, idxdef.Indexes, dbName, tblName) + if err != nil { + return err + } + } + } + } err = maybeCreateAutoIncrement( @@ -2013,6 +2028,21 @@ func (s *Scope) handleVectorIvfFlatIndex( return err } + async, err := catalog.IsIndexAsync(indexDefs[catalog.SystemSI_IVFFLAT_TblType_Metadata].IndexAlgoParams) + if err != nil { + return err + } + + // HNSWCDC CREATE PITR AND CDC TASK HERE + if async { + logutil.Infof("Ivfflat index Async is true") + sinker_type := getSinkerTypeFromAlgo(catalog.MoIndexIvfFlatAlgo.ToString()) + err = CreateIndexCdcTask(c, qryDatabase, originalTableDef.Name, + indexDefs[catalog.SystemSI_IVFFLAT_TblType_Metadata].IndexTableName, sinker_type) + if err != nil { + return err + } + } return nil } @@ -2037,6 +2067,9 @@ func (s *Scope) DropIndex(c *Compile) error { return err } + // old tabledef + oldTableDef := r.GetTableDef(c.proc.Ctx) + //1. build and update constraint def oldCt, err := GetConstraintDef(c.proc.Ctx, r) if err != nil { @@ -2065,14 +2098,20 @@ func (s *Scope) DropIndex(c *Compile) error { return err } + //3. HNSWCDC delete cdc table task for vector, fulltext index + err = DropIndexCdcTask(c, oldTableDef, qry.Database, qry.Table, qry.IndexName) + if err != nil { + return err + } } - //3. delete index object from mo_catalog.mo_indexes + //4. delete index object from mo_catalog.mo_indexes deleteSql := fmt.Sprintf(deleteMoIndexesWithTableIdAndIndexNameFormat, r.GetTableID(c.proc.Ctx), qry.IndexName) err = c.runSql(deleteSql) if err != nil { return err } + return nil } @@ -2331,6 +2370,15 @@ func (s *Scope) TruncateTable(c *Compile) error { } } + // TODO: HNSWCDC drop CDC task with old table Id before truncate index table + if !isTemp { + tabledef := rel.GetTableDef(c.proc.Ctx) + e := DropAllIndexCdcTasks(c, tabledef, dbName, tblName) + if e != nil { + return e + } + } + if isTemp { // memoryengine truncate always return 0, so for temporary table, just use origin tableId as newId _, err = dbSource.Truncate(c.proc.Ctx, engine.GetTempTableName(dbName, tblName)) @@ -2454,6 +2502,15 @@ func (s *Scope) TruncateTable(c *Compile) error { return err } + // TODO: HNSWCDC create CDC task with new table Id + if !isTemp { + tabledef := rel.GetTableDef(c.proc.Ctx) + e := CreateAllIndexCdcTasks(c, tabledef.Indexes, dbName, tblName) + if e != nil { + return e + } + } + c.addAffectedRows(uint64(affectedRows)) return nil } @@ -2622,6 +2679,12 @@ func (s *Scope) DropTable(c *Compile) error { } } + // HNSWCDC delete cdc task of the vector and fulltext index here + err = DropAllIndexCdcTasks(c, rel.GetTableDef(c.proc.Ctx), qry.Database, qry.Table) + if err != nil { + return err + } + // delete all index objects record of the table in mo_catalog.mo_indexes if !qry.IsView && qry.Database != catalog.MO_CATALOG && qry.Table != catalog.MO_INDEXES { if qry.GetTableDef().Pkey != nil || len(qry.GetTableDef().Indexes) > 0 { diff --git a/pkg/sql/compile/ddl_index_algo.go b/pkg/sql/compile/ddl_index_algo.go index 0c607df3632af..57409bff43cf6 100644 --- a/pkg/sql/compile/ddl_index_algo.go +++ b/pkg/sql/compile/ddl_index_algo.go @@ -23,6 +23,7 @@ import ( "github.com/matrixorigin/matrixone/pkg/catalog" "github.com/matrixorigin/matrixone/pkg/common/moerr" "github.com/matrixorigin/matrixone/pkg/container/vector" + "github.com/matrixorigin/matrixone/pkg/logutil" "github.com/matrixorigin/matrixone/pkg/pb/api" "github.com/matrixorigin/matrixone/pkg/pb/plan" "github.com/matrixorigin/matrixone/pkg/util/executor" @@ -148,13 +149,33 @@ func (s *Scope) handleFullTextIndexTable( return err } - insertSQLs := genInsertIndexTableSqlForFullTextIndex(originalTableDef, indexDef, qryDatabase) + insertSQLs, err := genInsertIndexTableSqlForFullTextIndex(originalTableDef, indexDef, qryDatabase) + if err != nil { + return err + } + for _, insertSQL := range insertSQLs { err = c.runSql(insertSQL) if err != nil { return err } } + + async, err := catalog.IsIndexAsync(indexDef.IndexAlgoParams) + if err != nil { + return err + } + // TODO: HNSWCDC create PITR and CDC TASK here + if async { + logutil.Infof("fulltext index Async is true") + sinker_type := getSinkerTypeFromAlgo(catalog.MOIndexFullTextAlgo.ToString()) + err = CreateIndexCdcTask(c, qryDatabase, originalTableDef.Name, + indexDef.IndexTableName, sinker_type) + if err != nil { + return err + } + } + return nil } @@ -571,5 +592,12 @@ func (s *Scope) handleVectorHnswIndex( } } + // TODO: HNSWCDC 4. register CDC update + sinker_type := getSinkerTypeFromAlgo(catalog.MoIndexHnswAlgo.ToString()) + err = CreateIndexCdcTask(c, qryDatabase, originalTableDef.Name, indexDefs[catalog.Hnsw_TblType_Metadata].IndexName, sinker_type) + if err != nil { + return err + } + return nil } diff --git a/pkg/sql/compile/util.go b/pkg/sql/compile/util.go index 06802a2b78312..5607811c2342f 100644 --- a/pkg/sql/compile/util.go +++ b/pkg/sql/compile/util.go @@ -506,7 +506,7 @@ func GetConstraintDefFromTableDefs(defs []engine.TableDef) *engine.ConstraintDef return cstrDef } -func genInsertIndexTableSqlForFullTextIndex(originalTableDef *plan.TableDef, indexDef *plan.IndexDef, qryDatabase string) []string { +func genInsertIndexTableSqlForFullTextIndex(originalTableDef *plan.TableDef, indexDef *plan.IndexDef, qryDatabase string) ([]string, error) { src_alias := "src" pkColName := src_alias + "." + originalTableDef.Pkey.PkeyColName params := indexDef.IndexAlgoParams @@ -527,7 +527,7 @@ func genInsertIndexTableSqlForFullTextIndex(originalTableDef *plan.TableDef, ind pkColName, concat) - return []string{sql} + return []string{sql}, nil } func genDeleteHnswIndex(proc *process.Process, indexDefs map[string]*plan.IndexDef, qryDatabase string, originalTableDef *plan.TableDef) ([]string, error) { diff --git a/pkg/sql/parsers/dialect/mysql/keywords.go b/pkg/sql/parsers/dialect/mysql/keywords.go index 17de914d405fa..5f6d1081749d1 100644 --- a/pkg/sql/parsers/dialect/mysql/keywords.go +++ b/pkg/sql/parsers/dialect/mysql/keywords.go @@ -36,6 +36,7 @@ func init() { "asc": ASC, "ascii": ASCII, "asensitive": UNUSED, + "async": ASYNC, "auto_increment": AUTO_INCREMENT, "autoextend_size": AUTOEXTEND_SIZE, "auto_random": AUTO_RANDOM, diff --git a/pkg/sql/parsers/dialect/mysql/mysql_sql.go b/pkg/sql/parsers/dialect/mysql/mysql_sql.go index ce947c3c28110..a25e1baee853a 100644 --- a/pkg/sql/parsers/dialect/mysql/mysql_sql.go +++ b/pkg/sql/parsers/dialect/mysql/mysql_sql.go @@ -362,305 +362,306 @@ const EF_SEARCH = 57685 const EF_CONSTRUCTION = 57686 const M = 57687 const QUANTIZATION = 57688 -const EXPIRE = 57689 -const ACCOUNT = 57690 -const ACCOUNTS = 57691 -const UNLOCK = 57692 -const DAY = 57693 -const NEVER = 57694 -const PUMP = 57695 -const MYSQL_COMPATIBILITY_MODE = 57696 -const UNIQUE_CHECK_ON_AUTOINCR = 57697 -const MODIFY = 57698 -const CHANGE = 57699 -const SECOND = 57700 -const ASCII = 57701 -const COALESCE = 57702 -const COLLATION = 57703 -const HOUR = 57704 -const MICROSECOND = 57705 -const MINUTE = 57706 -const MONTH = 57707 -const QUARTER = 57708 -const REPEAT = 57709 -const REVERSE = 57710 -const ROW_COUNT = 57711 -const WEEK = 57712 -const REVOKE = 57713 -const FUNCTION = 57714 -const PRIVILEGES = 57715 -const TABLESPACE = 57716 -const EXECUTE = 57717 -const SUPER = 57718 -const GRANT = 57719 -const OPTION = 57720 -const REFERENCES = 57721 -const REPLICATION = 57722 -const SLAVE = 57723 -const CLIENT = 57724 -const USAGE = 57725 -const RELOAD = 57726 -const FILE = 57727 -const TEMPORARY = 57728 -const ROUTINE = 57729 -const EVENT = 57730 -const SHUTDOWN = 57731 -const NULLX = 57732 -const AUTO_INCREMENT = 57733 -const APPROXNUM = 57734 -const SIGNED = 57735 -const UNSIGNED = 57736 -const ZEROFILL = 57737 -const ENGINES = 57738 -const LOW_CARDINALITY = 57739 -const AUTOEXTEND_SIZE = 57740 -const ADMIN_NAME = 57741 -const RANDOM = 57742 -const SUSPEND = 57743 -const ATTRIBUTE = 57744 -const HISTORY = 57745 -const REUSE = 57746 -const CURRENT = 57747 -const OPTIONAL = 57748 -const FAILED_LOGIN_ATTEMPTS = 57749 -const PASSWORD_LOCK_TIME = 57750 -const UNBOUNDED = 57751 -const SECONDARY = 57752 -const RESTRICTED = 57753 -const USER = 57754 -const IDENTIFIED = 57755 -const CIPHER = 57756 -const ISSUER = 57757 -const X509 = 57758 -const SUBJECT = 57759 -const SAN = 57760 -const REQUIRE = 57761 -const SSL = 57762 -const NONE = 57763 -const PASSWORD = 57764 -const SHARED = 57765 -const EXCLUSIVE = 57766 -const MAX_QUERIES_PER_HOUR = 57767 -const MAX_UPDATES_PER_HOUR = 57768 -const MAX_CONNECTIONS_PER_HOUR = 57769 -const MAX_USER_CONNECTIONS = 57770 -const FORMAT = 57771 -const VERBOSE = 57772 -const CONNECTION = 57773 -const TRIGGERS = 57774 -const PROFILES = 57775 -const LOAD = 57776 -const INLINE = 57777 -const INFILE = 57778 -const TERMINATED = 57779 -const OPTIONALLY = 57780 -const ENCLOSED = 57781 -const ESCAPED = 57782 -const STARTING = 57783 -const LINES = 57784 -const ROWS = 57785 -const IMPORT = 57786 -const DISCARD = 57787 -const JSONTYPE = 57788 -const MODUMP = 57789 -const OVER = 57790 -const PRECEDING = 57791 -const FOLLOWING = 57792 -const GROUPS = 57793 -const DATABASES = 57794 -const TABLES = 57795 -const SEQUENCES = 57796 -const EXTENDED = 57797 -const FULL = 57798 -const PROCESSLIST = 57799 -const FIELDS = 57800 -const COLUMNS = 57801 -const OPEN = 57802 -const ERRORS = 57803 -const WARNINGS = 57804 -const INDEXES = 57805 -const SCHEMAS = 57806 -const NODE = 57807 -const LOCKS = 57808 -const ROLES = 57809 -const TABLE_NUMBER = 57810 -const COLUMN_NUMBER = 57811 -const TABLE_VALUES = 57812 -const TABLE_SIZE = 57813 -const NAMES = 57814 -const GLOBAL = 57815 -const PERSIST = 57816 -const SESSION = 57817 -const ISOLATION = 57818 -const LEVEL = 57819 -const READ = 57820 -const WRITE = 57821 -const ONLY = 57822 -const REPEATABLE = 57823 -const COMMITTED = 57824 -const UNCOMMITTED = 57825 -const SERIALIZABLE = 57826 -const LOCAL = 57827 -const EVENTS = 57828 -const PLUGINS = 57829 -const CURRENT_TIMESTAMP = 57830 -const DATABASE = 57831 -const CURRENT_TIME = 57832 -const LOCALTIME = 57833 -const LOCALTIMESTAMP = 57834 -const UTC_DATE = 57835 -const UTC_TIME = 57836 -const UTC_TIMESTAMP = 57837 -const REPLACE = 57838 -const CONVERT = 57839 -const SEPARATOR = 57840 -const TIMESTAMPDIFF = 57841 -const CURRENT_DATE = 57842 -const CURRENT_USER = 57843 -const CURRENT_ROLE = 57844 -const SECOND_MICROSECOND = 57845 -const MINUTE_MICROSECOND = 57846 -const MINUTE_SECOND = 57847 -const HOUR_MICROSECOND = 57848 -const HOUR_SECOND = 57849 -const HOUR_MINUTE = 57850 -const DAY_MICROSECOND = 57851 -const DAY_SECOND = 57852 -const DAY_MINUTE = 57853 -const DAY_HOUR = 57854 -const YEAR_MONTH = 57855 -const SQL_TSI_HOUR = 57856 -const SQL_TSI_DAY = 57857 -const SQL_TSI_WEEK = 57858 -const SQL_TSI_MONTH = 57859 -const SQL_TSI_QUARTER = 57860 -const SQL_TSI_YEAR = 57861 -const SQL_TSI_SECOND = 57862 -const SQL_TSI_MINUTE = 57863 -const RECURSIVE = 57864 -const CONFIG = 57865 -const DRAINER = 57866 -const SOURCE = 57867 -const STREAM = 57868 -const HEADERS = 57869 -const CONNECTOR = 57870 -const CONNECTORS = 57871 -const DAEMON = 57872 -const PAUSE = 57873 -const CANCEL = 57874 -const TASK = 57875 -const RESUME = 57876 -const MATCH = 57877 -const AGAINST = 57878 -const BOOLEAN = 57879 -const LANGUAGE = 57880 -const WITH = 57881 -const QUERY = 57882 -const EXPANSION = 57883 -const WITHOUT = 57884 -const VALIDATION = 57885 -const UPGRADE = 57886 -const RETRY = 57887 -const ADDDATE = 57888 -const BIT_AND = 57889 -const BIT_OR = 57890 -const BIT_XOR = 57891 -const CAST = 57892 -const COUNT = 57893 -const APPROX_COUNT = 57894 -const APPROX_COUNT_DISTINCT = 57895 -const SERIAL_EXTRACT = 57896 -const APPROX_PERCENTILE = 57897 -const CURDATE = 57898 -const CURTIME = 57899 -const DATE_ADD = 57900 -const DATE_SUB = 57901 -const EXTRACT = 57902 -const GROUP_CONCAT = 57903 -const MAX = 57904 -const MID = 57905 -const MIN = 57906 -const NOW = 57907 -const POSITION = 57908 -const SESSION_USER = 57909 -const STD = 57910 -const STDDEV = 57911 -const MEDIAN = 57912 -const CLUSTER_CENTERS = 57913 -const KMEANS = 57914 -const STDDEV_POP = 57915 -const STDDEV_SAMP = 57916 -const SUBDATE = 57917 -const SUBSTR = 57918 -const SUBSTRING = 57919 -const SUM = 57920 -const SYSDATE = 57921 -const SYSTEM_USER = 57922 -const TRANSLATE = 57923 -const TRIM = 57924 -const VARIANCE = 57925 -const VAR_POP = 57926 -const VAR_SAMP = 57927 -const AVG = 57928 -const RANK = 57929 -const ROW_NUMBER = 57930 -const DENSE_RANK = 57931 -const BIT_CAST = 57932 -const BITMAP_BIT_POSITION = 57933 -const BITMAP_BUCKET_NUMBER = 57934 -const BITMAP_COUNT = 57935 -const BITMAP_CONSTRUCT_AGG = 57936 -const BITMAP_OR_AGG = 57937 -const NEXTVAL = 57938 -const SETVAL = 57939 -const CURRVAL = 57940 -const LASTVAL = 57941 -const ARROW = 57942 -const ROW = 57943 -const OUTFILE = 57944 -const HEADER = 57945 -const MAX_FILE_SIZE = 57946 -const FORCE_QUOTE = 57947 -const PARALLEL = 57948 -const STRICT = 57949 -const UNUSED = 57950 -const BINDINGS = 57951 -const DO = 57952 -const DECLARE = 57953 -const LOOP = 57954 -const WHILE = 57955 -const LEAVE = 57956 -const ITERATE = 57957 -const UNTIL = 57958 -const CALL = 57959 -const PREV = 57960 -const SLIDING = 57961 -const FILL = 57962 -const SPBEGIN = 57963 -const BACKEND = 57964 -const SERVERS = 57965 -const HANDLER = 57966 -const PERCENT = 57967 -const SAMPLE = 57968 -const MO_TS = 57969 -const PITR = 57970 -const RECOVERY_WINDOW = 57971 -const INTERNAL = 57972 -const CDC = 57973 -const GROUPING = 57974 -const SETS = 57975 -const CUBE = 57976 -const ROLLUP = 57977 -const LOGSERVICE = 57978 -const REPLICAS = 57979 -const STORES = 57980 -const SETTINGS = 57981 -const KILL = 57982 -const BACKUP = 57983 -const FILESYSTEM = 57984 -const PARALLELISM = 57985 -const RESTORE = 57986 -const QUERY_RESULT = 57987 +const ASYNC = 57689 +const EXPIRE = 57690 +const ACCOUNT = 57691 +const ACCOUNTS = 57692 +const UNLOCK = 57693 +const DAY = 57694 +const NEVER = 57695 +const PUMP = 57696 +const MYSQL_COMPATIBILITY_MODE = 57697 +const UNIQUE_CHECK_ON_AUTOINCR = 57698 +const MODIFY = 57699 +const CHANGE = 57700 +const SECOND = 57701 +const ASCII = 57702 +const COALESCE = 57703 +const COLLATION = 57704 +const HOUR = 57705 +const MICROSECOND = 57706 +const MINUTE = 57707 +const MONTH = 57708 +const QUARTER = 57709 +const REPEAT = 57710 +const REVERSE = 57711 +const ROW_COUNT = 57712 +const WEEK = 57713 +const REVOKE = 57714 +const FUNCTION = 57715 +const PRIVILEGES = 57716 +const TABLESPACE = 57717 +const EXECUTE = 57718 +const SUPER = 57719 +const GRANT = 57720 +const OPTION = 57721 +const REFERENCES = 57722 +const REPLICATION = 57723 +const SLAVE = 57724 +const CLIENT = 57725 +const USAGE = 57726 +const RELOAD = 57727 +const FILE = 57728 +const TEMPORARY = 57729 +const ROUTINE = 57730 +const EVENT = 57731 +const SHUTDOWN = 57732 +const NULLX = 57733 +const AUTO_INCREMENT = 57734 +const APPROXNUM = 57735 +const SIGNED = 57736 +const UNSIGNED = 57737 +const ZEROFILL = 57738 +const ENGINES = 57739 +const LOW_CARDINALITY = 57740 +const AUTOEXTEND_SIZE = 57741 +const ADMIN_NAME = 57742 +const RANDOM = 57743 +const SUSPEND = 57744 +const ATTRIBUTE = 57745 +const HISTORY = 57746 +const REUSE = 57747 +const CURRENT = 57748 +const OPTIONAL = 57749 +const FAILED_LOGIN_ATTEMPTS = 57750 +const PASSWORD_LOCK_TIME = 57751 +const UNBOUNDED = 57752 +const SECONDARY = 57753 +const RESTRICTED = 57754 +const USER = 57755 +const IDENTIFIED = 57756 +const CIPHER = 57757 +const ISSUER = 57758 +const X509 = 57759 +const SUBJECT = 57760 +const SAN = 57761 +const REQUIRE = 57762 +const SSL = 57763 +const NONE = 57764 +const PASSWORD = 57765 +const SHARED = 57766 +const EXCLUSIVE = 57767 +const MAX_QUERIES_PER_HOUR = 57768 +const MAX_UPDATES_PER_HOUR = 57769 +const MAX_CONNECTIONS_PER_HOUR = 57770 +const MAX_USER_CONNECTIONS = 57771 +const FORMAT = 57772 +const VERBOSE = 57773 +const CONNECTION = 57774 +const TRIGGERS = 57775 +const PROFILES = 57776 +const LOAD = 57777 +const INLINE = 57778 +const INFILE = 57779 +const TERMINATED = 57780 +const OPTIONALLY = 57781 +const ENCLOSED = 57782 +const ESCAPED = 57783 +const STARTING = 57784 +const LINES = 57785 +const ROWS = 57786 +const IMPORT = 57787 +const DISCARD = 57788 +const JSONTYPE = 57789 +const MODUMP = 57790 +const OVER = 57791 +const PRECEDING = 57792 +const FOLLOWING = 57793 +const GROUPS = 57794 +const DATABASES = 57795 +const TABLES = 57796 +const SEQUENCES = 57797 +const EXTENDED = 57798 +const FULL = 57799 +const PROCESSLIST = 57800 +const FIELDS = 57801 +const COLUMNS = 57802 +const OPEN = 57803 +const ERRORS = 57804 +const WARNINGS = 57805 +const INDEXES = 57806 +const SCHEMAS = 57807 +const NODE = 57808 +const LOCKS = 57809 +const ROLES = 57810 +const TABLE_NUMBER = 57811 +const COLUMN_NUMBER = 57812 +const TABLE_VALUES = 57813 +const TABLE_SIZE = 57814 +const NAMES = 57815 +const GLOBAL = 57816 +const PERSIST = 57817 +const SESSION = 57818 +const ISOLATION = 57819 +const LEVEL = 57820 +const READ = 57821 +const WRITE = 57822 +const ONLY = 57823 +const REPEATABLE = 57824 +const COMMITTED = 57825 +const UNCOMMITTED = 57826 +const SERIALIZABLE = 57827 +const LOCAL = 57828 +const EVENTS = 57829 +const PLUGINS = 57830 +const CURRENT_TIMESTAMP = 57831 +const DATABASE = 57832 +const CURRENT_TIME = 57833 +const LOCALTIME = 57834 +const LOCALTIMESTAMP = 57835 +const UTC_DATE = 57836 +const UTC_TIME = 57837 +const UTC_TIMESTAMP = 57838 +const REPLACE = 57839 +const CONVERT = 57840 +const SEPARATOR = 57841 +const TIMESTAMPDIFF = 57842 +const CURRENT_DATE = 57843 +const CURRENT_USER = 57844 +const CURRENT_ROLE = 57845 +const SECOND_MICROSECOND = 57846 +const MINUTE_MICROSECOND = 57847 +const MINUTE_SECOND = 57848 +const HOUR_MICROSECOND = 57849 +const HOUR_SECOND = 57850 +const HOUR_MINUTE = 57851 +const DAY_MICROSECOND = 57852 +const DAY_SECOND = 57853 +const DAY_MINUTE = 57854 +const DAY_HOUR = 57855 +const YEAR_MONTH = 57856 +const SQL_TSI_HOUR = 57857 +const SQL_TSI_DAY = 57858 +const SQL_TSI_WEEK = 57859 +const SQL_TSI_MONTH = 57860 +const SQL_TSI_QUARTER = 57861 +const SQL_TSI_YEAR = 57862 +const SQL_TSI_SECOND = 57863 +const SQL_TSI_MINUTE = 57864 +const RECURSIVE = 57865 +const CONFIG = 57866 +const DRAINER = 57867 +const SOURCE = 57868 +const STREAM = 57869 +const HEADERS = 57870 +const CONNECTOR = 57871 +const CONNECTORS = 57872 +const DAEMON = 57873 +const PAUSE = 57874 +const CANCEL = 57875 +const TASK = 57876 +const RESUME = 57877 +const MATCH = 57878 +const AGAINST = 57879 +const BOOLEAN = 57880 +const LANGUAGE = 57881 +const WITH = 57882 +const QUERY = 57883 +const EXPANSION = 57884 +const WITHOUT = 57885 +const VALIDATION = 57886 +const UPGRADE = 57887 +const RETRY = 57888 +const ADDDATE = 57889 +const BIT_AND = 57890 +const BIT_OR = 57891 +const BIT_XOR = 57892 +const CAST = 57893 +const COUNT = 57894 +const APPROX_COUNT = 57895 +const APPROX_COUNT_DISTINCT = 57896 +const SERIAL_EXTRACT = 57897 +const APPROX_PERCENTILE = 57898 +const CURDATE = 57899 +const CURTIME = 57900 +const DATE_ADD = 57901 +const DATE_SUB = 57902 +const EXTRACT = 57903 +const GROUP_CONCAT = 57904 +const MAX = 57905 +const MID = 57906 +const MIN = 57907 +const NOW = 57908 +const POSITION = 57909 +const SESSION_USER = 57910 +const STD = 57911 +const STDDEV = 57912 +const MEDIAN = 57913 +const CLUSTER_CENTERS = 57914 +const KMEANS = 57915 +const STDDEV_POP = 57916 +const STDDEV_SAMP = 57917 +const SUBDATE = 57918 +const SUBSTR = 57919 +const SUBSTRING = 57920 +const SUM = 57921 +const SYSDATE = 57922 +const SYSTEM_USER = 57923 +const TRANSLATE = 57924 +const TRIM = 57925 +const VARIANCE = 57926 +const VAR_POP = 57927 +const VAR_SAMP = 57928 +const AVG = 57929 +const RANK = 57930 +const ROW_NUMBER = 57931 +const DENSE_RANK = 57932 +const BIT_CAST = 57933 +const BITMAP_BIT_POSITION = 57934 +const BITMAP_BUCKET_NUMBER = 57935 +const BITMAP_COUNT = 57936 +const BITMAP_CONSTRUCT_AGG = 57937 +const BITMAP_OR_AGG = 57938 +const NEXTVAL = 57939 +const SETVAL = 57940 +const CURRVAL = 57941 +const LASTVAL = 57942 +const ARROW = 57943 +const ROW = 57944 +const OUTFILE = 57945 +const HEADER = 57946 +const MAX_FILE_SIZE = 57947 +const FORCE_QUOTE = 57948 +const PARALLEL = 57949 +const STRICT = 57950 +const UNUSED = 57951 +const BINDINGS = 57952 +const DO = 57953 +const DECLARE = 57954 +const LOOP = 57955 +const WHILE = 57956 +const LEAVE = 57957 +const ITERATE = 57958 +const UNTIL = 57959 +const CALL = 57960 +const PREV = 57961 +const SLIDING = 57962 +const FILL = 57963 +const SPBEGIN = 57964 +const BACKEND = 57965 +const SERVERS = 57966 +const HANDLER = 57967 +const PERCENT = 57968 +const SAMPLE = 57969 +const MO_TS = 57970 +const PITR = 57971 +const RECOVERY_WINDOW = 57972 +const INTERNAL = 57973 +const CDC = 57974 +const GROUPING = 57975 +const SETS = 57976 +const CUBE = 57977 +const ROLLUP = 57978 +const LOGSERVICE = 57979 +const REPLICAS = 57980 +const STORES = 57981 +const SETTINGS = 57982 +const KILL = 57983 +const BACKUP = 57984 +const FILESYSTEM = 57985 +const PARALLELISM = 57986 +const RESTORE = 57987 +const QUERY_RESULT = 57988 var yyToknames = [...]string{ "$end", @@ -1026,6 +1027,7 @@ var yyToknames = [...]string{ "EF_CONSTRUCTION", "M", "QUANTIZATION", + "ASYNC", "EXPIRE", "ACCOUNT", "ACCOUNTS", @@ -1338,7 +1340,7 @@ const yyEofCode = 1 const yyErrCode = 2 const yyInitialStackSize = 16 -//line mysql_sql.y:13036 +//line mysql_sql.y:13045 //line yacctab:1 var yyExca = [...]int{ @@ -1350,5992 +1352,6018 @@ var yyExca = [...]int{ 22, 814, -2, 807, -1, 167, - 246, 1256, + 246, 1257, 248, 1144, - -2, 1200, + -2, 1201, -1, 194, 44, 637, 248, 637, 275, 644, 276, 644, - 480, 637, + 481, 637, -2, 672, -1, 234, - 666, 2033, + 667, 2035, -2, 536, - -1, 548, - 666, 2157, + -1, 549, + 667, 2159, -2, 413, - -1, 606, - 666, 2216, - -2, 411, -1, 607, - 666, 2217, - -2, 412, + 667, 2218, + -2, 411, -1, 608, - 666, 2218, + 667, 2219, + -2, 412, + -1, 609, + 667, 2220, -2, 414, - -1, 749, + -1, 750, 327, 181, - 452, 181, 453, 181, - -2, 1930, - -1, 816, - 86, 1715, - -2, 2093, + 454, 181, + -2, 1932, -1, 817, - 86, 1734, - -2, 2064, - -1, 821, + 86, 1716, + -2, 2095, + -1, 818, 86, 1735, - -2, 2092, - -1, 855, - 86, 1642, - -2, 2297, + -2, 2066, + -1, 822, + 86, 1736, + -2, 2094, -1, 856, 86, 1643, - -2, 2296, + -2, 2299, -1, 857, 86, 1644, - -2, 2286, + -2, 2298, -1, 858, - 86, 2258, - -2, 2279, + 86, 1645, + -2, 2288, -1, 859, - 86, 2259, - -2, 2280, - -1, 860, 86, 2260, - -2, 2288, - -1, 861, + -2, 2281, + -1, 860, 86, 2261, - -2, 2268, - -1, 862, + -2, 2282, + -1, 861, 86, 2262, - -2, 2277, - -1, 863, + -2, 2290, + -1, 862, 86, 2263, - -2, 2289, - -1, 864, + -2, 2270, + -1, 863, 86, 2264, - -2, 2290, - -1, 865, + -2, 2279, + -1, 864, 86, 2265, - -2, 2295, - -1, 866, + -2, 2291, + -1, 865, 86, 2266, - -2, 2300, - -1, 867, + -2, 2292, + -1, 866, 86, 2267, - -2, 2301, + -2, 2297, + -1, 867, + 86, 2268, + -2, 2302, -1, 868, - 86, 1711, - -2, 2131, + 86, 2269, + -2, 2303, -1, 869, 86, 1712, - -2, 1914, + -2, 2133, -1, 870, 86, 1713, - -2, 2140, + -2, 1916, -1, 871, 86, 1714, - -2, 1923, - -1, 873, - 86, 1717, - -2, 1931, - -1, 875, - 86, 1719, - -2, 2164, - -1, 877, - 86, 1722, - -2, 1952, - -1, 879, - 86, 1724, - -2, 2176, + -2, 2142, + -1, 872, + 86, 1715, + -2, 1925, + -1, 874, + 86, 1718, + -2, 1933, + -1, 876, + 86, 1720, + -2, 2166, + -1, 878, + 86, 1723, + -2, 1954, -1, 880, 86, 1725, - -2, 2175, + -2, 2178, -1, 881, 86, 1726, - -2, 1999, + -2, 2177, -1, 882, 86, 1727, - -2, 2088, - -1, 885, - 86, 1730, - -2, 2187, - -1, 887, - 86, 1732, - -2, 2190, + -2, 2001, + -1, 883, + 86, 1728, + -2, 2090, + -1, 886, + 86, 1731, + -2, 2189, -1, 888, 86, 1733, -2, 2192, -1, 889, - 86, 1736, - -2, 2200, + 86, 1734, + -2, 2194, -1, 890, 86, 1737, - -2, 2073, + -2, 2202, -1, 891, 86, 1738, - -2, 2118, + -2, 2075, -1, 892, 86, 1739, - -2, 2083, + -2, 2120, -1, 893, 86, 1740, - -2, 2108, - -1, 904, - 86, 1620, - -2, 2291, + -2, 2085, + -1, 894, + 86, 1741, + -2, 2110, -1, 905, 86, 1621, - -2, 2292, + -2, 2293, -1, 906, 86, 1622, - -2, 2293, - -1, 1010, - 475, 672, + -2, 2294, + -1, 907, + 86, 1623, + -2, 2295, + -1, 1011, 476, 672, + 477, 672, -2, 638, - -1, 1061, - 128, 1914, - 139, 1914, - 159, 1914, - -2, 1888, - -1, 1182, + -1, 1062, + 128, 1916, + 139, 1916, + 159, 1916, + -2, 1889, + -1, 1183, 22, 841, -2, 790, - -1, 1292, + -1, 1293, 11, 814, 22, 814, - -2, 1497, - -1, 1376, + -2, 1498, + -1, 1377, 22, 841, -2, 790, - -1, 1736, - 86, 1787, - -2, 2090, -1, 1737, 86, 1788, - -2, 2091, - -1, 2344, + -2, 2092, + -1, 1738, + 86, 1789, + -2, 2093, + -1, 2345, 87, 1014, -2, 1020, - -1, 2360, - 111, 1192, - 155, 1192, - 195, 1192, - 198, 1192, - 288, 1192, - -2, 1185, - -1, 2525, + -1, 2361, + 111, 1193, + 155, 1193, + 195, 1193, + 198, 1193, + 288, 1193, + -2, 1186, + -1, 2526, 11, 814, 22, 814, -2, 955, - -1, 2559, - 87, 1874, - 160, 1874, - -2, 2075, -1, 2560, - 87, 1874, - 160, 1874, - -2, 2074, + 87, 1875, + 160, 1875, + -2, 2077, -1, 2561, - 87, 1850, - 160, 1850, - -2, 2061, + 87, 1875, + 160, 1875, + -2, 2076, -1, 2562, 87, 1851, 160, 1851, - -2, 2066, + -2, 2063, -1, 2563, 87, 1852, 160, 1852, - -2, 1987, + -2, 2068, -1, 2564, 87, 1853, 160, 1853, - -2, 1980, + -2, 1989, -1, 2565, 87, 1854, 160, 1854, - -2, 1904, + -2, 1982, -1, 2566, 87, 1855, 160, 1855, - -2, 2063, + -2, 1906, -1, 2567, 87, 1856, 160, 1856, - -2, 1985, + -2, 2065, -1, 2568, 87, 1857, 160, 1857, - -2, 1979, + -2, 1987, -1, 2569, 87, 1858, 160, 1858, - -2, 1967, + -2, 1981, -1, 2570, - 87, 1874, - 160, 1874, - -2, 1968, - -1, 2571, - 87, 1874, - 160, 1874, + 87, 1859, + 160, 1859, -2, 1969, - -1, 2573, - 87, 1863, - 160, 1863, - -2, 2108, + -1, 2571, + 87, 1875, + 160, 1875, + -2, 1970, + -1, 2572, + 87, 1875, + 160, 1875, + -2, 1971, -1, 2574, - 87, 1840, - 160, 1840, - -2, 2093, + 87, 1864, + 160, 1864, + -2, 2110, -1, 2575, - 87, 1872, - 160, 1872, - -2, 2064, + 87, 1841, + 160, 1841, + -2, 2095, -1, 2576, - 87, 1872, - 160, 1872, - -2, 2092, + 87, 1873, + 160, 1873, + -2, 2066, -1, 2577, - 87, 1872, - 160, 1872, - -2, 1932, + 87, 1873, + 160, 1873, + -2, 2094, -1, 2578, - 87, 1870, - 160, 1870, - -2, 2083, + 87, 1873, + 160, 1873, + -2, 1934, -1, 2579, - 87, 1867, - 160, 1867, - -2, 1957, + 87, 1871, + 160, 1871, + -2, 2085, -1, 2580, - 86, 1821, - 87, 1821, - 160, 1821, - 410, 1821, - 411, 1821, - 412, 1821, - -2, 1903, + 87, 1868, + 160, 1868, + -2, 1959, -1, 2581, 86, 1822, 87, 1822, 160, 1822, - 410, 1822, 411, 1822, 412, 1822, + 413, 1822, -2, 1905, -1, 2582, 86, 1823, 87, 1823, 160, 1823, - 410, 1823, 411, 1823, 412, 1823, - -2, 2136, + 413, 1823, + -2, 1907, -1, 2583, - 86, 1825, - 87, 1825, - 160, 1825, - 410, 1825, - 411, 1825, - 412, 1825, - -2, 2065, + 86, 1824, + 87, 1824, + 160, 1824, + 411, 1824, + 412, 1824, + 413, 1824, + -2, 2138, -1, 2584, - 86, 1827, - 87, 1827, - 160, 1827, - 410, 1827, - 411, 1827, - 412, 1827, - -2, 2043, + 86, 1826, + 87, 1826, + 160, 1826, + 411, 1826, + 412, 1826, + 413, 1826, + -2, 2067, -1, 2585, - 86, 1829, - 87, 1829, - 160, 1829, - 410, 1829, - 411, 1829, - 412, 1829, - -2, 1986, + 86, 1828, + 87, 1828, + 160, 1828, + 411, 1828, + 412, 1828, + 413, 1828, + -2, 2045, -1, 2586, - 86, 1831, - 87, 1831, - 160, 1831, - 410, 1831, - 411, 1831, - 412, 1831, - -2, 1963, + 86, 1830, + 87, 1830, + 160, 1830, + 411, 1830, + 412, 1830, + 413, 1830, + -2, 1988, -1, 2587, 86, 1832, 87, 1832, 160, 1832, - 410, 1832, 411, 1832, 412, 1832, - -2, 1964, + 413, 1832, + -2, 1965, -1, 2588, - 86, 1834, - 87, 1834, - 160, 1834, - 410, 1834, - 411, 1834, - 412, 1834, - -2, 1902, + 86, 1833, + 87, 1833, + 160, 1833, + 411, 1833, + 412, 1833, + 413, 1833, + -2, 1966, -1, 2589, - 87, 1877, - 160, 1877, - 410, 1877, - 411, 1877, - 412, 1877, - -2, 1937, + 86, 1835, + 87, 1835, + 160, 1835, + 411, 1835, + 412, 1835, + 413, 1835, + -2, 1904, -1, 2590, - 87, 1877, - 160, 1877, - 410, 1877, - 411, 1877, - 412, 1877, - -2, 1953, + 87, 1878, + 160, 1878, + 411, 1878, + 412, 1878, + 413, 1878, + -2, 1939, -1, 2591, - 87, 1880, - 160, 1880, - 410, 1880, - 411, 1880, - 412, 1880, - -2, 1933, + 87, 1878, + 160, 1878, + 411, 1878, + 412, 1878, + 413, 1878, + -2, 1955, -1, 2592, - 87, 1880, - 160, 1880, - 410, 1880, - 411, 1880, - 412, 1880, - -2, 2002, + 87, 1881, + 160, 1881, + 411, 1881, + 412, 1881, + 413, 1881, + -2, 1935, -1, 2593, - 87, 1877, - 160, 1877, - 410, 1877, - 411, 1877, - 412, 1877, - -2, 2025, - -1, 2821, - 111, 1192, - 155, 1192, - 195, 1192, - 198, 1192, - 288, 1192, - -2, 1186, - -1, 2841, + 87, 1881, + 160, 1881, + 411, 1881, + 412, 1881, + 413, 1881, + -2, 2004, + -1, 2594, + 87, 1878, + 160, 1878, + 411, 1878, + 412, 1878, + 413, 1878, + -2, 2027, + -1, 2822, + 111, 1193, + 155, 1193, + 195, 1193, + 198, 1193, + 288, 1193, + -2, 1187, + -1, 2842, 84, 734, 160, 734, - -2, 1371, - -1, 3274, - 198, 1192, - 312, 1460, - -2, 1432, - -1, 3468, - 111, 1192, - 155, 1192, - 195, 1192, - 198, 1192, - -2, 1312, - -1, 3471, - 111, 1192, - 155, 1192, - 195, 1192, - 198, 1192, - -2, 1312, - -1, 3483, - 84, 734, - 160, 734, - -2, 1371, - -1, 3504, - 198, 1192, - 312, 1460, + -2, 1372, + -1, 3275, + 198, 1193, + 312, 1461, -2, 1433, - -1, 3661, - 111, 1192, - 155, 1192, - 195, 1192, - 198, 1192, + -1, 3469, + 111, 1193, + 155, 1193, + 195, 1193, + 198, 1193, + -2, 1313, + -1, 3472, + 111, 1193, + 155, 1193, + 195, 1193, + 198, 1193, -2, 1313, - -1, 3688, - 87, 1274, - 160, 1274, - -2, 1192, - -1, 3838, - 87, 1274, - 160, 1274, - -2, 1192, - -1, 4010, - 87, 1278, - 160, 1278, - -2, 1192, - -1, 4066, + -1, 3484, + 84, 734, + 160, 734, + -2, 1372, + -1, 3505, + 198, 1193, + 312, 1461, + -2, 1434, + -1, 3662, + 111, 1193, + 155, 1193, + 195, 1193, + 198, 1193, + -2, 1314, + -1, 3689, + 87, 1275, + 160, 1275, + -2, 1193, + -1, 3839, + 87, 1275, + 160, 1275, + -2, 1193, + -1, 4012, 87, 1279, 160, 1279, - -2, 1192, + -2, 1193, + -1, 4068, + 87, 1280, + 160, 1280, + -2, 1193, } const yyPrivate = 57344 -const yyLast = 55180 +const yyLast = 55438 var yyAct = [...]int{ - 783, 759, 4120, 785, 4088, 2872, 223, 4112, 1637, 2000, - 4014, 1716, 3489, 3588, 4020, 3294, 3907, 4021, 4013, 3838, - 3260, 2596, 3930, 768, 3965, 3885, 3370, 3716, 1549, 3518, - 3816, 2866, 3781, 3876, 3837, 3371, 1328, 1712, 3908, 3648, - 1776, 2778, 3750, 813, 2869, 37, 649, 1183, 3592, 3806, - 761, 3449, 1060, 3886, 3888, 3583, 1487, 1945, 3454, 1763, - 2411, 3505, 1481, 667, 1177, 673, 673, 3269, 3669, 2844, - 3658, 673, 691, 700, 3230, 1719, 700, 3215, 3472, 3630, - 3368, 2985, 3191, 2984, 3663, 757, 2986, 3218, 2098, 3441, - 2111, 2962, 2895, 208, 3289, 3271, 3278, 2981, 2783, 3474, - 2134, 3413, 1781, 2685, 2208, 2095, 1778, 3054, 2555, 712, - 2414, 3014, 3333, 1960, 2809, 2557, 3198, 697, 2972, 2519, - 3196, 3194, 3193, 2060, 3240, 2372, 1542, 708, 1173, 3189, - 2650, 2822, 141, 1638, 3192, 3162, 756, 3277, 2192, 751, - 2166, 2444, 36, 2322, 1615, 2321, 2628, 2204, 3028, 2175, - 1874, 2610, 2174, 941, 2139, 1622, 1630, 1626, 3102, 2167, - 68, 2091, 2203, 2520, 1627, 2064, 2503, 2798, 2897, 2793, - 981, 2498, 2877, 2412, 1990, 2836, 2371, 2553, 219, 8, - 218, 7, 1710, 6, 2360, 1121, 1777, 2205, 1452, 1589, - 1446, 1413, 2061, 1921, 760, 1659, 1558, 1527, 666, 649, - 2407, 1521, 2351, 1054, 2722, 750, 1750, 769, 1701, 2354, - 1770, 15, 2238, 1490, 1199, 1470, 2173, 1641, 2170, 2155, - 758, 1917, 1596, 223, 705, 223, 1709, 1112, 1113, 1053, - 1526, 2527, 1920, 1959, 673, 2499, 682, 980, 1482, 1580, - 1523, 714, 1466, 1782, 1092, 27, 908, 1019, 24, 648, - 209, 699, 978, 16, 1491, 1005, 715, 1456, 1715, 957, - 963, 1329, 33, 711, 1374, 25, 17, 10, 201, 910, - 3895, 2212, 14, 752, 205, 1398, 3802, 2721, 911, 23, - 2758, 669, 2758, 695, 1260, 1261, 1262, 1259, 1260, 1261, - 1262, 1259, 2758, 2529, 1109, 989, 1260, 1261, 1262, 1259, - 3486, 685, 3379, 3247, 3071, 3070, 2222, 1178, 3619, 3457, - 1179, 3363, 2673, 2616, 2614, 1887, 1108, 696, 1110, 2613, - 2611, 1603, 1599, 1104, 1105, 692, 207, 703, 971, 668, - 972, 2320, 1525, 1393, 693, 1066, 930, 678, 1449, 1450, - 1451, 3863, 928, 1367, 694, 1068, 2597, 674, 2326, 1105, - 1888, 1105, 3172, 2330, 1039, 1396, 1652, 3155, 3157, 3152, - 3154, 4100, 1504, 1069, 1881, 1389, 1178, 985, 986, 952, - 752, 1601, 1260, 1261, 1262, 1259, 3581, 3050, 1029, 1260, - 1261, 1262, 1259, 966, 3048, 962, 8, 2144, 7, 3871, - 3757, 1103, 3751, 3584, 3369, 2189, 1323, 3890, 2169, 909, - 3131, 2161, 206, 64, 197, 168, 2452, 4126, 3884, 2750, - 2748, 920, 4097, 3765, 1258, 3598, 3823, 1404, 4049, 3631, - 3473, 1222, 206, 206, 206, 64, 197, 168, 3992, 1087, - 2659, 2363, 1636, 3635, 2667, 2209, 3882, 929, 3789, 3763, - 3432, 944, 1645, 927, 2703, 3941, 1566, 930, 1403, 206, - 206, 206, 1402, 2752, 1399, 2362, 206, 64, 197, 168, - 3824, 1401, 1031, 928, 1070, 1030, 3129, 1438, 710, 1657, - 206, 1064, 1642, 2220, 2829, 202, 206, 2979, 1405, 2355, - 1065, 206, 206, 64, 197, 168, 2547, 1257, 1890, 1194, - 1650, 206, 64, 197, 168, 202, 1644, 202, 140, 1654, - 2548, 1088, 1034, 1032, 1015, 1033, 1953, 3021, 206, 64, - 197, 168, 1649, 990, 3022, 3023, 968, 2108, 961, 3074, - 921, 1668, 202, 1656, 2827, 3062, 925, 965, 964, 202, - 140, 899, 2074, 898, 900, 901, 2777, 902, 903, 3156, - 992, 3153, 1237, 202, 2534, 1238, 3264, 2533, 953, 202, - 2535, 1421, 2075, 2076, 202, 202, 1191, 1899, 1900, 854, - 3791, 1682, 2629, 1528, 202, 1530, 1028, 2773, 960, 1478, - 1488, 1489, 2795, 1240, 2830, 1419, 1082, 1077, 1072, 1076, - 1080, 202, 2796, 1974, 1718, 1702, 2309, 970, 1706, 1255, - 3893, 3989, 959, 3262, 1040, 1500, 958, 1063, 1501, 1062, - 1250, 3892, 946, 3891, 1085, 4048, 1014, 1012, 1075, 951, - 3874, 2775, 1705, 4024, 4025, 3608, 1602, 1600, 3985, 3893, - 3979, 1036, 1486, 3892, 3978, 1951, 1485, 1488, 1489, 3967, - 1197, 2794, 3055, 1011, 3891, 3977, 949, 3372, 4092, 4093, - 3970, 3967, 2770, 3754, 3056, 984, 3057, 1816, 2654, 3877, - 3878, 3879, 3880, 3372, 1188, 2774, 991, 1024, 2224, 1083, - 2092, 1235, 3904, 2753, 3386, 1722, 2917, 2086, 2082, 1086, - 1697, 673, 673, 2801, 969, 3994, 3995, 1202, 1205, 3442, - 1020, 2216, 673, 1187, 3447, 1038, 2771, 1503, 3211, 3990, - 3991, 1420, 3998, 3997, 3996, 3999, 1073, 3640, 2973, 2152, - 950, 3092, 700, 700, 1707, 673, 167, 195, 204, 196, - 1242, 2486, 969, 1243, 2350, 2493, 1021, 1025, 1609, 1608, - 1084, 2780, 3530, 746, 3987, 1236, 748, 2664, 1704, 194, - 3090, 747, 697, 697, 697, 2221, 1008, 3209, 1006, 1010, - 1028, 1245, 1253, 1254, 1007, 1004, 1003, 1252, 1009, 994, - 995, 993, 996, 997, 998, 999, 1514, 1026, 193, 1027, - 1074, 3607, 1037, 1115, 1392, 2450, 1952, 1225, 1300, 3609, - 1022, 1023, 2832, 1476, 3582, 3894, 4023, 967, 2106, 2107, - 3049, 3801, 3793, 3794, 2751, 3389, 2967, 3096, 2488, 1186, - 1721, 1720, 3205, 3206, 3207, 3798, 2776, 2757, 1202, 1205, - 2489, 2490, 1239, 1180, 2550, 1179, 3664, 1018, 1179, 3208, - 3744, 3216, 1179, 1017, 3637, 1187, 956, 2210, 3654, 1217, - 1248, 1249, 1066, 2327, 3417, 1889, 2210, 2772, 1013, 1241, - 923, 2210, 1068, 3599, 4057, 3072, 1196, 1081, 2496, 3069, - 698, 1247, 665, 3545, 1422, 1703, 3266, 2243, 2211, 1105, - 1069, 1105, 1105, 1230, 3228, 1502, 1232, 1105, 1193, 3241, - 1105, 1105, 698, 3923, 3292, 1332, 3293, 3542, 1246, 3918, - 3822, 1179, 2837, 1078, 924, 702, 1079, 3828, 2223, 1728, - 1731, 1732, 1204, 1203, 1233, 2612, 3290, 3291, 3993, 3820, - 1729, 701, 1604, 1244, 698, 1066, 1294, 2977, 695, 695, - 695, 1035, 65, 2362, 2357, 1068, 1016, 3745, 3203, 3535, - 3163, 3909, 987, 988, 3925, 982, 945, 3764, 3490, 943, - 983, 1333, 3931, 1069, 65, 1395, 3261, 1397, 909, 698, - 3217, 2871, 696, 696, 696, 1488, 1489, 3497, 3428, 1409, - 692, 692, 692, 1412, 1182, 169, 698, 1418, 1181, 693, - 693, 693, 1175, 1210, 1211, 1372, 65, 1065, 1377, 694, - 694, 694, 1465, 1214, 1651, 169, 169, 169, 3636, 2668, - 1206, 1400, 1226, 1216, 3787, 3296, 1089, 1891, 1301, 1071, - 981, 2749, 1488, 1489, 1296, 1297, 1298, 1299, 1190, 1192, - 1195, 65, 169, 169, 169, 2341, 3625, 2800, 1228, 169, - 3425, 3792, 3179, 1204, 1203, 1477, 3427, 2093, 65, 3217, - 1231, 1234, 3212, 169, 2484, 926, 2430, 1692, 203, 169, - 1693, 2974, 2410, 2433, 169, 169, 3093, 3546, 4132, 3903, - 2227, 2229, 2230, 3707, 169, 673, 1227, 2417, 1516, 2492, - 3829, 2462, 673, 3986, 2461, 3595, 649, 649, 971, 1208, - 972, 169, 3821, 3696, 2804, 2805, 649, 649, 2550, 2807, - 1553, 1553, 2918, 673, 2919, 2920, 3773, 1484, 3774, 2803, - 2482, 2483, 2085, 2083, 3773, 1698, 3774, 3702, 3641, 3267, - 2432, 1538, 4115, 1537, 700, 1581, 667, 1344, 1345, 1555, - 1215, 1592, 3768, 1480, 1479, 1463, 2908, 1551, 1551, 1462, - 3932, 1461, 2216, 2909, 2910, 2911, 223, 3795, 2867, 2868, - 3807, 2871, 1560, 1229, 3842, 649, 4012, 3270, 1174, 3204, - 3151, 2453, 3776, 3475, 2410, 2427, 2693, 2431, 1730, 1291, - 3776, 3579, 3016, 3018, 1414, 710, 1415, 1416, 3375, 3964, - 1524, 1425, 1426, 1427, 1428, 1429, 1222, 1431, 2763, 3469, - 3462, 1515, 3286, 1437, 3775, 1165, 1161, 1162, 1163, 1164, - 935, 2698, 3775, 2697, 2696, 2694, 3167, 1634, 3290, 3291, - 3295, 2660, 1639, 3435, 1455, 1376, 2539, 2448, 2416, 1648, - 2213, 2081, 1464, 2418, 1547, 1548, 1378, 2058, 1411, 1474, - 2813, 2817, 2818, 2819, 2814, 2816, 2815, 1493, 1494, 1430, - 1496, 1497, 1029, 1498, 3324, 3033, 3034, 2420, 1680, 1424, - 1029, 939, 3095, 1683, 1472, 1473, 937, 936, 3287, 1643, - 2361, 1436, 1553, 4116, 1553, 1187, 1655, 1435, 1893, 1658, - 1434, 1433, 1445, 2695, 1041, 704, 1221, 2419, 2239, 697, - 1423, 3414, 697, 697, 3709, 1458, 3225, 3841, 973, 1532, - 1534, 1467, 1471, 1471, 1471, 1691, 2225, 2226, 1448, 1545, - 1546, 2915, 2644, 1492, 1505, 1506, 1495, 1613, 1443, 1616, - 1617, 975, 976, 977, 3104, 3103, 1467, 1467, 1610, 2228, - 2767, 1618, 1619, 2334, 1582, 2342, 1031, 2336, 2335, 1030, - 1408, 1902, 1553, 938, 1031, 3617, 1903, 1030, 4011, 1624, - 1625, 942, 2946, 3169, 1647, 1536, 3017, 970, 3698, 1187, - 1780, 2333, 3697, 1675, 1676, 1901, 3703, 3704, 1605, 1406, - 1407, 1632, 1811, 1812, 1829, 1815, 931, 1629, 2474, 1764, - 1633, 1717, 932, 1830, 1069, 1579, 1593, 1573, 678, 2426, - 1561, 1069, 2421, 2424, 3670, 1184, 1837, 1567, 1839, 4134, - 1840, 1841, 1842, 3974, 2937, 2938, 1594, 4113, 4114, 1738, + 784, 760, 4122, 786, 4090, 4114, 223, 2873, 4016, 2001, + 1717, 3589, 1638, 4022, 3490, 4023, 3908, 3839, 4015, 3931, + 3261, 3886, 3295, 769, 3966, 3717, 3371, 3519, 3817, 2867, + 3782, 3877, 3909, 3372, 1329, 762, 2597, 3838, 3649, 1777, + 1482, 3751, 2779, 814, 1061, 2870, 650, 1184, 3807, 3450, + 3593, 3887, 1488, 1639, 3889, 3584, 1946, 3270, 3455, 2845, + 2412, 1764, 3670, 668, 3506, 674, 674, 3216, 1178, 3659, + 3231, 674, 692, 701, 1720, 3369, 701, 3631, 3473, 3664, + 2986, 3192, 2985, 2987, 2099, 3219, 1550, 3442, 1713, 208, + 2096, 2896, 2963, 3290, 2558, 3279, 3272, 3475, 2982, 2061, + 1779, 2135, 37, 2112, 2784, 3055, 2520, 3414, 2556, 2686, + 3015, 2167, 2209, 3334, 1782, 2810, 2415, 1961, 2973, 3199, + 2651, 3197, 2373, 3193, 3241, 3195, 1543, 709, 3194, 3278, + 2823, 1174, 2323, 757, 3190, 2322, 3163, 2193, 713, 752, + 3103, 1623, 1616, 2205, 2629, 2176, 141, 3029, 36, 1875, + 1627, 2175, 2168, 942, 2611, 1628, 2092, 2140, 1631, 2204, + 2521, 2065, 2504, 1447, 2062, 2898, 2799, 2499, 68, 2794, + 982, 2878, 1991, 2413, 698, 6, 2837, 2372, 219, 8, + 218, 7, 2361, 1922, 2239, 1122, 2554, 1453, 1778, 2206, + 1711, 1590, 1528, 753, 761, 1457, 1559, 1522, 2352, 650, + 1960, 1716, 751, 667, 2723, 1471, 2408, 1771, 1751, 2355, + 1702, 759, 1660, 1200, 2174, 1642, 2171, 2156, 1597, 706, + 1054, 2528, 1918, 223, 1710, 223, 770, 1113, 1114, 1527, + 1921, 2500, 683, 1492, 674, 1581, 1467, 981, 715, 1020, + 1524, 716, 24, 1783, 25, 27, 17, 10, 909, 1093, + 700, 1483, 209, 16, 958, 1006, 1399, 964, 979, 712, + 201, 1330, 2213, 2530, 1375, 205, 911, 912, 1491, 990, + 23, 1261, 1262, 1263, 1260, 3896, 14, 3803, 670, 2759, + 2759, 2759, 2445, 1110, 3380, 15, 3072, 2722, 3487, 3248, + 753, 1414, 1261, 1262, 1263, 1260, 1261, 1262, 1263, 1260, + 33, 3071, 2223, 1179, 972, 3620, 973, 1088, 3458, 1180, + 2674, 686, 1109, 3364, 1111, 2617, 2614, 697, 2615, 1888, + 1604, 1600, 1055, 2612, 1105, 693, 704, 1106, 207, 679, + 669, 2321, 1394, 1526, 3864, 758, 1179, 1368, 1450, 1451, + 1452, 986, 987, 931, 675, 953, 1106, 929, 695, 1067, + 1106, 1069, 1030, 2598, 1653, 2327, 1889, 696, 1040, 967, + 3173, 963, 2331, 1397, 3156, 3158, 3153, 3155, 649, 4102, + 1505, 1070, 694, 1882, 1390, 3582, 1602, 3051, 3049, 1089, + 2145, 3872, 3758, 1104, 2751, 2749, 8, 3752, 7, 1261, + 1262, 1263, 1260, 1261, 1262, 1263, 1260, 3585, 3370, 2190, + 3891, 2170, 910, 1324, 3132, 2162, 2453, 4128, 206, 64, + 197, 168, 3885, 921, 4099, 3824, 206, 945, 3766, 3636, + 4051, 1259, 3599, 1223, 206, 206, 3632, 2660, 2753, 2210, + 1405, 3474, 2364, 3993, 1637, 1646, 1032, 3883, 206, 1031, + 206, 3790, 2363, 1658, 930, 3764, 3433, 2668, 928, 2704, + 206, 64, 197, 168, 1083, 1078, 1073, 1077, 1081, 3825, + 3942, 2830, 1400, 206, 1567, 1643, 1404, 1403, 1065, 1066, + 206, 1402, 931, 1655, 3075, 929, 1071, 1422, 1016, 711, + 1439, 202, 1086, 3130, 2980, 2221, 1076, 991, 1651, 1645, + 1238, 1406, 969, 1239, 962, 2778, 2774, 1657, 202, 2356, + 2548, 1420, 1891, 966, 965, 1258, 1035, 1033, 2549, 1034, + 1650, 2828, 3063, 202, 993, 206, 64, 197, 168, 140, + 3022, 1241, 922, 202, 954, 926, 3023, 3024, 2076, 2077, + 3792, 2075, 206, 64, 197, 168, 202, 1084, 1501, 2535, + 1954, 1502, 2534, 202, 961, 2536, 3157, 1087, 3154, 1900, + 1901, 206, 206, 64, 197, 168, 1529, 2630, 1531, 1479, + 1029, 2831, 3609, 971, 206, 64, 197, 168, 960, 2796, + 2776, 2771, 959, 2109, 1975, 1074, 1489, 1490, 947, 2797, + 1015, 1013, 1719, 1251, 1256, 952, 4026, 4027, 202, 1064, + 3894, 3980, 855, 1063, 1683, 3894, 3990, 1195, 1041, 1085, + 140, 3893, 3979, 3986, 3893, 202, 3892, 3978, 1012, 3892, + 1236, 2310, 4050, 950, 3875, 2775, 2772, 1669, 1421, 3373, + 985, 1603, 1601, 3968, 202, 202, 1037, 3056, 2795, 1192, + 1504, 992, 1025, 3265, 3968, 3263, 1198, 202, 2754, 1075, + 4094, 4095, 900, 2655, 899, 901, 902, 1817, 903, 904, + 3057, 970, 3058, 3373, 1231, 1021, 1189, 1233, 1487, 3971, + 1952, 3755, 1486, 1489, 1490, 2225, 3878, 3879, 3880, 3881, + 1723, 2918, 674, 674, 1237, 3905, 3387, 951, 2083, 2093, + 3995, 3996, 3448, 674, 1188, 1234, 3443, 2217, 1698, 2974, + 1039, 1022, 1026, 2494, 3991, 3992, 2802, 3999, 3998, 3997, + 4000, 4001, 3093, 701, 701, 3212, 674, 1203, 1206, 3608, + 2487, 1009, 2351, 1007, 1011, 1029, 1082, 3610, 3641, 1008, + 1005, 1004, 2153, 1010, 995, 996, 994, 997, 998, 999, + 1000, 970, 1027, 2781, 1028, 1610, 1609, 1254, 1255, 167, + 195, 204, 196, 1116, 3531, 1023, 1024, 710, 2222, 3988, + 4025, 1240, 1079, 3091, 968, 1080, 2777, 2773, 3210, 2833, + 2752, 1253, 194, 1477, 1393, 3794, 3795, 1038, 1515, 1301, + 2665, 1423, 193, 2451, 1227, 1226, 3583, 3050, 2968, 1203, + 1206, 3895, 1019, 3802, 1187, 3390, 3097, 2758, 1018, 3206, + 698, 698, 698, 957, 1180, 1180, 1722, 1721, 3217, 1503, + 1229, 1953, 2489, 1014, 1249, 1250, 3665, 1181, 3799, 1180, + 2490, 2491, 1232, 1235, 3207, 3208, 1188, 1295, 3745, 3655, + 2211, 2087, 1803, 3073, 2211, 3638, 2211, 3418, 2551, 924, + 3209, 2328, 1890, 2497, 1248, 2107, 2108, 1067, 1228, 1069, + 2212, 3600, 1180, 1197, 3070, 666, 3546, 699, 2244, 1218, + 3267, 1333, 1106, 3543, 1106, 1090, 4059, 1106, 1072, 1070, + 1106, 1106, 3293, 1106, 3294, 2228, 2230, 2231, 3291, 3292, + 3823, 3229, 3242, 1703, 925, 2224, 1707, 747, 3829, 3924, + 749, 1017, 3821, 703, 3919, 748, 702, 988, 989, 699, + 983, 2838, 2978, 946, 3994, 984, 944, 2358, 3536, 3164, + 1706, 2363, 3746, 2613, 3910, 3204, 1036, 1605, 3926, 65, + 1067, 3491, 1069, 1205, 1204, 1230, 1334, 3932, 3218, 3262, + 1729, 1732, 1733, 2872, 3765, 3498, 1396, 3429, 1398, 2342, + 2909, 1730, 1070, 697, 697, 697, 910, 2910, 2911, 2912, + 1410, 693, 693, 693, 1413, 1183, 1182, 1066, 1419, 1215, + 1176, 65, 169, 1211, 1212, 3637, 1373, 2750, 2418, 1378, + 169, 1466, 1207, 1652, 695, 695, 695, 1194, 169, 169, + 1217, 699, 3793, 696, 696, 696, 1297, 1298, 1299, 1300, + 1401, 982, 169, 2669, 169, 1205, 1204, 3547, 694, 694, + 694, 699, 1892, 1708, 169, 3428, 1478, 1799, 1302, 1191, + 1193, 1196, 3788, 699, 1796, 3626, 3426, 169, 1798, 1795, + 1797, 1801, 1802, 2975, 169, 927, 1800, 1705, 2493, 3904, + 972, 2801, 973, 1489, 1490, 1489, 1490, 2094, 3094, 3987, + 3213, 3180, 1243, 65, 3218, 1244, 674, 2868, 2869, 1517, + 2872, 3830, 3774, 674, 3775, 3822, 1485, 650, 650, 2485, + 3708, 1693, 203, 65, 1694, 3297, 2463, 650, 650, 169, + 3769, 1554, 1554, 1246, 674, 65, 4134, 2462, 2919, 4117, + 2920, 2921, 3596, 2551, 1209, 3703, 169, 2808, 2805, 2806, + 1539, 2217, 3697, 3268, 2084, 701, 1582, 668, 1345, 1346, + 1464, 3796, 1593, 2804, 1699, 169, 169, 1463, 3777, 2417, + 3642, 2483, 2484, 1538, 2419, 1216, 2694, 223, 169, 1481, + 1480, 1462, 3933, 1561, 2229, 1030, 650, 3205, 3718, 3719, + 3720, 3724, 3722, 3723, 3725, 3721, 3808, 4014, 3843, 3271, + 3776, 1175, 3152, 2454, 1704, 1166, 1162, 1163, 1164, 1165, + 2431, 2699, 3476, 2698, 2697, 2695, 2411, 2434, 1556, 1552, + 1552, 2411, 1242, 1292, 3291, 3292, 1516, 3376, 2420, 3226, + 1806, 1807, 1808, 1809, 1810, 1811, 1804, 1805, 1635, 1731, + 2428, 3580, 1415, 1640, 1456, 711, 1377, 3965, 1379, 1525, + 1649, 3470, 1465, 1223, 1459, 1548, 1549, 1431, 3463, 1475, + 2764, 1247, 3017, 3019, 3287, 3168, 2661, 1494, 1495, 1032, + 1497, 1498, 1031, 1499, 2433, 1473, 1474, 1425, 2540, 1681, + 4118, 2449, 1424, 2696, 1684, 3774, 1245, 3775, 2362, 2343, + 3034, 3035, 2913, 1554, 2214, 1554, 1188, 2086, 2082, 2059, + 1659, 1468, 1472, 1472, 1472, 1412, 2421, 1416, 1417, 1446, + 1449, 3325, 1426, 1427, 1428, 1429, 1430, 1894, 1432, 3096, + 3296, 2432, 1437, 1436, 1438, 1435, 1468, 1468, 1434, 1506, + 1507, 3842, 2240, 1042, 1493, 705, 1614, 1496, 1617, 1618, + 3436, 3777, 1611, 1222, 3288, 2226, 2227, 1644, 3710, 971, + 1619, 1620, 2916, 936, 1656, 3415, 1625, 1626, 974, 2947, + 1583, 1537, 3227, 1554, 976, 977, 978, 698, 1030, 2645, + 698, 698, 1444, 3776, 2768, 3105, 3104, 2335, 1648, 4013, + 1188, 1781, 1409, 1692, 3704, 3705, 2337, 2336, 1903, 1630, + 1904, 936, 1634, 943, 1633, 1830, 1718, 1812, 1813, 1568, + 1816, 679, 1562, 1574, 940, 1580, 1902, 3699, 1831, 938, + 937, 3698, 1594, 1070, 4115, 4116, 1407, 1408, 1676, 1677, + 1070, 1838, 3618, 1840, 3170, 1841, 1842, 1843, 2334, 1595, + 932, 2700, 2701, 3770, 2938, 2939, 3018, 3771, 1715, 1533, + 1535, 2422, 935, 1820, 1821, 1822, 2475, 938, 937, 1546, + 1547, 1765, 1032, 933, 2427, 1031, 1836, 3671, 2425, 1837, + 2518, 2278, 1188, 3377, 2277, 1458, 4130, 1458, 1893, 4124, + 1734, 1030, 1896, 3247, 1898, 4136, 1850, 1851, 1696, 4112, + 2843, 3975, 1905, 1907, 1873, 1908, 939, 1910, 1911, 2765, + 2354, 668, 1582, 4070, 1712, 1259, 1872, 1919, 1554, 1924, + 1925, 1815, 1927, 1517, 674, 3331, 1662, 2551, 1606, 674, + 697, 1680, 1554, 697, 697, 2448, 982, 3327, 693, 1947, + 1679, 693, 693, 1690, 2787, 1686, 1691, 1689, 1685, 1223, + 1709, 1876, 1554, 1667, 1688, 1714, 1670, 1259, 1517, 2219, + 1829, 695, 4125, 692, 695, 695, 1895, 2788, 2789, 2844, + 696, 3289, 4071, 696, 696, 1032, 1043, 1687, 1031, 1185, + 2632, 2937, 1884, 1974, 4037, 694, 4071, 3439, 694, 694, + 1760, 1761, 1981, 1981, 1700, 1517, 1668, 1517, 1517, 1671, + 1672, 674, 674, 1753, 2048, 1919, 2052, 1220, 2519, 1554, + 2056, 2057, 4034, 4028, 4010, 2072, 3959, 650, 2814, 2818, + 2819, 2820, 2815, 2817, 2816, 3958, 3770, 2519, 2353, 3331, + 3888, 650, 3389, 1554, 2948, 2950, 2951, 2952, 2949, 1978, + 1928, 2315, 2253, 2844, 1275, 1274, 1284, 1285, 1277, 1278, + 1279, 1280, 1281, 1282, 1283, 1276, 2660, 4038, 3952, 1926, + 674, 1919, 1554, 2280, 2117, 3301, 674, 674, 674, 709, + 709, 1221, 1261, 1262, 1263, 1260, 2127, 2128, 2129, 2130, + 1879, 1844, 2003, 2136, 1221, 4035, 2254, 4011, 2050, 1259, + 223, 2134, 2110, 223, 223, 1701, 223, 3299, 1259, 3186, 1739, 1740, 1741, 1742, 1743, 1744, 1745, 1746, 1747, 1748, - 1749, 1714, 2786, 2842, 3376, 1761, 1762, 2764, 1258, 3226, - 2699, 2700, 2353, 1457, 3330, 2550, 3769, 3326, 2912, 2517, - 3887, 1187, 1222, 2133, 3769, 2787, 2788, 1892, 3770, 2631, - 1029, 1895, 1733, 1897, 1184, 695, 1679, 1695, 695, 695, - 4128, 1904, 1906, 1457, 1907, 1678, 1909, 1910, 1814, 3438, - 667, 1581, 1661, 4122, 1838, 3288, 1918, 1553, 1923, 1924, - 4110, 1926, 1516, 673, 3388, 1872, 3246, 1700, 673, 696, - 2314, 1553, 696, 696, 2447, 981, 1042, 692, 1946, 4068, - 692, 692, 1819, 1820, 1821, 1690, 693, 1894, 1689, 693, - 693, 1553, 1708, 1687, 1875, 1835, 694, 1516, 1836, 694, - 694, 1666, 691, 1828, 1669, 1685, 1688, 1684, 2659, 1713, - 1711, 2936, 1686, 2218, 1031, 1849, 1850, 1030, 2277, 4035, - 935, 2276, 1973, 1752, 1258, 1667, 4123, 1883, 1670, 1671, - 2352, 1980, 1980, 4069, 1516, 1871, 1516, 1516, 1759, 1760, - 673, 673, 2843, 2047, 1918, 2051, 2843, 2518, 1553, 2055, - 2056, 4032, 4069, 1699, 2071, 2518, 649, 3717, 3718, 3719, - 3723, 3721, 3722, 3724, 3720, 2252, 2131, 3300, 3298, 1925, - 649, 934, 1553, 3185, 3161, 1927, 937, 936, 4026, 3159, - 798, 142, 1977, 1373, 2518, 3330, 142, 2947, 2949, 2950, - 2951, 2948, 4036, 3036, 1258, 1260, 1261, 1262, 1259, 673, - 1918, 1553, 1878, 2116, 2754, 673, 673, 673, 708, 708, - 1222, 2417, 2420, 4008, 2649, 2126, 2127, 2128, 2129, 753, - 1843, 2636, 2135, 2209, 4033, 2073, 2002, 3958, 2049, 223, - 1220, 2403, 223, 223, 3957, 223, 2319, 913, 914, 915, - 916, 2251, 2313, 1914, 1915, 1916, 1879, 1983, 1912, 679, - 1873, 2253, 142, 2109, 2312, 1929, 1930, 1931, 1932, 4141, - 1274, 1273, 1283, 1284, 1276, 1277, 1278, 1279, 1280, 1281, - 1282, 1275, 3951, 2284, 2200, 1829, 1829, 2177, 2087, 2279, - 2104, 1957, 1958, 2101, 2102, 3926, 4009, 1829, 1829, 2078, - 1913, 2080, 2057, 1444, 2194, 2118, 2119, 2120, 1967, 1968, - 1258, 1767, 2099, 2100, 1948, 1949, 3914, 1258, 2417, 2420, - 1219, 2115, 1943, 1942, 1961, 1922, 1963, 1964, 1978, 2094, - 3861, 1966, 2143, 1643, 1982, 2146, 2147, 1946, 2149, 1938, - 1970, 1553, 2207, 1971, 1956, 3860, 3855, 3854, 1962, 3853, - 1947, 3852, 3832, 2179, 1539, 2253, 1467, 2421, 697, 1954, - 3831, 2188, 2416, 2410, 2415, 3804, 2413, 2418, 2218, 2072, - 1471, 4124, 1965, 3486, 2390, 2048, 1979, 1981, 2405, 1984, - 1985, 3040, 1471, 3551, 1260, 1261, 1262, 1259, 1972, 3915, - 2053, 1975, 1976, 1067, 2201, 2059, 3446, 1220, 142, 918, - 3734, 3499, 2077, 3862, 2079, 3464, 3406, 3402, 2845, 2088, - 1100, 1101, 1102, 142, 3308, 142, 2054, 1066, 2376, 2253, - 2253, 2419, 2253, 3011, 2253, 2218, 2740, 1068, 2728, 1066, - 3127, 2113, 3549, 2218, 2172, 2184, 2720, 2114, 2253, 1068, - 2675, 2662, 2121, 2122, 1099, 1069, 2172, 1096, 1069, 2661, - 1106, 1107, 2657, 2653, 2421, 1111, 2550, 1069, 2140, 2416, - 2410, 2415, 2397, 2413, 2418, 1260, 1261, 1262, 1259, 1711, - 1260, 1261, 1262, 1259, 3500, 2272, 786, 796, 3465, 3407, - 3403, 2157, 2257, 2236, 2237, 2199, 787, 3309, 788, 792, - 795, 791, 789, 790, 2645, 2638, 2518, 2190, 1275, 2376, - 1291, 1258, 2138, 2124, 2633, 2178, 2625, 1946, 2623, 1258, - 2103, 2389, 2611, 1258, 2187, 2185, 2249, 2621, 2419, 913, - 914, 915, 916, 1663, 695, 2376, 1066, 2232, 2198, 2324, - 2325, 2619, 2328, 2375, 1309, 2331, 1068, 1207, 2315, 1171, - 1166, 793, 2291, 3919, 933, 3251, 2337, 3671, 2202, 2290, - 3087, 2275, 751, 2266, 1069, 673, 673, 673, 696, 2265, - 2264, 2254, 1818, 1817, 2307, 2215, 692, 2634, 2639, 1468, - 673, 673, 673, 673, 794, 693, 2255, 2634, 1499, 2626, - 4135, 2624, 2231, 2373, 4096, 694, 2445, 3920, 2196, 1541, - 2620, 3672, 2377, 2378, 2379, 3478, 2382, 1516, 3896, 2217, - 1564, 2233, 1752, 3836, 2620, 1672, 2376, 1093, 1094, 1095, - 1098, 2314, 1097, 2240, 2197, 1258, 2234, 2235, 2285, 2286, - 2245, 2288, 1258, 1516, 1258, 3476, 1258, 1453, 2295, 1818, - 1817, 1454, 1258, 1258, 2253, 1844, 1845, 1846, 1847, 3479, - 2439, 1851, 1852, 1853, 1854, 1856, 1857, 1858, 1859, 1860, - 1861, 1862, 1863, 1864, 1865, 1866, 3803, 1274, 1273, 1283, - 1284, 1276, 1277, 1278, 1279, 1280, 1281, 1282, 1275, 3477, - 3761, 918, 2218, 3361, 3700, 3699, 1855, 1543, 1673, 3685, - 2394, 1453, 3644, 3456, 2396, 1454, 2398, 3242, 1544, 3331, - 1469, 3322, 2678, 1540, 3314, 2446, 940, 3310, 673, 1980, - 1278, 1279, 1280, 1281, 1282, 1275, 3220, 2522, 2522, 2071, - 2522, 2970, 2308, 2310, 2311, 2316, 1274, 1273, 1283, 1284, - 1276, 1277, 1278, 1279, 1280, 1281, 1282, 1275, 2969, 3041, - 649, 649, 2811, 2759, 2672, 2637, 2399, 2541, 1187, 2182, - 2181, 2180, 1440, 1848, 1553, 673, 1276, 1277, 1278, 1279, - 1280, 1281, 1282, 1275, 1439, 2409, 2408, 2343, 673, 1260, - 1261, 1262, 1259, 1189, 1187, 2594, 667, 1758, 3243, 2682, - 3364, 2605, 1592, 1771, 2071, 2246, 1597, 2601, 2141, 2603, - 2141, 2545, 223, 1755, 1757, 1754, 1771, 1756, 1332, 2451, - 1262, 1259, 2454, 2455, 2456, 2457, 2458, 2459, 2460, 2391, - 1908, 2463, 2464, 2465, 2466, 2467, 2468, 2469, 2470, 2471, - 2472, 2473, 3244, 2475, 2476, 2477, 2478, 2479, 2402, 2480, - 2386, 3976, 2641, 1259, 2536, 2392, 2537, 2524, 2393, 2528, - 2383, 3712, 2526, 2395, 3711, 2422, 2423, 3058, 2428, 2530, - 2655, 1066, 2906, 2207, 1333, 2542, 2543, 2904, 2552, 2883, - 1553, 1068, 1553, 2881, 1553, 2384, 2385, 3645, 3646, 1187, - 1260, 1261, 1262, 1259, 3691, 2387, 2388, 2674, 4106, 1069, - 2558, 2615, 1471, 4105, 2742, 2606, 2743, 142, 142, 142, - 1067, 1266, 1267, 1268, 1269, 1270, 1271, 1272, 1264, 2665, - 2712, 4104, 3638, 1553, 1187, 4102, 2491, 2600, 2706, 2497, - 1273, 1283, 1284, 1276, 1277, 1278, 1279, 1280, 1281, 1282, - 1275, 2531, 4131, 2713, 1260, 1261, 1262, 1259, 1553, 1311, - 4101, 2701, 3120, 3362, 2810, 1833, 1260, 1261, 1262, 1259, - 1551, 3444, 1310, 1532, 1534, 2684, 1260, 1261, 1262, 1259, - 1834, 2546, 2260, 4039, 1597, 2549, 2714, 1260, 1261, 1262, - 1259, 4017, 3639, 1292, 4007, 1551, 2607, 1260, 1261, 1262, - 1259, 2599, 2958, 2956, 2595, 2669, 1598, 2761, 2762, 2954, - 4006, 2765, 3450, 2717, 2718, 2651, 2652, 4130, 1260, 1261, - 1262, 1259, 3921, 2779, 1263, 3119, 1187, 1260, 1261, 1262, - 1259, 3445, 1293, 1553, 2690, 3857, 1516, 2943, 2268, 3845, - 3455, 1303, 1516, 2051, 2686, 2715, 2686, 3835, 3825, 2671, - 3752, 2841, 1260, 1261, 1262, 1259, 2666, 2847, 2680, 3674, - 2848, 3673, 2957, 2955, 2647, 3491, 2704, 1312, 2598, 2953, - 2658, 3613, 2663, 3480, 3443, 2656, 3210, 3083, 2858, 1260, - 1261, 1262, 1259, 2746, 1260, 1261, 1262, 1259, 1187, 3053, - 2828, 1260, 1261, 1262, 1259, 3106, 2880, 2942, 1260, 1261, - 1262, 1259, 3052, 1187, 1187, 1187, 1980, 2941, 2267, 1187, - 2940, 2890, 2891, 2892, 2893, 1187, 2900, 2692, 2901, 2902, - 2702, 2903, 2939, 2905, 3601, 2823, 2825, 2676, 2677, 3600, - 2931, 2925, 2558, 2924, 2900, 1260, 1261, 1262, 1259, 4127, - 2679, 2923, 1379, 2922, 2859, 2755, 2522, 2627, 1711, 2808, - 2538, 1260, 1261, 1262, 1259, 2824, 1260, 1261, 1262, 1259, - 2959, 3539, 2318, 2160, 2159, 2838, 2158, 2154, 2002, 649, - 2153, 2849, 2797, 1260, 1261, 1262, 1259, 2051, 2110, 1898, - 1896, 1187, 2071, 2071, 2071, 2071, 2071, 2071, 1260, 1261, - 1262, 1259, 1664, 2250, 2875, 1391, 3197, 2861, 1187, 2071, - 3796, 3797, 2522, 2789, 2878, 1069, 2964, 1169, 2878, 2875, - 2886, 2887, 3394, 4125, 4107, 2889, 3123, 2790, 3019, 2792, - 1553, 2896, 2874, 3589, 4094, 4056, 2806, 2840, 4055, 2831, - 4052, 673, 673, 8, 3982, 7, 3981, 2885, 2846, 1260, - 1261, 1262, 1259, 1260, 1261, 1262, 1259, 746, 2723, 2724, - 748, 3782, 2850, 3962, 2729, 747, 2860, 3906, 2863, 3649, - 3900, 2855, 2856, 3881, 3872, 2876, 1168, 3849, 2913, 2914, - 2882, 1260, 1261, 1262, 1259, 3844, 3843, 2888, 3800, 3007, - 3786, 3784, 3753, 2929, 2930, 3693, 2879, 2987, 223, 2857, - 3653, 1922, 2975, 223, 3642, 3627, 1562, 3626, 3122, 3622, - 679, 3620, 2921, 3121, 2987, 3618, 3615, 3612, 2966, 2933, - 3611, 3587, 3585, 3558, 3555, 1829, 3020, 1829, 3553, 2963, - 3068, 3440, 3422, 3415, 2851, 1260, 1261, 1262, 1259, 2854, - 1260, 1261, 1262, 1259, 3082, 2965, 142, 3399, 3397, 2971, - 1553, 3392, 3342, 3089, 1283, 1284, 1276, 1277, 1278, 1279, - 1280, 1281, 1282, 1275, 3037, 3320, 3319, 3317, 3316, 3063, - 1591, 3004, 3311, 3306, 3008, 3010, 3305, 3221, 2248, 3183, - 2739, 3075, 2968, 3182, 2988, 2989, 2990, 2991, 2992, 2993, - 2738, 3042, 3024, 3027, 3173, 1617, 3046, 2737, 3171, 3168, - 3009, 2736, 1535, 3166, 2069, 1618, 1619, 1260, 1261, 1262, - 1259, 1875, 2323, 2735, 142, 3097, 3067, 1260, 1261, 1262, - 1259, 142, 1624, 1625, 1260, 1261, 1262, 1259, 1260, 1261, - 1262, 1259, 3094, 3073, 142, 3051, 3026, 142, 142, 1632, - 1260, 1261, 1262, 1259, 2952, 1629, 2944, 2934, 1633, 2932, - 142, 3044, 2928, 3043, 2927, 3170, 1260, 1261, 1262, 1259, - 3086, 3091, 3174, 3175, 3176, 3178, 3065, 3180, 3181, 672, - 672, 2926, 2734, 3061, 3064, 680, 1187, 3076, 3079, 3066, - 2768, 3059, 1187, 2733, 1069, 3078, 3077, 2760, 3200, 2756, - 854, 853, 4133, 2648, 2338, 2332, 1069, 3085, 3214, 1260, - 1261, 1262, 1259, 673, 2329, 3099, 2163, 2156, 1886, 3098, - 1260, 1261, 1262, 1259, 1885, 1665, 1340, 3231, 1187, 1336, - 1335, 673, 1172, 673, 1187, 1187, 3118, 922, 3109, 3110, - 2732, 4082, 3938, 2071, 2373, 3934, 3250, 3105, 1723, 1724, - 1725, 1726, 1727, 3112, 3111, 3778, 3113, 3160, 3114, 3115, - 3777, 3766, 206, 3762, 197, 168, 2439, 1260, 1261, 1262, - 1259, 3614, 3596, 3568, 3471, 3234, 3224, 3470, 3276, 3468, - 3279, 3239, 3279, 3279, 3437, 3411, 3409, 1187, 3408, 3227, - 1768, 3405, 3186, 3164, 1772, 1773, 1774, 1775, 2875, 2731, - 3404, 3398, 3165, 2730, 1813, 3301, 2823, 3396, 3259, 3297, - 3377, 3367, 1823, 3366, 1553, 1553, 3353, 3202, 3352, 3254, - 3252, 3187, 3184, 3158, 3263, 3265, 1260, 1261, 1262, 1259, - 1260, 1261, 1262, 1259, 2875, 202, 4074, 3125, 3116, 3108, - 2875, 2875, 3302, 3303, 3107, 3101, 3035, 2622, 680, 2727, - 2618, 1551, 1551, 3223, 2617, 2296, 2289, 3233, 2283, 2282, - 1066, 673, 2281, 3237, 3238, 1876, 3248, 3200, 3245, 3249, - 1068, 2280, 2726, 2278, 3275, 2274, 1260, 1261, 1262, 1259, - 1516, 3284, 2273, 2051, 2051, 3258, 2409, 2408, 1069, 2271, - 1069, 3274, 2262, 2875, 2259, 2258, 1069, 3132, 3133, 1260, - 1261, 1262, 1259, 3134, 3135, 3136, 3137, 2162, 3138, 3139, - 3140, 3141, 3142, 3143, 3144, 3145, 3146, 3147, 3148, 3280, - 3281, 3285, 1869, 1069, 1868, 1867, 1832, 3299, 1831, 1822, - 1565, 206, 1563, 2873, 1286, 4081, 1290, 1187, 4038, 3956, - 1330, 2706, 2725, 3933, 3867, 3864, 3257, 1950, 3851, 3365, - 3846, 3307, 1287, 1289, 1285, 3747, 1288, 1274, 1273, 1283, - 1284, 1276, 1277, 1278, 1279, 1280, 1281, 1282, 1275, 1260, - 1261, 1262, 1259, 1969, 2070, 3282, 3746, 3728, 3710, 3706, - 3327, 3328, 2719, 3313, 3684, 3668, 3312, 4072, 2709, 3569, - 3318, 3321, 2705, 3325, 3566, 3315, 673, 3537, 3536, 3533, - 3532, 3950, 3682, 3338, 202, 3339, 2681, 3498, 3253, 1260, - 1261, 1262, 1259, 3255, 3256, 1260, 1261, 1262, 1259, 1260, - 1261, 1262, 1259, 3495, 3493, 3346, 3458, 3349, 3350, 3351, - 3117, 1612, 1876, 1260, 1261, 1262, 1259, 1876, 1876, 1623, - 1614, 1628, 1631, 2558, 1620, 3355, 1447, 2998, 2960, 142, - 3948, 1766, 142, 142, 2884, 142, 1274, 1273, 1283, 1284, - 1276, 1277, 1278, 1279, 1280, 1281, 1282, 1275, 2834, 2135, - 3419, 709, 2833, 3421, 2826, 2791, 2741, 3423, 1260, 1261, - 1262, 1259, 3429, 2632, 2540, 2481, 3381, 2142, 2374, 2345, - 2145, 3385, 2344, 2148, 3384, 1067, 2150, 3400, 142, 2317, - 1753, 202, 2123, 3378, 3430, 1882, 1696, 1067, 1646, 1621, - 3390, 1390, 1375, 1371, 1370, 3380, 1369, 673, 2051, 3424, - 1368, 3426, 2686, 142, 1367, 1366, 1365, 1364, 1363, 3463, - 1362, 1361, 1360, 1359, 3436, 1358, 1357, 1356, 1355, 1354, - 1353, 3439, 1352, 3329, 1351, 1350, 2522, 2071, 3483, 1349, - 1348, 2500, 2193, 1347, 1346, 1343, 1342, 1341, 1339, 1338, - 1337, 1334, 1327, 1326, 3412, 3345, 3416, 1324, 1323, 3418, - 1322, 3501, 1321, 1320, 1187, 1319, 1318, 1317, 1316, 1315, - 1314, 1313, 1308, 3276, 3433, 1307, 1306, 1187, 2507, 2511, - 2512, 2513, 2508, 2516, 2509, 2514, 1305, 1304, 2510, 1187, - 2515, 3548, 3434, 1224, 1292, 1553, 1170, 3451, 3334, 3335, - 3946, 3944, 3534, 2381, 2359, 3453, 1212, 4022, 3337, 2812, - 3485, 2551, 2165, 1223, 3006, 673, 2996, 2051, 3344, 3001, - 3571, 1187, 3343, 3550, 3002, 3531, 2999, 2995, 3572, 3340, - 3005, 3000, 1551, 3003, 2994, 2512, 2513, 125, 3492, 1069, - 3494, 3975, 3883, 67, 66, 3689, 1069, 2242, 3488, 3524, - 2646, 2247, 2635, 223, 1441, 3481, 3459, 3460, 3461, 2256, - 3482, 1940, 1941, 3466, 3467, 3559, 1187, 3562, 3219, 3538, - 3502, 3540, 3543, 3382, 3383, 672, 1176, 3272, 3570, 3273, - 3081, 3547, 2449, 3541, 3544, 3356, 1185, 1935, 1936, 1937, - 2039, 3552, 1606, 3554, 2630, 2896, 2263, 3573, 2670, 3557, - 3561, 2651, 2652, 2339, 2270, 3560, 675, 3563, 3616, 1213, - 3564, 3556, 676, 677, 1660, 1640, 2125, 1218, 3195, 3624, - 3188, 2862, 2835, 2401, 2369, 1944, 2287, 2987, 1911, 1187, - 3594, 2292, 2293, 2294, 1818, 1817, 2297, 2298, 2299, 2300, - 2301, 2302, 2303, 2304, 2305, 2306, 3580, 3590, 4085, 1187, - 1553, 1553, 3591, 1386, 1387, 3848, 3231, 3621, 3304, 3623, - 1384, 1385, 1382, 1383, 1380, 1381, 2494, 2487, 3662, 2052, - 1508, 3662, 2987, 1507, 1251, 2183, 1483, 3348, 3651, 3029, - 2340, 2195, 1460, 3575, 1187, 3678, 1187, 1551, 1764, 3650, - 1459, 1432, 4045, 4043, 4000, 3681, 3484, 3683, 3972, 3971, - 3969, 3910, 3868, 1553, 3659, 3487, 3632, 3656, 3657, 3634, - 3652, 3633, 3742, 3741, 3679, 3586, 3401, 3374, 3373, 3643, - 3359, 673, 2434, 1187, 1187, 3610, 2404, 1187, 1187, 1662, - 3655, 3358, 3667, 3039, 1457, 2875, 3666, 3420, 2179, 3680, - 1764, 3629, 3084, 3485, 2766, 3730, 2261, 3677, 4076, 4075, - 1184, 1394, 1209, 3725, 4075, 3531, 3690, 1946, 3687, 4076, - 3739, 3708, 3694, 3714, 3715, 3354, 1475, 3726, 3727, 210, - 3, 75, 3748, 3749, 3686, 913, 914, 915, 916, 3524, - 1184, 2, 4098, 4099, 3692, 1553, 1, 2747, 1880, 1388, - 1717, 917, 1717, 1274, 1273, 1283, 1284, 1276, 1277, 1278, - 1279, 1280, 1281, 1282, 1275, 912, 3735, 1529, 3779, 2525, - 2532, 2105, 1557, 3760, 3737, 3736, 1884, 919, 3731, 1069, - 3772, 3012, 1551, 2507, 2511, 2512, 2513, 2508, 2516, 2509, - 2514, 3013, 3783, 2510, 3785, 2515, 3347, 3755, 3015, 2769, - 3759, 2214, 2976, 2485, 2349, 3805, 3213, 1442, 974, 1824, - 3767, 3771, 1677, 1201, 1674, 3812, 1200, 3788, 1876, 3817, - 1876, 3810, 1198, 1769, 3602, 800, 3603, 2168, 2961, 2935, - 3738, 4084, 4119, 4037, 2070, 1187, 4087, 3732, 1694, 1876, - 1876, 3733, 142, 784, 3963, 3799, 3834, 3873, 3840, 4041, - 3875, 3758, 2219, 1256, 3060, 1001, 3808, 841, 811, 1325, - 1653, 3130, 3128, 810, 3448, 3813, 3811, 3814, 2802, 3594, - 3743, 1591, 3032, 3826, 3830, 3819, 1002, 2151, 3870, 1187, - 3756, 1607, 1611, 2400, 1553, 3827, 3929, 3688, 3268, 3675, - 3676, 2870, 1635, 3924, 3496, 3606, 3604, 3605, 716, 1511, - 2084, 647, 3847, 1051, 2241, 3729, 1522, 2164, 717, 2380, - 3988, 3850, 3858, 954, 3431, 2358, 955, 947, 2821, 3856, - 2640, 1551, 2643, 2820, 1734, 1265, 1751, 1559, 1274, 1273, - 1283, 1284, 1276, 1277, 1278, 1279, 1280, 1281, 1282, 1275, - 3902, 1717, 3889, 3149, 3150, 1302, 755, 2244, 3869, 2799, - 3519, 3025, 74, 73, 72, 71, 3897, 231, 3898, 802, - 230, 3780, 3647, 3959, 4089, 781, 780, 779, 778, 3911, - 777, 1069, 776, 2505, 2506, 2504, 2502, 2501, 2066, 3899, - 2065, 3038, 3357, 2130, 2132, 3229, 2683, 2899, 2894, 2689, - 1991, 1989, 3905, 1520, 2429, 2436, 1988, 4019, 3928, 3391, - 2707, 2708, 1187, 3913, 3597, 3939, 3940, 3705, 2710, 2711, - 1553, 2945, 3593, 3953, 1934, 2425, 2008, 2916, 3960, 3943, - 3945, 3947, 3949, 3927, 2716, 2005, 3859, 2004, 2907, 3701, - 3865, 3866, 3961, 3695, 3936, 2036, 3815, 3661, 3952, 3922, - 3503, 3504, 3942, 3510, 2368, 1120, 1116, 1551, 1118, 1119, - 1117, 2691, 3323, 1723, 1876, 2406, 3190, 2785, 2784, 3968, - 3966, 2782, 2781, 1553, 1417, 142, 3817, 3901, 3984, 3628, - 2556, 2554, 3983, 1167, 3336, 142, 3332, 2176, 3980, 3341, - 2997, 2191, 4010, 3080, 2067, 2063, 2062, 1091, 4018, 1090, - 1588, 4002, 4001, 2978, 2495, 3790, 4003, 1939, 948, 2356, - 1551, 3126, 109, 3912, 41, 122, 108, 185, 59, 3916, - 3917, 184, 58, 120, 182, 4034, 57, 4004, 4005, 103, - 102, 119, 4027, 180, 4028, 56, 4029, 215, 4030, 2852, - 2853, 4031, 214, 4044, 217, 4046, 4047, 216, 213, 2608, - 3937, 4042, 4040, 2609, 212, 1595, 211, 3973, 3665, 3955, - 3889, 1187, 4050, 907, 4051, 1274, 1273, 1283, 1284, 1276, - 1277, 1278, 1279, 1280, 1281, 1282, 1275, 44, 43, 186, - 3840, 42, 4064, 110, 60, 40, 39, 38, 34, 13, - 4066, 4067, 4065, 4070, 12, 35, 4073, 4083, 4071, 4091, - 22, 21, 4090, 1681, 4077, 4078, 4079, 4080, 20, 26, - 32, 31, 2070, 2070, 2070, 2070, 2070, 2070, 4103, 4095, - 135, 134, 30, 133, 1187, 132, 131, 130, 129, 2070, - 128, 127, 29, 19, 51, 4108, 3928, 4109, 50, 49, - 4111, 48, 1802, 47, 4117, 46, 9, 4121, 123, 118, - 4118, 1274, 1273, 1283, 1284, 1276, 1277, 1278, 1279, 1280, - 1281, 1282, 1275, 116, 28, 117, 114, 4062, 115, 113, - 112, 111, 106, 104, 86, 4129, 85, 84, 99, 98, - 1876, 97, 96, 95, 4091, 4137, 94, 4090, 4136, 92, - 93, 4053, 4054, 1000, 83, 82, 4121, 4138, 4058, 4059, - 4060, 4061, 4142, 81, 80, 79, 101, 1928, 107, 105, - 90, 100, 1933, 91, 89, 88, 87, 78, 142, 77, - 76, 166, 165, 142, 164, 163, 162, 160, 161, 159, - 1717, 158, 157, 156, 155, 154, 52, 53, 54, 55, - 176, 175, 177, 179, 142, 181, 178, 183, 173, 171, - 174, 172, 170, 69, 11, 121, 142, 18, 4, 0, - 0, 3045, 0, 3047, 1509, 1510, 0, 1512, 1513, 0, - 1517, 1518, 1519, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1876, 0, 1986, 1987, 0, 1876, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 2193, - 0, 0, 0, 0, 1568, 1569, 1570, 1571, 1572, 0, - 1574, 1575, 1576, 1577, 1578, 0, 1798, 0, 1584, 1585, - 1586, 1587, 0, 1795, 0, 0, 0, 1797, 1794, 1796, - 1800, 1801, 0, 0, 3100, 1799, 0, 0, 206, 64, - 197, 168, 0, 2112, 0, 0, 0, 0, 0, 2112, - 2112, 2112, 0, 0, 0, 0, 0, 198, 3508, 0, - 0, 0, 3124, 0, 189, 0, 0, 0, 199, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 206, 64, - 197, 168, 0, 0, 0, 0, 0, 140, 2037, 0, - 0, 0, 0, 0, 0, 206, 0, 198, 0, 3520, - 0, 0, 126, 0, 189, 0, 0, 0, 199, 0, - 0, 202, 3511, 0, 0, 0, 0, 0, 3660, 0, - 0, 0, 0, 3506, 2039, 0, 0, 140, 3528, 3529, - 0, 0, 0, 0, 3507, 0, 0, 0, 1067, 0, - 142, 0, 126, 0, 0, 0, 142, 0, 0, 0, - 0, 202, 0, 2070, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 202, 0, - 0, 3512, 0, 142, 0, 0, 0, 0, 2014, 1805, - 1806, 1807, 1808, 1809, 1810, 1803, 1804, 0, 148, 149, - 0, 150, 151, 0, 0, 0, 152, 0, 0, 153, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 148, 149, - 0, 150, 151, 0, 3283, 0, 152, 0, 0, 153, - 0, 0, 0, 0, 0, 0, 2030, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 167, 195, 204, 196, 124, 0, 0, 3527, - 0, 2415, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 194, 188, 187, 0, 0, - 0, 0, 70, 0, 0, 0, 3516, 0, 0, 0, - 0, 0, 167, 195, 204, 196, 124, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 3513, 3517, - 3515, 3514, 0, 0, 0, 194, 188, 187, 0, 0, - 2018, 0, 70, 0, 0, 0, 0, 0, 0, 0, - 0, 2024, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 190, 191, 192, 0, 0, 0, 3522, - 3523, 2012, 2046, 0, 0, 2013, 2015, 2017, 0, 2019, - 2020, 2021, 2025, 2026, 2027, 2029, 2032, 2033, 2034, 0, - 0, 0, 0, 0, 0, 0, 2022, 2031, 2023, 2346, - 2347, 2348, 200, 190, 191, 192, 0, 0, 0, 0, - 0, 0, 0, 0, 2364, 2365, 2366, 2367, 0, 0, - 0, 0, 3530, 136, 0, 0, 0, 193, 0, 137, - 0, 0, 0, 2038, 3509, 0, 0, 0, 0, 0, - 3521, 0, 200, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 136, 0, 0, 0, 193, 0, 137, - 0, 0, 0, 0, 2037, 0, 0, 0, 0, 1998, - 3393, 0, 0, 2035, 0, 0, 138, 3395, 0, 0, - 0, 1802, 0, 0, 0, 0, 0, 0, 0, 63, - 2011, 0, 0, 0, 0, 0, 0, 2010, 0, 142, - 2039, 2007, 0, 0, 0, 2117, 142, 0, 0, 3410, - 2040, 2041, 0, 0, 0, 0, 138, 0, 0, 0, - 0, 2028, 1260, 1261, 1262, 1259, 0, 0, 0, 63, - 2016, 0, 1522, 0, 0, 0, 2006, 0, 65, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 2014, 0, 0, 2070, 0, 0, - 3526, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 146, 203, 0, 147, 0, 65, 1559, - 0, 169, 0, 0, 0, 0, 61, 0, 0, 0, - 0, 0, 2112, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1802, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 146, 203, 0, 147, 0, 0, 0, - 0, 169, 2030, 0, 0, 0, 61, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 3525, 0, 169, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 139, 45, 0, 1798, 0, 0, 0, 62, - 0, 0, 1795, 5, 0, 1876, 1797, 1794, 1796, 1800, - 1801, 0, 0, 142, 1799, 0, 0, 0, 0, 0, - 0, 1876, 143, 144, 3565, 0, 145, 3567, 0, 0, - 0, 0, 139, 45, 0, 0, 1997, 1999, 1996, 62, - 0, 1993, 0, 0, 0, 0, 2018, 0, 3574, 0, - 0, 0, 0, 0, 0, 0, 0, 2024, 0, 0, - 0, 0, 143, 144, 0, 2009, 145, 1992, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 2012, 2046, 0, - 0, 2013, 2015, 2017, 0, 2019, 2020, 2021, 2025, 2026, - 2027, 2029, 2032, 2033, 2034, 0, 2037, 0, 0, 0, - 0, 1998, 2022, 2031, 2023, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 2001, 0, 1798, 0, 0, 142, - 0, 0, 0, 1795, 0, 0, 0, 1797, 1794, 1796, - 1800, 1801, 2039, 2007, 0, 1799, 0, 0, 0, 2038, - 0, 0, 2040, 2041, 0, 0, 0, 1783, 1784, 1785, - 1786, 1787, 1788, 1789, 1790, 1791, 1792, 1793, 1805, 1806, - 1807, 1808, 1809, 1810, 1803, 1804, 0, 0, 2006, 0, - 0, 1994, 1995, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 2839, 2014, 0, 0, 2035, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 2011, 0, 0, 0, - 0, 0, 0, 2010, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 2028, 0, 0, - 0, 0, 0, 0, 0, 0, 2016, 0, 0, 0, - 0, 0, 0, 0, 2030, 0, 0, 0, 0, 2043, - 2042, 0, 0, 1139, 0, 0, 0, 0, 1783, 1784, - 1785, 1786, 1787, 1788, 1789, 1790, 1791, 1792, 1793, 1805, - 1806, 1807, 1808, 1809, 1810, 1803, 1804, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 142, 2003, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 1997, 2865, - 1996, 0, 0, 2864, 0, 0, 0, 0, 2018, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 2024, - 0, 0, 0, 0, 2045, 0, 0, 2044, 0, 0, - 0, 0, 0, 0, 0, 3030, 3031, 0, 0, 2012, - 2046, 0, 0, 2013, 2015, 2017, 0, 2019, 2020, 2021, - 2025, 2026, 2027, 2029, 2032, 2033, 2034, 1124, 0, 0, - 0, 0, 0, 0, 2022, 2031, 2023, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 2001, 0, 1147, 1151, - 1153, 1155, 1157, 1158, 1160, 0, 1165, 1161, 1162, 1163, - 1164, 0, 1142, 1143, 1144, 1145, 1122, 1123, 1148, 0, - 1125, 2038, 1127, 1128, 1129, 1130, 1126, 1131, 1132, 1133, - 1134, 1135, 1138, 1140, 1136, 1137, 1146, 0, 0, 0, - 0, 0, 0, 0, 1150, 1152, 1154, 1156, 1159, 0, - 0, 0, 0, 1994, 1995, 0, 1312, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 2035, 0, 0, 0, 0, 0, 0, 0, 0, - 728, 727, 734, 724, 1141, 0, 0, 0, 2011, 0, - 0, 0, 0, 731, 732, 2010, 733, 737, 0, 0, - 718, 0, 0, 0, 0, 1139, 0, 0, 0, 0, - 742, 0, 0, 0, 0, 0, 0, 0, 0, 2028, - 0, 0, 0, 0, 0, 0, 3935, 0, 2016, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 2043, 2042, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 746, 0, 0, 748, - 0, 0, 0, 0, 747, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 2003, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 4015, 0, 0, 0, 3222, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 1124, - 0, 2687, 2688, 1114, 0, 3235, 2045, 3236, 0, 2044, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1147, 1151, 1153, 1155, 1157, 1158, 1160, 1139, 1165, 1161, - 1162, 1163, 1164, 0, 1142, 1143, 1144, 1145, 1122, 1123, - 1148, 0, 1125, 0, 1127, 1128, 1129, 1130, 1126, 1131, - 1132, 1133, 1134, 1135, 1138, 1140, 1136, 1137, 1146, 0, - 0, 0, 4015, 0, 0, 0, 1150, 1152, 1154, 1156, - 1159, 0, 0, 0, 719, 721, 720, 0, 0, 0, - 0, 0, 0, 0, 0, 726, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 730, 0, 0, - 0, 0, 0, 0, 745, 0, 1141, 0, 0, 0, - 0, 723, 0, 0, 0, 713, 0, 0, 0, 4015, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 2112, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1149, 0, 0, 0, 0, - 0, 1124, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1147, 1151, 1153, 1155, 1157, 1158, 1160, 0, - 1165, 1161, 1162, 1163, 1164, 4140, 1142, 1143, 1144, 1145, - 1122, 1123, 1148, 0, 1125, 0, 1127, 1128, 1129, 1130, - 1126, 1131, 1132, 1133, 1134, 1135, 1138, 1140, 1136, 1137, - 1146, 0, 0, 0, 0, 0, 0, 0, 1150, 1152, - 1154, 1156, 1159, 0, 0, 0, 0, 0, 0, 725, - 729, 735, 0, 736, 738, 0, 0, 739, 740, 741, - 0, 0, 743, 744, 0, 0, 0, 0, 0, 0, - 0, 818, 0, 0, 0, 0, 0, 0, 1141, 0, - 401, 0, 0, 532, 565, 554, 638, 520, 0, 0, - 3387, 0, 0, 0, 770, 0, 0, 0, 336, 0, - 0, 369, 569, 551, 561, 552, 537, 538, 539, 546, - 348, 540, 541, 542, 512, 543, 513, 544, 545, 809, - 568, 519, 434, 385, 586, 585, 0, 0, 878, 886, - 0, 0, 0, 0, 0, 0, 0, 0, 874, 0, - 0, 0, 0, 762, 0, 0, 799, 854, 853, 786, - 796, 0, 0, 309, 229, 514, 634, 516, 515, 787, - 0, 788, 792, 795, 791, 789, 790, 0, 869, 0, - 0, 0, 0, 0, 0, 754, 766, 0, 771, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 763, 764, 0, 0, 0, 0, 819, 0, - 765, 2112, 0, 814, 793, 797, 0, 1149, 722, 0, - 299, 441, 460, 310, 429, 473, 315, 437, 452, 305, - 400, 426, 0, 0, 301, 458, 436, 382, 359, 360, - 300, 0, 420, 334, 350, 331, 398, 794, 817, 821, - 330, 892, 815, 468, 303, 0, 467, 397, 454, 459, - 383, 376, 0, 302, 456, 381, 375, 363, 340, 893, - 364, 365, 354, 409, 373, 410, 355, 387, 386, 388, - 0, 0, 0, 0, 0, 496, 497, 0, 0, 645, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 627, 812, 0, 631, 0, 470, 0, 0, 876, - 0, 0, 0, 440, 0, 0, 366, 0, 0, 2112, - 816, 0, 423, 403, 889, 0, 0, 421, 371, 455, - 411, 461, 442, 469, 417, 412, 294, 443, 333, 384, - 306, 308, 328, 335, 337, 341, 342, 393, 394, 406, - 428, 445, 446, 447, 332, 316, 422, 317, 352, 318, - 295, 324, 322, 325, 430, 326, 297, 407, 451, 1149, - 347, 418, 379, 298, 378, 408, 450, 449, 307, 477, - 483, 484, 573, 0, 489, 661, 662, 663, 498, 0, - 413, 0, 503, 504, 505, 507, 508, 509, 510, 574, - 591, 558, 528, 491, 582, 525, 529, 530, 357, 594, - 1826, 1825, 1827, 482, 367, 368, 0, 339, 338, 380, - 416, 345, 291, 292, 656, 873, 399, 596, 629, 630, - 521, 0, 888, 868, 870, 871, 875, 879, 880, 881, - 882, 883, 885, 887, 891, 655, 0, 575, 590, 659, - 589, 652, 405, 0, 427, 587, 534, 0, 579, 553, - 0, 580, 549, 584, 0, 523, 0, 435, 463, 475, - 492, 495, 524, 609, 610, 611, 296, 494, 613, 614, - 615, 616, 617, 618, 619, 612, 890, 556, 533, 559, - 474, 536, 535, 0, 0, 570, 820, 571, 572, 389, - 390, 391, 392, 877, 597, 314, 493, 415, 0, 557, - 0, 0, 0, 0, 0, 0, 0, 0, 562, 563, - 560, 664, 0, 620, 621, 3713, 0, 487, 488, 344, - 351, 506, 353, 313, 404, 346, 472, 361, 0, 499, - 564, 500, 623, 626, 624, 625, 396, 356, 358, 431, - 362, 372, 419, 471, 402, 424, 311, 462, 433, 377, - 550, 577, 899, 872, 898, 900, 901, 897, 902, 903, - 884, 775, 0, 827, 895, 894, 896, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 605, 604, - 603, 602, 601, 600, 599, 598, 0, 0, 547, 448, - 323, 285, 319, 320, 327, 653, 650, 453, 654, 782, - 293, 527, 370, 0, 414, 343, 592, 593, 0, 644, - 861, 834, 835, 836, 772, 837, 831, 832, 773, 833, - 862, 825, 858, 859, 801, 828, 838, 857, 839, 860, - 863, 864, 904, 905, 845, 829, 257, 906, 842, 865, - 856, 855, 840, 826, 866, 867, 808, 803, 843, 844, - 830, 849, 850, 851, 774, 822, 823, 824, 846, 847, - 804, 805, 806, 807, 0, 0, 0, 478, 479, 480, - 502, 0, 464, 526, 651, 0, 0, 0, 0, 0, - 0, 0, 576, 588, 622, 0, 632, 633, 635, 637, - 852, 639, 438, 439, 646, 0, 848, 642, 643, 640, - 374, 425, 444, 432, 818, 657, 517, 518, 658, 628, - 0, 767, 0, 401, 0, 0, 532, 565, 554, 638, - 520, 0, 0, 0, 0, 0, 0, 770, 0, 0, - 0, 336, 1877, 0, 369, 569, 551, 561, 552, 537, - 538, 539, 546, 348, 540, 541, 542, 512, 543, 513, - 544, 545, 809, 568, 519, 434, 385, 586, 585, 0, - 0, 878, 886, 0, 0, 0, 0, 0, 0, 0, - 0, 874, 0, 2096, 0, 0, 762, 0, 0, 799, - 854, 853, 786, 796, 0, 0, 309, 229, 514, 634, - 516, 515, 787, 0, 788, 792, 795, 791, 789, 790, - 0, 869, 0, 0, 0, 0, 0, 0, 754, 766, - 0, 771, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 763, 764, 0, 0, 0, - 0, 819, 0, 765, 0, 0, 2097, 793, 797, 0, - 0, 0, 0, 299, 441, 460, 310, 429, 473, 315, - 437, 452, 305, 400, 426, 0, 0, 301, 458, 436, - 382, 359, 360, 300, 0, 420, 334, 350, 331, 398, - 794, 817, 821, 330, 892, 815, 468, 303, 0, 467, - 397, 454, 459, 383, 376, 0, 302, 456, 381, 375, - 363, 340, 893, 364, 365, 354, 409, 373, 410, 355, - 387, 386, 388, 0, 0, 0, 0, 0, 496, 497, - 0, 0, 645, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 627, 812, 0, 631, 0, 470, - 0, 0, 876, 0, 0, 0, 440, 0, 0, 366, - 0, 0, 0, 816, 0, 423, 403, 889, 0, 0, - 421, 371, 455, 411, 461, 442, 469, 417, 412, 294, - 443, 333, 384, 306, 308, 328, 335, 337, 341, 342, - 393, 394, 406, 428, 445, 446, 447, 332, 316, 422, - 317, 352, 318, 295, 324, 322, 325, 430, 326, 297, - 407, 451, 0, 347, 418, 379, 298, 378, 408, 450, - 449, 307, 477, 483, 484, 573, 0, 489, 661, 662, - 663, 498, 0, 413, 0, 503, 504, 505, 507, 508, - 509, 510, 574, 591, 558, 528, 491, 582, 525, 529, - 530, 357, 594, 0, 0, 0, 482, 367, 368, 0, - 339, 338, 380, 416, 345, 291, 292, 656, 873, 399, - 596, 629, 630, 521, 0, 888, 868, 870, 871, 875, - 879, 880, 881, 882, 883, 885, 887, 891, 655, 0, - 575, 590, 659, 589, 652, 405, 0, 427, 587, 534, - 0, 579, 553, 0, 580, 549, 584, 0, 523, 0, - 435, 463, 475, 492, 495, 524, 609, 610, 611, 296, - 494, 613, 614, 615, 616, 617, 618, 619, 612, 890, - 556, 533, 559, 474, 536, 535, 0, 0, 570, 820, - 571, 572, 389, 390, 391, 392, 877, 597, 314, 493, - 415, 0, 557, 0, 0, 0, 0, 0, 0, 0, - 0, 562, 563, 560, 664, 0, 620, 621, 0, 0, - 487, 488, 344, 351, 506, 353, 313, 404, 346, 472, - 361, 0, 499, 564, 500, 623, 626, 624, 625, 396, - 356, 358, 431, 362, 372, 419, 471, 402, 424, 311, - 462, 433, 377, 550, 577, 899, 872, 898, 900, 901, - 897, 902, 903, 884, 775, 0, 827, 895, 894, 896, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 605, 604, 603, 602, 601, 600, 599, 598, 0, - 0, 547, 448, 323, 285, 319, 320, 327, 653, 650, - 453, 654, 782, 293, 527, 370, 0, 414, 343, 592, - 593, 0, 644, 861, 834, 835, 836, 772, 837, 831, - 832, 773, 833, 862, 825, 858, 859, 801, 828, 838, - 857, 839, 860, 863, 864, 904, 905, 845, 829, 257, - 906, 842, 865, 856, 855, 840, 826, 866, 867, 808, - 803, 843, 844, 830, 849, 850, 851, 774, 822, 823, - 824, 846, 847, 804, 805, 806, 807, 0, 0, 0, - 478, 479, 480, 502, 0, 464, 526, 651, 0, 0, - 0, 0, 0, 0, 0, 576, 588, 622, 0, 632, - 633, 635, 637, 852, 639, 438, 439, 646, 0, 848, - 642, 643, 640, 374, 425, 444, 432, 0, 657, 517, - 518, 658, 628, 0, 767, 206, 818, 0, 0, 0, - 0, 0, 0, 0, 0, 401, 0, 0, 532, 565, - 554, 638, 520, 0, 0, 0, 0, 0, 0, 770, - 0, 0, 0, 336, 0, 0, 369, 569, 551, 561, - 552, 537, 538, 539, 546, 348, 540, 541, 542, 512, - 543, 513, 544, 545, 1295, 568, 519, 434, 385, 586, - 585, 0, 0, 878, 886, 0, 0, 0, 0, 0, - 0, 0, 0, 874, 0, 0, 0, 0, 762, 0, - 0, 799, 854, 853, 786, 796, 0, 0, 309, 229, - 514, 634, 516, 515, 787, 0, 788, 792, 795, 791, - 789, 790, 0, 869, 0, 0, 0, 0, 0, 0, - 754, 766, 0, 771, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 763, 764, 0, - 0, 0, 0, 819, 0, 765, 0, 0, 814, 793, - 797, 0, 0, 0, 0, 299, 441, 460, 310, 429, - 473, 315, 437, 452, 305, 400, 426, 0, 0, 301, - 458, 436, 382, 359, 360, 300, 0, 420, 334, 350, - 331, 398, 794, 817, 821, 330, 892, 815, 468, 303, - 0, 467, 397, 454, 459, 383, 376, 0, 302, 456, - 381, 375, 363, 340, 893, 364, 365, 354, 409, 373, - 410, 355, 387, 386, 388, 0, 0, 0, 0, 0, - 496, 497, 0, 0, 645, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 627, 812, 0, 631, - 0, 470, 0, 0, 876, 0, 0, 0, 440, 0, - 0, 366, 0, 0, 0, 816, 0, 423, 403, 889, - 0, 0, 421, 371, 455, 411, 461, 442, 469, 417, - 412, 294, 443, 333, 384, 306, 308, 328, 335, 337, - 341, 342, 393, 394, 406, 428, 445, 446, 447, 332, - 316, 422, 317, 352, 318, 295, 324, 322, 325, 430, - 326, 297, 407, 451, 0, 347, 418, 379, 298, 378, - 408, 450, 449, 307, 477, 483, 484, 573, 0, 489, - 661, 662, 663, 498, 0, 413, 0, 503, 504, 505, - 507, 508, 509, 510, 574, 591, 558, 528, 491, 582, - 525, 529, 530, 357, 594, 0, 0, 0, 482, 367, - 368, 0, 339, 338, 380, 416, 345, 291, 292, 656, - 873, 399, 596, 629, 630, 521, 0, 888, 868, 870, - 871, 875, 879, 880, 881, 882, 883, 885, 887, 891, - 655, 0, 575, 590, 659, 589, 652, 405, 0, 427, - 587, 534, 0, 579, 553, 0, 580, 549, 584, 0, - 523, 0, 435, 463, 475, 492, 495, 524, 609, 610, - 611, 296, 494, 613, 614, 615, 616, 617, 618, 619, - 612, 890, 556, 533, 559, 474, 536, 535, 0, 0, - 570, 820, 571, 572, 389, 390, 391, 392, 877, 597, - 314, 493, 415, 0, 557, 0, 0, 0, 0, 0, - 0, 0, 0, 562, 563, 560, 664, 0, 620, 621, - 0, 0, 487, 488, 344, 351, 506, 353, 313, 404, - 346, 472, 361, 0, 499, 564, 500, 623, 626, 624, - 625, 396, 356, 358, 431, 362, 372, 419, 471, 402, - 424, 311, 462, 433, 377, 550, 577, 899, 872, 898, - 900, 901, 897, 902, 903, 884, 775, 0, 827, 895, - 894, 896, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 605, 604, 603, 602, 601, 600, 599, - 598, 0, 0, 547, 448, 323, 285, 319, 320, 327, - 653, 650, 453, 654, 782, 293, 527, 370, 169, 414, - 343, 592, 593, 0, 644, 861, 834, 835, 836, 772, - 837, 831, 832, 773, 833, 862, 825, 858, 859, 801, - 828, 838, 857, 839, 860, 863, 864, 904, 905, 845, - 829, 257, 906, 842, 865, 856, 855, 840, 826, 866, - 867, 808, 803, 843, 844, 830, 849, 850, 851, 774, - 822, 823, 824, 846, 847, 804, 805, 806, 807, 0, - 0, 0, 478, 479, 480, 502, 0, 464, 526, 651, - 0, 0, 0, 0, 0, 0, 0, 576, 588, 622, - 0, 632, 633, 635, 637, 852, 639, 438, 439, 646, - 0, 848, 642, 643, 640, 374, 425, 444, 432, 818, - 657, 517, 518, 658, 628, 0, 767, 0, 401, 0, - 0, 532, 565, 554, 638, 520, 0, 0, 0, 0, - 0, 0, 770, 0, 0, 0, 336, 4139, 0, 369, - 569, 551, 561, 552, 537, 538, 539, 546, 348, 540, - 541, 542, 512, 543, 513, 544, 545, 809, 568, 519, - 434, 385, 586, 585, 0, 0, 878, 886, 0, 0, - 0, 0, 0, 0, 0, 0, 874, 0, 0, 0, - 0, 762, 0, 0, 799, 854, 853, 786, 796, 0, - 0, 309, 229, 514, 634, 516, 515, 787, 0, 788, - 792, 795, 791, 789, 790, 0, 869, 0, 0, 0, - 0, 0, 0, 754, 766, 0, 771, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 763, 764, 0, 0, 0, 0, 819, 0, 765, 0, - 0, 814, 793, 797, 0, 0, 0, 0, 299, 441, - 460, 310, 429, 473, 315, 437, 452, 305, 400, 426, - 0, 0, 301, 458, 436, 382, 359, 360, 300, 0, - 420, 334, 350, 331, 398, 794, 817, 821, 330, 892, - 815, 468, 303, 0, 467, 397, 454, 459, 383, 376, - 0, 302, 456, 381, 375, 363, 340, 893, 364, 365, - 354, 409, 373, 410, 355, 387, 386, 388, 0, 0, - 0, 0, 0, 496, 497, 0, 0, 645, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 627, - 812, 0, 631, 0, 470, 0, 0, 876, 0, 0, - 0, 440, 0, 0, 366, 0, 0, 0, 816, 0, - 423, 403, 889, 0, 0, 421, 371, 455, 411, 461, - 442, 469, 417, 412, 294, 443, 333, 384, 306, 308, - 328, 335, 337, 341, 342, 393, 394, 406, 428, 445, - 446, 447, 332, 316, 422, 317, 352, 318, 295, 324, - 322, 325, 430, 326, 297, 407, 451, 0, 347, 418, - 379, 298, 378, 408, 450, 449, 307, 477, 483, 484, - 573, 0, 489, 661, 662, 663, 498, 0, 413, 0, - 503, 504, 505, 507, 508, 509, 510, 574, 591, 558, - 528, 491, 582, 525, 529, 530, 357, 594, 0, 0, - 0, 482, 367, 368, 0, 339, 338, 380, 416, 345, - 291, 292, 656, 873, 399, 596, 629, 630, 521, 0, - 888, 868, 870, 871, 875, 879, 880, 881, 882, 883, - 885, 887, 891, 655, 0, 575, 590, 659, 589, 652, - 405, 0, 427, 587, 534, 0, 579, 553, 0, 580, - 549, 584, 0, 523, 0, 435, 463, 475, 492, 495, - 524, 609, 610, 611, 296, 494, 613, 614, 615, 616, - 617, 618, 619, 612, 890, 556, 533, 559, 474, 536, - 535, 0, 0, 570, 820, 571, 572, 389, 390, 391, - 392, 877, 597, 314, 493, 415, 0, 557, 0, 0, - 0, 0, 0, 0, 0, 0, 562, 563, 560, 664, - 0, 620, 621, 0, 0, 487, 488, 344, 351, 506, - 353, 313, 404, 346, 472, 361, 0, 499, 564, 500, - 623, 626, 624, 625, 396, 356, 358, 431, 362, 372, - 419, 471, 402, 424, 311, 462, 433, 377, 550, 577, - 899, 872, 898, 900, 901, 897, 902, 903, 884, 775, - 0, 827, 895, 894, 896, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 605, 604, 603, 602, - 601, 600, 599, 598, 0, 0, 547, 448, 323, 285, - 319, 320, 327, 653, 650, 453, 654, 782, 293, 527, - 370, 0, 414, 343, 592, 593, 0, 644, 861, 834, - 835, 836, 772, 837, 831, 832, 773, 833, 862, 825, - 858, 859, 801, 828, 838, 857, 839, 860, 863, 864, - 904, 905, 845, 829, 257, 906, 842, 865, 856, 855, - 840, 826, 866, 867, 808, 803, 843, 844, 830, 849, - 850, 851, 774, 822, 823, 824, 846, 847, 804, 805, - 806, 807, 0, 0, 0, 478, 479, 480, 502, 0, - 464, 526, 651, 0, 0, 0, 0, 0, 0, 0, - 576, 588, 622, 0, 632, 633, 635, 637, 852, 639, - 438, 439, 646, 0, 848, 642, 643, 640, 374, 425, - 444, 432, 818, 657, 517, 518, 658, 628, 0, 767, - 0, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 770, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 809, 568, 519, 434, 385, 586, 585, 0, 0, 878, - 886, 0, 0, 0, 0, 0, 0, 0, 0, 874, - 0, 0, 0, 0, 762, 0, 0, 799, 854, 853, - 786, 796, 0, 0, 309, 229, 514, 634, 516, 515, - 787, 0, 788, 792, 795, 791, 789, 790, 0, 869, - 0, 0, 0, 0, 0, 0, 754, 766, 0, 771, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 763, 764, 0, 0, 0, 0, 819, - 0, 765, 0, 0, 814, 793, 797, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 794, 817, - 821, 330, 892, 815, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 893, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 812, 0, 631, 0, 470, 0, 0, - 876, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 816, 0, 423, 403, 889, 4016, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 873, 399, 596, 629, - 630, 521, 0, 888, 868, 870, 871, 875, 879, 880, - 881, 882, 883, 885, 887, 891, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 890, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 820, 571, 572, - 389, 390, 391, 392, 877, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 899, 872, 898, 900, 901, 897, 902, - 903, 884, 775, 0, 827, 895, 894, 896, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 782, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 861, 834, 835, 836, 772, 837, 831, 832, 773, - 833, 862, 825, 858, 859, 801, 828, 838, 857, 839, - 860, 863, 864, 904, 905, 845, 829, 257, 906, 842, - 865, 856, 855, 840, 826, 866, 867, 808, 803, 843, - 844, 830, 849, 850, 851, 774, 822, 823, 824, 846, - 847, 804, 805, 806, 807, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 852, 639, 438, 439, 646, 0, 848, 642, 643, - 640, 374, 425, 444, 432, 818, 657, 517, 518, 658, - 628, 0, 767, 0, 401, 0, 0, 532, 565, 554, - 638, 520, 0, 0, 0, 0, 0, 0, 770, 0, - 0, 0, 336, 1877, 0, 369, 569, 551, 561, 552, - 537, 538, 539, 546, 348, 540, 541, 542, 512, 543, - 513, 544, 545, 809, 568, 519, 434, 385, 586, 585, - 0, 0, 878, 886, 0, 0, 0, 0, 0, 0, - 0, 0, 874, 0, 0, 0, 0, 762, 0, 0, - 799, 854, 853, 786, 796, 0, 0, 309, 229, 514, - 634, 516, 515, 787, 0, 788, 792, 795, 791, 789, - 790, 0, 869, 0, 0, 0, 0, 0, 0, 754, - 766, 0, 771, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 763, 764, 0, 0, - 0, 0, 819, 0, 765, 0, 0, 814, 793, 797, - 0, 0, 0, 0, 299, 441, 460, 310, 429, 473, - 315, 437, 452, 305, 400, 426, 0, 0, 301, 458, - 436, 382, 359, 360, 300, 0, 420, 334, 350, 331, - 398, 794, 817, 821, 330, 892, 815, 468, 303, 0, - 467, 397, 454, 459, 383, 376, 0, 302, 456, 381, - 375, 363, 340, 893, 364, 365, 354, 409, 373, 410, - 355, 387, 386, 388, 0, 0, 0, 0, 0, 496, - 497, 0, 0, 645, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 627, 812, 0, 631, 0, - 470, 0, 0, 876, 0, 0, 0, 440, 0, 0, - 366, 0, 0, 0, 816, 0, 423, 403, 889, 0, - 0, 421, 371, 455, 411, 461, 442, 469, 417, 412, - 294, 443, 333, 384, 306, 308, 328, 335, 337, 341, - 342, 393, 394, 406, 428, 445, 446, 447, 332, 316, - 422, 317, 352, 318, 295, 324, 322, 325, 430, 326, - 297, 407, 451, 0, 347, 418, 379, 298, 378, 408, - 450, 449, 307, 477, 483, 484, 573, 0, 489, 661, - 662, 663, 498, 0, 413, 0, 503, 504, 505, 507, - 508, 509, 510, 574, 591, 558, 528, 491, 582, 525, - 529, 530, 357, 594, 0, 0, 0, 482, 367, 368, - 0, 339, 338, 380, 416, 345, 291, 292, 656, 873, - 399, 596, 629, 630, 521, 0, 888, 868, 870, 871, - 875, 879, 880, 881, 882, 883, 885, 887, 891, 655, - 0, 575, 590, 659, 589, 652, 405, 0, 427, 587, - 534, 0, 579, 553, 0, 580, 549, 584, 0, 523, - 0, 435, 463, 475, 492, 495, 524, 609, 610, 611, - 296, 494, 613, 614, 615, 616, 617, 618, 619, 612, - 890, 556, 533, 559, 474, 536, 535, 0, 0, 570, - 820, 571, 572, 389, 390, 391, 392, 877, 597, 314, - 493, 415, 0, 557, 0, 0, 0, 0, 0, 0, - 0, 0, 562, 563, 560, 664, 0, 620, 621, 0, - 0, 487, 488, 344, 351, 506, 353, 313, 404, 346, - 472, 361, 0, 499, 564, 500, 623, 626, 624, 625, - 396, 356, 358, 431, 362, 372, 419, 471, 402, 424, - 311, 462, 433, 377, 550, 577, 899, 872, 898, 900, - 901, 897, 902, 903, 884, 775, 0, 827, 895, 894, - 896, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 605, 604, 603, 602, 601, 600, 599, 598, - 0, 0, 547, 448, 323, 285, 319, 320, 327, 653, - 650, 453, 654, 782, 293, 527, 370, 0, 414, 343, - 592, 593, 0, 644, 861, 834, 835, 836, 772, 837, - 831, 832, 773, 833, 862, 825, 858, 859, 801, 828, - 838, 857, 839, 860, 863, 864, 904, 905, 845, 829, - 257, 906, 842, 865, 856, 855, 840, 826, 866, 867, - 808, 803, 843, 844, 830, 849, 850, 851, 774, 822, - 823, 824, 846, 847, 804, 805, 806, 807, 0, 0, - 0, 478, 479, 480, 502, 0, 464, 526, 651, 0, - 0, 0, 0, 0, 0, 0, 576, 588, 622, 0, - 632, 633, 635, 637, 852, 639, 438, 439, 646, 0, - 848, 642, 643, 640, 374, 425, 444, 432, 818, 657, - 517, 518, 658, 628, 0, 767, 0, 401, 0, 0, - 532, 565, 554, 638, 520, 0, 0, 0, 0, 0, - 0, 770, 0, 0, 0, 336, 0, 0, 369, 569, - 551, 561, 552, 537, 538, 539, 546, 348, 540, 541, - 542, 512, 543, 513, 544, 545, 809, 568, 519, 434, - 385, 586, 585, 0, 0, 878, 886, 0, 0, 0, - 0, 0, 0, 0, 0, 874, 0, 0, 0, 0, - 762, 0, 0, 799, 854, 853, 786, 796, 0, 0, - 309, 229, 514, 634, 516, 515, 787, 0, 788, 792, - 795, 791, 789, 790, 0, 869, 0, 0, 0, 0, - 0, 0, 754, 766, 0, 771, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 763, - 764, 1590, 0, 0, 0, 819, 0, 765, 0, 0, - 814, 793, 797, 0, 0, 0, 0, 299, 441, 460, - 310, 429, 473, 315, 437, 452, 305, 400, 426, 0, - 0, 301, 458, 436, 382, 359, 360, 300, 0, 420, - 334, 350, 331, 398, 794, 817, 821, 330, 892, 815, - 468, 303, 0, 467, 397, 454, 459, 383, 376, 0, - 302, 456, 381, 375, 363, 340, 893, 364, 365, 354, - 409, 373, 410, 355, 387, 386, 388, 0, 0, 0, - 0, 0, 496, 497, 0, 0, 645, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 627, 812, - 0, 631, 0, 470, 0, 0, 876, 0, 0, 0, - 440, 0, 0, 366, 0, 0, 0, 816, 0, 423, - 403, 889, 0, 0, 421, 371, 455, 411, 461, 442, - 469, 417, 412, 294, 443, 333, 384, 306, 308, 328, - 335, 337, 341, 342, 393, 394, 406, 428, 445, 446, - 447, 332, 316, 422, 317, 352, 318, 295, 324, 322, - 325, 430, 326, 297, 407, 451, 0, 347, 418, 379, - 298, 378, 408, 450, 449, 307, 477, 483, 484, 573, - 0, 489, 661, 662, 663, 498, 0, 413, 0, 503, - 504, 505, 507, 508, 509, 510, 574, 591, 558, 528, - 491, 582, 525, 529, 530, 357, 594, 0, 0, 0, - 482, 367, 368, 0, 339, 338, 380, 416, 345, 291, - 292, 656, 873, 399, 596, 629, 630, 521, 0, 888, - 868, 870, 871, 875, 879, 880, 881, 882, 883, 885, - 887, 891, 655, 0, 575, 590, 659, 589, 652, 405, - 0, 427, 587, 534, 0, 579, 553, 0, 580, 549, - 584, 0, 523, 0, 435, 463, 475, 492, 495, 524, - 609, 610, 611, 296, 494, 613, 614, 615, 616, 617, - 618, 619, 612, 890, 556, 533, 559, 474, 536, 535, - 0, 0, 570, 820, 571, 572, 389, 390, 391, 392, - 877, 597, 314, 493, 415, 0, 557, 0, 0, 0, - 0, 0, 0, 0, 0, 562, 563, 560, 664, 0, - 620, 621, 0, 0, 487, 488, 344, 351, 506, 353, - 313, 404, 346, 472, 361, 0, 499, 564, 500, 623, - 626, 624, 625, 396, 356, 358, 431, 362, 372, 419, - 471, 402, 424, 311, 462, 433, 377, 550, 577, 899, - 872, 898, 900, 901, 897, 902, 903, 884, 775, 0, - 827, 895, 894, 896, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 605, 604, 603, 602, 601, - 600, 599, 598, 0, 0, 547, 448, 323, 285, 319, - 320, 327, 653, 650, 453, 654, 782, 293, 527, 370, - 0, 414, 343, 592, 593, 0, 644, 861, 834, 835, - 836, 772, 837, 831, 832, 773, 833, 862, 825, 858, - 859, 801, 828, 838, 857, 839, 860, 863, 864, 904, - 905, 845, 829, 257, 906, 842, 865, 856, 855, 840, - 826, 866, 867, 808, 803, 843, 844, 830, 849, 850, - 851, 774, 822, 823, 824, 846, 847, 804, 805, 806, - 807, 0, 0, 0, 478, 479, 480, 502, 0, 464, - 526, 651, 0, 0, 0, 0, 0, 0, 0, 576, - 588, 622, 0, 632, 633, 635, 637, 852, 639, 438, - 439, 646, 0, 848, 642, 643, 640, 374, 425, 444, - 432, 0, 657, 517, 518, 658, 628, 818, 767, 0, - 2269, 0, 0, 0, 0, 0, 401, 0, 0, 532, - 565, 554, 638, 520, 0, 0, 0, 0, 0, 0, - 770, 0, 0, 0, 336, 0, 0, 369, 569, 551, - 561, 552, 537, 538, 539, 546, 348, 540, 541, 542, - 512, 543, 513, 544, 545, 809, 568, 519, 434, 385, - 586, 585, 0, 0, 878, 886, 0, 0, 0, 0, - 0, 0, 0, 0, 874, 0, 0, 0, 0, 762, - 0, 0, 799, 854, 853, 786, 796, 0, 0, 309, - 229, 514, 634, 516, 515, 787, 0, 788, 792, 795, - 791, 789, 790, 0, 869, 0, 0, 0, 0, 0, - 0, 754, 766, 0, 771, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 763, 764, - 0, 0, 0, 0, 819, 0, 765, 0, 0, 814, - 793, 797, 0, 0, 0, 0, 299, 441, 460, 310, - 429, 473, 315, 437, 452, 305, 400, 426, 0, 0, - 301, 458, 436, 382, 359, 360, 300, 0, 420, 334, - 350, 331, 398, 794, 817, 821, 330, 892, 815, 468, - 303, 0, 467, 397, 454, 459, 383, 376, 0, 302, - 456, 381, 375, 363, 340, 893, 364, 365, 354, 409, - 373, 410, 355, 387, 386, 388, 0, 0, 0, 0, - 0, 496, 497, 0, 0, 645, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 627, 812, 0, - 631, 0, 470, 0, 0, 876, 0, 0, 0, 440, - 0, 0, 366, 0, 0, 0, 816, 0, 423, 403, - 889, 0, 0, 421, 371, 455, 411, 461, 442, 469, - 417, 412, 294, 443, 333, 384, 306, 308, 328, 335, - 337, 341, 342, 393, 394, 406, 428, 445, 446, 447, - 332, 316, 422, 317, 352, 318, 295, 324, 322, 325, - 430, 326, 297, 407, 451, 0, 347, 418, 379, 298, - 378, 408, 450, 449, 307, 477, 483, 484, 573, 0, - 489, 661, 662, 663, 498, 0, 413, 0, 503, 504, - 505, 507, 508, 509, 510, 574, 591, 558, 528, 491, - 582, 525, 529, 530, 357, 594, 0, 0, 0, 482, - 367, 368, 0, 339, 338, 380, 416, 345, 291, 292, - 656, 873, 399, 596, 629, 630, 521, 0, 888, 868, - 870, 871, 875, 879, 880, 881, 882, 883, 885, 887, - 891, 655, 0, 575, 590, 659, 589, 652, 405, 0, - 427, 587, 534, 0, 579, 553, 0, 580, 549, 584, - 0, 523, 0, 435, 463, 475, 492, 495, 524, 609, - 610, 611, 296, 494, 613, 614, 615, 616, 617, 618, - 619, 612, 890, 556, 533, 559, 474, 536, 535, 0, - 0, 570, 820, 571, 572, 389, 390, 391, 392, 877, - 597, 314, 493, 415, 0, 557, 0, 0, 0, 0, - 0, 0, 0, 0, 562, 563, 560, 664, 0, 620, - 621, 0, 0, 487, 488, 344, 351, 506, 353, 313, - 404, 346, 472, 361, 0, 499, 564, 500, 623, 626, - 624, 625, 396, 356, 358, 431, 362, 372, 419, 471, - 402, 424, 311, 462, 433, 377, 550, 577, 899, 872, - 898, 900, 901, 897, 902, 903, 884, 775, 0, 827, - 895, 894, 896, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 605, 604, 603, 602, 601, 600, - 599, 598, 0, 0, 547, 448, 323, 285, 319, 320, - 327, 653, 650, 453, 654, 782, 293, 527, 370, 0, - 414, 343, 592, 593, 0, 644, 861, 834, 835, 836, - 772, 837, 831, 832, 773, 833, 862, 825, 858, 859, - 801, 828, 838, 857, 839, 860, 863, 864, 904, 905, - 845, 829, 257, 906, 842, 865, 856, 855, 840, 826, - 866, 867, 808, 803, 843, 844, 830, 849, 850, 851, - 774, 822, 823, 824, 846, 847, 804, 805, 806, 807, - 0, 0, 0, 478, 479, 480, 502, 0, 464, 526, - 651, 0, 0, 0, 0, 0, 0, 0, 576, 588, - 622, 0, 632, 633, 635, 637, 852, 639, 438, 439, - 646, 0, 848, 642, 643, 640, 374, 425, 444, 432, - 818, 657, 517, 518, 658, 628, 0, 767, 0, 401, - 0, 0, 532, 565, 554, 638, 520, 0, 0, 0, - 0, 0, 0, 770, 0, 0, 0, 336, 0, 0, - 369, 569, 551, 561, 552, 537, 538, 539, 546, 348, - 540, 541, 542, 512, 543, 513, 544, 545, 809, 568, - 519, 434, 385, 586, 585, 0, 0, 878, 886, 0, - 0, 0, 0, 0, 0, 0, 0, 874, 0, 0, - 0, 0, 762, 0, 0, 799, 854, 853, 786, 796, - 0, 0, 309, 229, 514, 634, 516, 515, 787, 0, - 788, 792, 795, 791, 789, 790, 0, 869, 0, 0, - 0, 0, 0, 0, 754, 766, 0, 771, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 763, 764, 1870, 0, 0, 0, 819, 0, 765, - 0, 0, 814, 793, 797, 0, 0, 0, 0, 299, - 441, 460, 310, 429, 473, 315, 437, 452, 305, 400, - 426, 0, 0, 301, 458, 436, 382, 359, 360, 300, - 0, 420, 334, 350, 331, 398, 794, 817, 821, 330, - 892, 815, 468, 303, 0, 467, 397, 454, 459, 383, - 376, 0, 302, 456, 381, 375, 363, 340, 893, 364, - 365, 354, 409, 373, 410, 355, 387, 386, 388, 0, - 0, 0, 0, 0, 496, 497, 0, 0, 645, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 627, 812, 0, 631, 0, 470, 0, 0, 876, 0, - 0, 0, 440, 0, 0, 366, 0, 0, 0, 816, - 0, 423, 403, 889, 0, 0, 421, 371, 455, 411, - 461, 442, 469, 417, 412, 294, 443, 333, 384, 306, - 308, 328, 335, 337, 341, 342, 393, 394, 406, 428, - 445, 446, 447, 332, 316, 422, 317, 352, 318, 295, - 324, 322, 325, 430, 326, 297, 407, 451, 0, 347, - 418, 379, 298, 378, 408, 450, 449, 307, 477, 483, - 484, 573, 0, 489, 661, 662, 663, 498, 0, 413, - 0, 503, 504, 505, 507, 508, 509, 510, 574, 591, - 558, 528, 491, 582, 525, 529, 530, 357, 594, 0, - 0, 0, 482, 367, 368, 0, 339, 338, 380, 416, - 345, 291, 292, 656, 873, 399, 596, 629, 630, 521, - 0, 888, 868, 870, 871, 875, 879, 880, 881, 882, - 883, 885, 887, 891, 655, 0, 575, 590, 659, 589, - 652, 405, 0, 427, 587, 534, 0, 579, 553, 0, - 580, 549, 584, 0, 523, 0, 435, 463, 475, 492, - 495, 524, 609, 610, 611, 296, 494, 613, 614, 615, - 616, 617, 618, 619, 612, 890, 556, 533, 559, 474, - 536, 535, 0, 0, 570, 820, 571, 572, 389, 390, - 391, 392, 877, 597, 314, 493, 415, 0, 557, 0, - 0, 0, 0, 0, 0, 0, 0, 562, 563, 560, - 664, 0, 620, 621, 0, 0, 487, 488, 344, 351, - 506, 353, 313, 404, 346, 472, 361, 0, 499, 564, - 500, 623, 626, 624, 625, 396, 356, 358, 431, 362, - 372, 419, 471, 402, 424, 311, 462, 433, 377, 550, - 577, 899, 872, 898, 900, 901, 897, 902, 903, 884, - 775, 0, 827, 895, 894, 896, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 605, 604, 603, - 602, 601, 600, 599, 598, 0, 0, 547, 448, 323, - 285, 319, 320, 327, 653, 650, 453, 654, 782, 293, - 527, 370, 0, 414, 343, 592, 593, 0, 644, 861, - 834, 835, 836, 772, 837, 831, 832, 773, 833, 862, - 825, 858, 859, 801, 828, 838, 857, 839, 860, 863, - 864, 904, 905, 845, 829, 257, 906, 842, 865, 856, - 855, 840, 826, 866, 867, 808, 803, 843, 844, 830, - 849, 850, 851, 774, 822, 823, 824, 846, 847, 804, - 805, 806, 807, 0, 0, 0, 478, 479, 480, 502, - 0, 464, 526, 651, 0, 0, 0, 0, 0, 0, - 0, 576, 588, 622, 0, 632, 633, 635, 637, 852, - 639, 438, 439, 646, 0, 848, 642, 643, 640, 374, - 425, 444, 432, 818, 657, 517, 518, 658, 628, 0, - 767, 0, 401, 0, 0, 532, 565, 554, 638, 520, - 0, 0, 0, 0, 0, 0, 770, 0, 0, 0, - 336, 0, 0, 369, 569, 551, 561, 552, 537, 538, - 539, 546, 348, 540, 541, 542, 512, 543, 513, 544, - 545, 809, 568, 519, 434, 385, 586, 585, 0, 0, - 878, 886, 0, 0, 0, 0, 0, 0, 0, 0, - 874, 0, 0, 0, 0, 762, 0, 0, 799, 854, - 853, 786, 796, 0, 0, 309, 229, 514, 634, 516, - 515, 787, 0, 788, 792, 795, 791, 789, 790, 0, - 869, 0, 0, 0, 0, 0, 0, 754, 766, 0, - 771, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 763, 764, 0, 0, 0, 0, - 819, 0, 765, 0, 0, 814, 793, 797, 0, 0, - 0, 0, 299, 441, 460, 310, 429, 473, 315, 437, - 452, 305, 400, 426, 0, 0, 301, 458, 436, 382, - 359, 360, 300, 0, 420, 334, 350, 331, 398, 794, - 817, 821, 330, 892, 815, 468, 303, 0, 467, 397, - 454, 459, 383, 376, 0, 302, 456, 381, 375, 363, - 340, 893, 364, 365, 354, 409, 373, 410, 355, 387, - 386, 388, 0, 0, 0, 0, 0, 496, 497, 0, - 0, 645, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 627, 812, 0, 631, 0, 470, 0, - 0, 876, 0, 0, 0, 440, 0, 0, 366, 0, - 0, 0, 816, 0, 423, 403, 889, 0, 0, 421, - 371, 455, 411, 461, 442, 469, 417, 412, 294, 443, - 333, 384, 306, 308, 328, 335, 337, 341, 342, 393, - 394, 406, 428, 445, 446, 447, 332, 316, 422, 317, - 352, 318, 295, 324, 322, 325, 430, 326, 297, 407, - 451, 0, 347, 418, 379, 298, 378, 408, 450, 449, - 307, 477, 483, 484, 573, 0, 489, 661, 662, 663, - 498, 0, 413, 0, 503, 504, 505, 507, 508, 509, - 510, 574, 591, 558, 528, 491, 582, 525, 529, 530, - 357, 594, 0, 0, 0, 482, 367, 368, 0, 339, - 338, 380, 416, 345, 291, 292, 656, 873, 399, 596, - 629, 630, 521, 0, 888, 868, 870, 871, 875, 879, - 880, 881, 882, 883, 885, 887, 891, 655, 0, 575, - 590, 659, 589, 652, 405, 0, 427, 587, 534, 0, - 579, 553, 0, 580, 549, 584, 0, 523, 0, 435, - 463, 475, 492, 495, 524, 609, 610, 611, 296, 494, - 613, 614, 615, 616, 617, 618, 619, 612, 890, 556, - 533, 559, 474, 536, 535, 0, 0, 570, 820, 571, - 572, 389, 390, 391, 392, 877, 597, 314, 493, 415, - 0, 557, 0, 0, 0, 0, 0, 0, 0, 0, - 562, 563, 560, 664, 0, 620, 621, 0, 0, 487, - 488, 344, 351, 506, 353, 313, 404, 346, 472, 361, - 0, 499, 564, 500, 623, 626, 624, 625, 396, 356, - 358, 431, 362, 372, 419, 471, 402, 424, 311, 462, - 433, 377, 550, 577, 899, 872, 898, 900, 901, 897, - 902, 903, 884, 775, 0, 827, 895, 894, 896, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 605, 604, 603, 602, 601, 600, 599, 598, 0, 0, - 547, 448, 323, 285, 319, 320, 327, 653, 650, 453, - 654, 782, 293, 527, 370, 0, 414, 343, 592, 593, - 0, 644, 861, 834, 835, 836, 772, 837, 831, 832, - 773, 833, 862, 825, 858, 859, 801, 828, 838, 857, - 839, 860, 863, 864, 904, 905, 845, 829, 257, 906, - 842, 865, 856, 855, 840, 826, 866, 867, 808, 803, - 843, 844, 830, 849, 850, 851, 774, 822, 823, 824, - 846, 847, 804, 805, 806, 807, 0, 0, 0, 478, - 479, 480, 502, 0, 464, 526, 651, 0, 0, 0, - 0, 0, 0, 0, 576, 588, 622, 0, 632, 633, - 635, 637, 852, 639, 438, 439, 646, 0, 848, 642, - 643, 640, 374, 425, 444, 432, 818, 657, 517, 518, - 658, 628, 0, 767, 0, 401, 0, 0, 532, 565, - 554, 638, 520, 0, 0, 0, 0, 0, 0, 770, - 0, 0, 0, 336, 0, 0, 369, 569, 551, 561, - 552, 537, 538, 539, 546, 348, 540, 541, 542, 512, - 543, 513, 544, 545, 809, 568, 519, 434, 385, 586, - 585, 0, 0, 878, 886, 0, 0, 0, 0, 0, - 0, 0, 0, 874, 0, 0, 0, 0, 762, 0, - 0, 799, 854, 853, 786, 796, 0, 0, 309, 229, - 514, 634, 516, 515, 787, 0, 788, 792, 795, 791, - 789, 790, 0, 869, 0, 0, 0, 0, 0, 0, - 754, 766, 0, 771, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 763, 764, 0, - 0, 0, 0, 819, 0, 765, 0, 0, 814, 793, - 797, 0, 0, 0, 0, 299, 441, 460, 310, 429, - 473, 315, 437, 452, 305, 400, 426, 0, 0, 301, - 458, 436, 382, 359, 360, 300, 0, 420, 334, 350, - 331, 398, 794, 817, 821, 330, 892, 815, 468, 303, - 0, 467, 397, 454, 459, 383, 376, 0, 302, 456, - 381, 375, 363, 340, 893, 364, 365, 354, 409, 373, - 410, 355, 387, 386, 388, 0, 0, 0, 0, 0, - 496, 497, 0, 0, 645, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 627, 812, 0, 631, - 0, 470, 0, 0, 876, 0, 0, 0, 440, 0, - 0, 366, 0, 0, 0, 816, 0, 423, 403, 889, - 0, 0, 421, 371, 455, 411, 461, 442, 469, 417, - 412, 294, 443, 333, 384, 306, 308, 328, 335, 337, - 341, 342, 393, 394, 406, 428, 445, 446, 447, 332, - 316, 422, 317, 352, 318, 295, 324, 322, 325, 430, - 326, 297, 407, 451, 0, 347, 418, 379, 298, 378, - 408, 450, 449, 307, 477, 483, 484, 573, 0, 489, - 661, 662, 663, 498, 0, 413, 0, 503, 504, 505, - 507, 508, 509, 510, 574, 591, 558, 528, 491, 582, - 525, 529, 530, 357, 594, 0, 0, 0, 482, 367, - 368, 0, 339, 338, 380, 416, 345, 291, 292, 656, - 873, 399, 596, 629, 630, 521, 0, 888, 868, 870, - 871, 875, 879, 880, 881, 882, 883, 885, 887, 891, - 655, 0, 575, 590, 659, 589, 652, 405, 0, 427, - 587, 534, 0, 579, 553, 0, 580, 549, 584, 0, - 523, 0, 435, 463, 475, 492, 495, 524, 609, 610, - 611, 296, 494, 613, 614, 615, 616, 617, 618, 619, - 612, 890, 556, 533, 559, 474, 536, 535, 0, 0, - 570, 820, 571, 572, 389, 390, 391, 392, 877, 597, - 314, 493, 415, 0, 557, 0, 0, 0, 0, 0, - 0, 0, 0, 562, 563, 560, 664, 0, 620, 621, - 0, 0, 487, 488, 344, 351, 506, 353, 313, 404, - 346, 472, 361, 0, 499, 564, 500, 623, 626, 624, - 625, 396, 356, 358, 431, 362, 372, 419, 471, 402, - 424, 311, 462, 433, 377, 550, 577, 899, 872, 898, - 900, 901, 897, 902, 903, 884, 775, 0, 827, 895, - 894, 896, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 605, 604, 603, 602, 601, 600, 599, - 598, 0, 0, 547, 448, 323, 285, 319, 320, 327, - 653, 650, 453, 654, 782, 293, 527, 370, 0, 414, - 343, 592, 593, 0, 644, 861, 834, 835, 836, 772, - 837, 831, 832, 773, 833, 862, 825, 858, 859, 801, - 828, 838, 857, 839, 860, 863, 864, 904, 905, 845, - 829, 257, 906, 842, 865, 856, 855, 840, 826, 866, - 867, 808, 803, 843, 844, 830, 849, 850, 851, 774, - 822, 823, 824, 846, 847, 804, 805, 806, 807, 0, - 0, 0, 478, 479, 480, 502, 0, 464, 526, 651, - 0, 0, 0, 0, 0, 0, 0, 576, 588, 622, - 0, 632, 633, 635, 637, 852, 639, 438, 439, 646, - 0, 3576, 642, 3577, 3578, 374, 425, 444, 432, 818, - 657, 517, 518, 658, 628, 0, 767, 0, 401, 0, - 0, 532, 565, 554, 638, 520, 0, 0, 0, 0, - 0, 0, 770, 0, 0, 0, 336, 0, 0, 369, - 569, 551, 561, 552, 537, 538, 539, 546, 348, 540, - 541, 542, 512, 543, 513, 544, 545, 809, 568, 519, - 434, 385, 586, 585, 0, 0, 878, 886, 0, 0, - 0, 0, 0, 0, 0, 0, 874, 0, 0, 0, - 0, 762, 0, 0, 799, 854, 853, 786, 796, 0, - 0, 309, 229, 514, 634, 516, 515, 2744, 0, 2745, - 792, 795, 791, 789, 790, 0, 869, 0, 0, 0, - 0, 0, 0, 754, 766, 0, 771, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 763, 764, 0, 0, 0, 0, 819, 0, 765, 0, - 0, 814, 793, 797, 0, 0, 0, 0, 299, 441, - 460, 310, 429, 473, 315, 437, 452, 305, 400, 426, - 0, 0, 301, 458, 436, 382, 359, 360, 300, 0, - 420, 334, 350, 331, 398, 794, 817, 821, 330, 892, - 815, 468, 303, 0, 467, 397, 454, 459, 383, 376, - 0, 302, 456, 381, 375, 363, 340, 893, 364, 365, - 354, 409, 373, 410, 355, 387, 386, 388, 0, 0, - 0, 0, 0, 496, 497, 0, 0, 645, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 627, - 812, 0, 631, 0, 470, 0, 0, 876, 0, 0, - 0, 440, 0, 0, 366, 0, 0, 0, 816, 0, - 423, 403, 889, 0, 0, 421, 371, 455, 411, 461, - 442, 469, 417, 412, 294, 443, 333, 384, 306, 308, - 328, 335, 337, 341, 342, 393, 394, 406, 428, 445, - 446, 447, 332, 316, 422, 317, 352, 318, 295, 324, - 322, 325, 430, 326, 297, 407, 451, 0, 347, 418, - 379, 298, 378, 408, 450, 449, 307, 477, 483, 484, - 573, 0, 489, 661, 662, 663, 498, 0, 413, 0, - 503, 504, 505, 507, 508, 509, 510, 574, 591, 558, - 528, 491, 582, 525, 529, 530, 357, 594, 0, 0, - 0, 482, 367, 368, 0, 339, 338, 380, 416, 345, - 291, 292, 656, 873, 399, 596, 629, 630, 521, 0, - 888, 868, 870, 871, 875, 879, 880, 881, 882, 883, - 885, 887, 891, 655, 0, 575, 590, 659, 589, 652, - 405, 0, 427, 587, 534, 0, 579, 553, 0, 580, - 549, 584, 0, 523, 0, 435, 463, 475, 492, 495, - 524, 609, 610, 611, 296, 494, 613, 614, 615, 616, - 617, 618, 619, 612, 890, 556, 533, 559, 474, 536, - 535, 0, 0, 570, 820, 571, 572, 389, 390, 391, - 392, 877, 597, 314, 493, 415, 0, 557, 0, 0, - 0, 0, 0, 0, 0, 0, 562, 563, 560, 664, - 0, 620, 621, 0, 0, 487, 488, 344, 351, 506, - 353, 313, 404, 346, 472, 361, 0, 499, 564, 500, - 623, 626, 624, 625, 396, 356, 358, 431, 362, 372, - 419, 471, 402, 424, 311, 462, 433, 377, 550, 577, - 899, 872, 898, 900, 901, 897, 902, 903, 884, 775, - 0, 827, 895, 894, 896, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 605, 604, 603, 602, - 601, 600, 599, 598, 0, 0, 547, 448, 323, 285, - 319, 320, 327, 653, 650, 453, 654, 782, 293, 527, - 370, 0, 414, 343, 592, 593, 0, 644, 861, 834, - 835, 836, 772, 837, 831, 832, 773, 833, 862, 825, - 858, 859, 801, 828, 838, 857, 839, 860, 863, 864, - 904, 905, 845, 829, 257, 906, 842, 865, 856, 855, - 840, 826, 866, 867, 808, 803, 843, 844, 830, 849, - 850, 851, 774, 822, 823, 824, 846, 847, 804, 805, - 806, 807, 0, 0, 0, 478, 479, 480, 502, 0, - 464, 526, 651, 0, 0, 0, 0, 0, 0, 0, - 576, 588, 622, 0, 632, 633, 635, 637, 852, 639, - 438, 439, 646, 0, 848, 642, 643, 640, 374, 425, - 444, 432, 818, 657, 517, 518, 658, 628, 0, 767, - 0, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 1735, 0, 0, 0, 770, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 809, 568, 519, 434, 385, 586, 585, 0, 0, 878, - 886, 0, 0, 0, 0, 0, 0, 0, 0, 874, - 0, 0, 0, 0, 762, 0, 0, 799, 854, 853, - 786, 796, 0, 0, 309, 229, 514, 634, 516, 515, - 787, 0, 788, 792, 795, 791, 789, 790, 0, 869, - 0, 0, 0, 0, 0, 0, 0, 766, 0, 771, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 763, 764, 0, 0, 0, 0, 819, - 0, 765, 0, 0, 814, 793, 797, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 794, 817, - 821, 330, 892, 815, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 893, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 812, 0, 631, 0, 470, 0, 0, - 876, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 816, 0, 423, 403, 889, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 1736, 1737, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 873, 399, 596, 629, - 630, 521, 0, 888, 868, 870, 871, 875, 879, 880, - 881, 882, 883, 885, 887, 891, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 890, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 820, 571, 572, - 389, 390, 391, 392, 877, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 899, 872, 898, 900, 901, 897, 902, - 903, 884, 775, 0, 827, 895, 894, 896, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 782, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 861, 834, 835, 836, 772, 837, 831, 832, 773, - 833, 862, 825, 858, 859, 801, 828, 838, 857, 839, - 860, 863, 864, 904, 905, 845, 829, 257, 906, 842, - 865, 856, 855, 840, 826, 866, 867, 808, 803, 843, - 844, 830, 849, 850, 851, 774, 822, 823, 824, 846, - 847, 804, 805, 806, 807, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 852, 639, 438, 439, 646, 0, 848, 642, 643, - 640, 374, 425, 444, 432, 818, 657, 517, 518, 658, - 628, 0, 767, 0, 401, 0, 0, 532, 565, 554, - 638, 520, 0, 0, 0, 0, 0, 0, 770, 0, - 0, 0, 336, 0, 0, 369, 569, 551, 561, 552, - 537, 538, 539, 546, 348, 540, 541, 542, 512, 543, - 513, 544, 545, 809, 568, 519, 434, 385, 586, 585, - 0, 0, 878, 886, 0, 0, 0, 0, 0, 0, - 0, 0, 874, 0, 0, 0, 0, 762, 0, 0, - 799, 854, 853, 786, 796, 0, 0, 309, 229, 514, - 634, 516, 515, 787, 0, 788, 792, 795, 791, 789, - 790, 0, 869, 0, 0, 0, 0, 0, 0, 0, - 766, 0, 771, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 763, 764, 0, 0, - 0, 0, 819, 0, 765, 0, 0, 814, 793, 797, - 0, 0, 0, 0, 299, 441, 460, 310, 429, 473, - 315, 437, 452, 305, 400, 426, 0, 0, 301, 458, - 436, 382, 359, 360, 300, 0, 420, 334, 350, 331, - 398, 794, 817, 821, 330, 892, 815, 468, 303, 0, - 467, 397, 454, 459, 383, 376, 0, 302, 456, 381, - 375, 363, 340, 893, 364, 365, 354, 409, 373, 410, - 355, 387, 386, 388, 0, 0, 0, 0, 0, 496, - 497, 0, 0, 645, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 627, 812, 0, 631, 0, - 470, 0, 0, 876, 0, 0, 0, 440, 0, 0, - 366, 0, 0, 0, 816, 0, 423, 403, 889, 0, - 0, 421, 371, 455, 411, 461, 442, 469, 417, 412, - 294, 443, 333, 384, 306, 308, 328, 335, 337, 341, - 342, 393, 394, 406, 428, 445, 446, 447, 332, 316, - 422, 317, 352, 318, 295, 324, 322, 325, 430, 326, - 297, 407, 451, 0, 347, 418, 379, 298, 378, 408, - 450, 449, 307, 477, 483, 484, 573, 0, 489, 661, - 662, 663, 498, 0, 413, 0, 503, 504, 505, 507, - 508, 509, 510, 574, 591, 558, 528, 491, 582, 525, - 529, 530, 357, 594, 0, 0, 0, 482, 367, 368, - 0, 339, 338, 380, 416, 345, 291, 292, 656, 873, - 399, 596, 629, 630, 521, 0, 888, 868, 870, 871, - 875, 879, 880, 881, 882, 883, 885, 887, 891, 655, - 0, 575, 590, 659, 589, 652, 405, 0, 427, 587, - 534, 0, 579, 553, 0, 580, 549, 584, 0, 523, - 0, 435, 463, 475, 492, 495, 524, 609, 610, 611, - 296, 494, 613, 614, 615, 616, 617, 618, 619, 612, - 890, 556, 533, 559, 474, 536, 535, 0, 0, 570, - 820, 571, 572, 389, 390, 391, 392, 877, 597, 314, - 493, 415, 0, 557, 0, 0, 0, 0, 0, 0, - 0, 0, 562, 563, 560, 664, 0, 620, 621, 0, - 0, 487, 488, 344, 351, 506, 353, 313, 404, 346, - 472, 361, 0, 499, 564, 500, 623, 626, 624, 625, - 396, 356, 358, 431, 362, 372, 419, 471, 402, 424, - 311, 462, 433, 377, 550, 577, 899, 872, 898, 900, - 901, 897, 902, 903, 884, 775, 0, 827, 895, 894, - 896, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 605, 604, 603, 602, 601, 600, 599, 598, - 0, 0, 547, 448, 323, 285, 319, 320, 327, 653, - 650, 453, 654, 782, 293, 527, 370, 0, 414, 343, - 592, 593, 0, 644, 861, 834, 835, 836, 772, 837, - 831, 832, 773, 833, 862, 825, 858, 859, 801, 828, - 838, 857, 839, 860, 863, 864, 904, 905, 845, 829, - 257, 906, 842, 865, 856, 855, 840, 826, 866, 867, - 808, 803, 843, 844, 830, 849, 850, 851, 774, 822, - 823, 824, 846, 847, 804, 805, 806, 807, 0, 0, - 0, 478, 479, 480, 502, 0, 464, 526, 651, 0, - 0, 0, 0, 0, 0, 0, 576, 588, 622, 0, - 632, 633, 635, 637, 852, 639, 438, 439, 646, 0, - 848, 642, 643, 640, 374, 425, 444, 432, 818, 657, - 517, 518, 658, 628, 0, 767, 0, 401, 0, 0, - 532, 565, 554, 638, 520, 0, 0, 0, 0, 0, - 0, 770, 0, 0, 0, 336, 0, 0, 369, 569, - 551, 561, 552, 537, 538, 539, 546, 348, 540, 541, - 542, 512, 543, 513, 544, 545, 809, 568, 519, 434, - 385, 586, 585, 0, 0, 878, 886, 0, 0, 0, - 0, 0, 0, 0, 0, 874, 0, 0, 0, 0, - 0, 0, 0, 799, 854, 853, 786, 796, 0, 0, - 309, 229, 514, 634, 516, 515, 787, 0, 788, 792, - 795, 791, 789, 790, 0, 869, 0, 0, 0, 0, - 0, 0, 754, 766, 0, 771, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 763, - 764, 0, 0, 0, 0, 819, 0, 765, 0, 0, - 814, 793, 797, 0, 0, 0, 0, 299, 441, 460, - 310, 429, 473, 315, 437, 452, 305, 400, 426, 0, - 0, 301, 458, 436, 382, 359, 360, 300, 0, 420, - 334, 350, 331, 398, 794, 817, 821, 330, 892, 815, - 468, 303, 0, 467, 397, 454, 459, 383, 376, 0, - 302, 456, 381, 375, 363, 340, 893, 364, 365, 354, - 409, 373, 410, 355, 387, 386, 388, 0, 0, 0, - 0, 0, 496, 497, 0, 0, 645, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 627, 812, - 0, 631, 0, 470, 0, 0, 876, 0, 0, 0, - 440, 0, 0, 366, 0, 0, 0, 816, 0, 423, - 403, 889, 0, 0, 421, 371, 455, 411, 461, 442, - 469, 417, 412, 294, 443, 333, 384, 306, 308, 328, - 335, 337, 341, 342, 393, 394, 406, 428, 445, 446, - 447, 332, 316, 422, 317, 352, 318, 295, 324, 322, - 325, 430, 326, 297, 407, 451, 0, 347, 418, 379, - 298, 378, 408, 450, 449, 307, 477, 483, 484, 573, - 0, 489, 661, 662, 663, 498, 0, 413, 0, 503, - 504, 505, 507, 508, 509, 510, 574, 591, 558, 528, - 491, 582, 525, 529, 530, 357, 594, 0, 0, 0, - 482, 367, 368, 0, 339, 338, 380, 416, 345, 291, - 292, 656, 873, 399, 596, 629, 630, 521, 0, 888, - 868, 870, 871, 875, 879, 880, 881, 882, 883, 885, - 887, 891, 655, 0, 575, 590, 659, 589, 652, 405, - 0, 427, 587, 534, 0, 579, 553, 0, 580, 549, - 584, 0, 523, 0, 435, 463, 475, 492, 495, 524, - 609, 610, 611, 296, 494, 613, 614, 615, 616, 617, - 618, 619, 612, 890, 556, 533, 559, 474, 536, 535, - 0, 0, 570, 820, 571, 572, 389, 390, 391, 392, - 877, 597, 314, 493, 415, 0, 557, 0, 0, 0, - 0, 0, 0, 0, 0, 562, 563, 560, 664, 0, - 620, 621, 0, 0, 487, 488, 344, 351, 506, 353, - 313, 404, 346, 472, 361, 0, 499, 564, 500, 623, - 626, 624, 625, 396, 356, 358, 431, 362, 372, 419, - 471, 402, 424, 311, 462, 433, 377, 550, 577, 899, - 872, 898, 900, 901, 897, 902, 903, 884, 775, 0, - 827, 895, 894, 896, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 605, 604, 603, 602, 601, - 600, 599, 598, 0, 0, 547, 448, 323, 285, 319, - 320, 327, 653, 650, 453, 654, 782, 293, 527, 370, - 0, 414, 343, 592, 593, 0, 644, 861, 834, 835, - 836, 772, 837, 831, 832, 773, 833, 862, 825, 858, - 859, 801, 828, 838, 857, 839, 860, 863, 864, 904, - 905, 845, 829, 257, 906, 842, 865, 856, 855, 840, - 826, 866, 867, 808, 803, 843, 844, 830, 849, 850, - 851, 774, 822, 823, 824, 846, 847, 804, 805, 806, - 807, 0, 0, 0, 478, 479, 480, 502, 0, 464, - 526, 651, 0, 0, 0, 0, 0, 0, 0, 576, - 588, 622, 0, 632, 633, 635, 637, 852, 639, 438, - 439, 646, 0, 848, 642, 643, 640, 374, 425, 444, - 432, 0, 657, 517, 518, 658, 628, 0, 767, 206, - 64, 197, 168, 0, 0, 0, 0, 0, 0, 401, - 0, 0, 532, 565, 554, 638, 520, 0, 198, 0, - 0, 0, 0, 0, 0, 189, 0, 336, 0, 199, - 369, 569, 551, 561, 552, 537, 538, 539, 546, 348, - 540, 541, 542, 512, 543, 513, 544, 545, 140, 568, - 519, 434, 385, 586, 585, 0, 0, 0, 0, 0, + 1749, 1750, 1984, 1874, 1913, 3162, 1762, 1763, 2252, 1923, + 1880, 1261, 1262, 1263, 1260, 3160, 3927, 2519, 1259, 2102, + 2103, 2254, 3037, 1939, 3915, 2755, 1830, 1830, 2178, 1948, + 3862, 1958, 1959, 914, 915, 916, 917, 1914, 1830, 1830, + 2079, 2650, 2081, 1955, 2637, 2195, 1949, 1950, 1968, 1969, + 2210, 1966, 3861, 2100, 2101, 1839, 2074, 3128, 2088, 2119, + 2120, 2121, 1967, 1944, 1943, 3856, 2095, 1973, 1979, 2144, + 1976, 1977, 2147, 2148, 1972, 2150, 1468, 1185, 1947, 1957, + 2189, 3855, 1554, 2208, 3854, 1963, 3853, 1985, 1986, 2219, + 1472, 2116, 2418, 2421, 1915, 1916, 1917, 3916, 2180, 2391, + 2055, 2404, 1472, 3863, 3833, 2320, 1930, 1931, 1932, 1933, + 2314, 2313, 2285, 1980, 1982, 2418, 2421, 2049, 2201, 2105, + 1962, 2058, 1964, 1965, 2132, 2377, 2060, 3832, 1223, 2054, + 1445, 1644, 1768, 1540, 2202, 4143, 1971, 3447, 2254, 3805, + 3552, 2089, 2078, 4126, 2080, 3487, 3500, 2185, 3041, 914, + 915, 916, 917, 1712, 2254, 2846, 698, 2254, 3465, 2254, + 2663, 1510, 1511, 2662, 1513, 1514, 3407, 1518, 1519, 1520, + 3403, 2173, 1067, 2114, 1069, 1983, 2115, 2219, 2122, 2123, + 2654, 2398, 2273, 2173, 1067, 919, 1069, 2258, 2233, 3309, + 1261, 1262, 1263, 1260, 1070, 2141, 3012, 1070, 2200, 2741, + 2219, 1569, 1570, 1571, 1572, 1573, 1070, 1575, 1576, 1577, + 1578, 1579, 2254, 2551, 2139, 1585, 1586, 1587, 1588, 3501, + 2158, 1261, 1262, 1263, 1260, 3735, 1374, 2729, 2422, 2073, + 1565, 3466, 2721, 2417, 2411, 2416, 2390, 2414, 2419, 3408, + 2125, 1664, 3550, 3404, 2179, 2676, 2658, 1310, 1947, 2406, + 2646, 2422, 2639, 2188, 2186, 2191, 2417, 2411, 2416, 1208, + 2414, 2419, 3310, 2634, 1172, 1167, 1292, 2250, 2199, 2519, + 2325, 2326, 2377, 2329, 2626, 2104, 2332, 2624, 2622, 2286, + 2287, 1067, 2289, 1069, 2620, 1276, 2376, 2338, 2316, 2296, + 2292, 2203, 2420, 752, 2291, 934, 674, 674, 674, 697, + 1259, 919, 2276, 1070, 2308, 1259, 2216, 693, 1819, 1818, + 2256, 674, 674, 674, 674, 2420, 1819, 1818, 1259, 2377, + 2197, 3252, 3920, 2635, 2374, 2640, 2241, 2267, 2266, 3672, + 695, 2265, 754, 2378, 2379, 2380, 2635, 2383, 1517, 696, + 3243, 3088, 2232, 2255, 2234, 2218, 1673, 2627, 2235, 2236, + 2625, 2621, 1454, 3479, 694, 1469, 1455, 2621, 2246, 2377, + 1544, 2315, 1753, 1259, 1517, 2198, 3921, 1259, 1101, 1102, + 1103, 1545, 2612, 3673, 1542, 1259, 1845, 1846, 1847, 1848, + 3477, 2440, 1852, 1853, 1854, 1855, 1857, 1858, 1859, 1860, + 1861, 1862, 1863, 1864, 1865, 1866, 1867, 3480, 787, 797, + 1259, 1259, 1100, 3042, 1259, 1097, 3362, 4137, 788, 1500, + 789, 793, 796, 792, 790, 791, 2254, 4098, 2219, 1674, + 2446, 3244, 1856, 3897, 3478, 2395, 3804, 3762, 2447, 2397, + 1849, 2399, 1279, 1280, 1281, 1282, 1283, 1276, 3701, 674, + 1981, 1759, 3700, 3686, 3645, 3457, 3332, 941, 2523, 2523, + 2072, 2523, 3323, 2309, 2311, 2312, 3315, 1756, 1758, 1755, + 3311, 1757, 3221, 794, 2971, 3245, 1261, 1262, 1263, 1260, + 2683, 650, 650, 2317, 2237, 2238, 1470, 3365, 1541, 1188, + 1772, 2400, 2970, 2812, 2760, 1554, 674, 1277, 1278, 1279, + 1280, 1281, 1282, 1283, 1276, 2344, 795, 2673, 2638, 674, + 2410, 2542, 2183, 2409, 2606, 1188, 2595, 668, 1261, 1262, + 1263, 1260, 1454, 1593, 1333, 2072, 1455, 2182, 2602, 2616, + 2604, 2181, 2142, 223, 1267, 1268, 1269, 1270, 1271, 1272, + 1273, 1265, 2403, 1441, 2385, 2386, 1440, 1190, 2384, 2392, + 1261, 1262, 1263, 1260, 2388, 2389, 1263, 1260, 1598, 2527, + 2537, 1909, 2538, 1107, 1108, 2525, 3977, 2529, 1112, 1772, + 1598, 2247, 2142, 2642, 2396, 1094, 1095, 1096, 1099, 1260, + 1098, 2543, 2544, 2546, 2652, 2653, 3713, 3712, 3059, 1334, + 2531, 2656, 2423, 2424, 2208, 2429, 1261, 1262, 1263, 1260, + 2907, 1554, 1472, 1554, 2905, 1554, 1067, 2884, 1069, 2882, + 1188, 3692, 2553, 3646, 3647, 2559, 4108, 4133, 2675, 1312, + 1834, 2743, 2607, 2744, 2601, 4107, 2387, 4106, 1070, 2811, + 4129, 2393, 1311, 4104, 2394, 1835, 4103, 4041, 1261, 1262, + 1263, 1260, 4009, 2492, 1554, 1188, 2498, 3363, 1536, 2707, + 1261, 1262, 1263, 1260, 4008, 3922, 3639, 2532, 2780, 2685, + 1261, 1262, 1263, 1260, 2714, 3858, 3846, 3836, 3121, 1554, + 1274, 1284, 1285, 1277, 1278, 1279, 1280, 1281, 1282, 1283, + 1276, 2452, 4132, 3445, 2455, 2456, 2457, 2458, 2459, 2460, + 2461, 2666, 2547, 2464, 2465, 2466, 2467, 2468, 2469, 2470, + 2471, 2472, 2473, 2474, 3826, 2476, 2477, 2478, 2479, 2480, + 2670, 2481, 2118, 2550, 2600, 3107, 3640, 2599, 2762, 2763, + 2596, 3753, 2766, 3675, 2718, 2719, 1261, 1262, 1263, 1260, + 2702, 3120, 1552, 3674, 2687, 2608, 2687, 1188, 2959, 1261, + 1262, 1263, 1260, 3446, 1554, 2957, 2955, 1517, 1599, 2269, + 2672, 2691, 2944, 1517, 2052, 2715, 3492, 1552, 1261, 1262, + 1263, 1260, 2842, 2713, 2667, 3481, 2681, 2705, 2848, 3444, + 3211, 2849, 1284, 1285, 1277, 1278, 1279, 1280, 1281, 1282, + 1283, 1276, 3084, 2659, 3054, 3053, 2657, 2942, 2941, 2859, + 2747, 2664, 2648, 1261, 1262, 1263, 1260, 2940, 2958, 1188, + 2932, 2926, 1712, 1533, 1535, 2956, 2954, 2881, 2925, 2924, + 2677, 2678, 2943, 2923, 1188, 1188, 1188, 1981, 2756, 2268, + 1188, 2628, 2891, 2892, 2893, 2894, 1188, 2901, 2693, 2902, + 2903, 2824, 2904, 2703, 2906, 2539, 2826, 2559, 4019, 2319, + 2161, 2160, 2680, 2159, 2155, 2901, 1261, 1262, 1263, 1260, + 2154, 2111, 1899, 3451, 3614, 2839, 1897, 2523, 2829, 2860, + 1261, 1262, 1263, 1260, 2809, 1261, 1262, 1263, 1260, 3456, + 2825, 2960, 1665, 1392, 2003, 3198, 4127, 3602, 3797, 3798, + 650, 1261, 1262, 1263, 1260, 4109, 3590, 2862, 2052, 4096, + 4058, 4057, 1188, 2072, 2072, 2072, 2072, 2072, 2072, 2876, + 1170, 2791, 4054, 2793, 1261, 1262, 1263, 1260, 3983, 1188, + 2072, 2850, 3982, 2523, 2876, 2887, 2888, 2251, 2965, 3783, + 2890, 2879, 2875, 2790, 1070, 2879, 2897, 2807, 3963, 3907, + 3650, 1554, 747, 3020, 3901, 749, 3601, 2886, 2832, 2841, + 748, 2847, 674, 674, 8, 1923, 7, 1275, 1274, 1284, + 1285, 1277, 1278, 1279, 1280, 1281, 1282, 1283, 1276, 1169, + 3882, 3873, 2851, 1261, 1262, 1263, 1260, 2864, 2861, 2724, + 2725, 2856, 2857, 2852, 3850, 2730, 2877, 3845, 2855, 3844, + 2883, 3801, 3787, 3785, 2889, 3754, 3540, 3694, 3654, 3008, + 3643, 4135, 2988, 3628, 3627, 1261, 1262, 1263, 1260, 223, + 3623, 3621, 3619, 2976, 223, 3395, 2716, 3616, 3613, 2988, + 2922, 3124, 3021, 1261, 1262, 1263, 1260, 2934, 3612, 3588, + 3586, 3837, 3559, 3556, 2798, 3554, 1830, 2964, 1830, 3441, + 2070, 3069, 1261, 1262, 1263, 1260, 3123, 3423, 1261, 1262, + 1263, 1260, 799, 142, 3038, 3083, 2966, 3416, 142, 2972, + 3400, 1554, 3398, 3393, 3090, 2858, 3343, 2989, 2990, 2991, + 2992, 2993, 2994, 1261, 1262, 1263, 1260, 3321, 3005, 3320, + 3318, 3009, 3317, 3011, 3010, 1275, 1274, 1284, 1285, 1277, + 1278, 1279, 1280, 1281, 1282, 1283, 1276, 3312, 3043, 3028, + 3025, 3307, 3306, 3047, 1618, 673, 673, 2880, 1264, 3222, + 3184, 681, 3122, 3183, 1619, 1620, 1294, 2874, 1876, 1625, + 1626, 680, 3174, 3068, 142, 1304, 2740, 2249, 3172, 3169, + 2914, 2915, 3167, 2739, 2324, 3098, 3095, 3064, 3951, 1261, + 1262, 1263, 1260, 3074, 3052, 2930, 2931, 1630, 3066, 3076, + 1634, 1313, 1633, 1261, 1262, 1263, 1260, 3027, 2953, 3077, + 1261, 1262, 1263, 1260, 2261, 3045, 3171, 3044, 2945, 2935, + 2967, 2933, 2929, 3175, 3176, 3177, 3179, 2928, 3181, 3182, + 3092, 3065, 2927, 3062, 2769, 3060, 2761, 1188, 3080, 3067, + 2738, 2757, 2649, 1188, 3079, 2737, 3078, 855, 854, 3201, + 3087, 2339, 2333, 1070, 3086, 1261, 1262, 1263, 1260, 3215, + 3099, 2330, 2969, 3100, 674, 1070, 2164, 1261, 1262, 1263, + 1260, 2157, 1261, 1262, 1263, 1260, 1887, 3119, 3232, 1188, + 3106, 1886, 674, 1666, 674, 1188, 1188, 3110, 3111, 4084, + 3113, 3115, 3116, 1341, 2072, 2374, 1337, 3251, 3112, 1336, + 3114, 1173, 923, 3939, 3935, 1068, 3779, 3778, 3767, 3763, + 142, 1261, 1262, 1263, 1260, 3615, 3597, 2440, 3569, 3225, + 3161, 2736, 3472, 3471, 681, 142, 3469, 142, 3438, 3277, + 2735, 3280, 3412, 3280, 3280, 3410, 3409, 3187, 1188, 3406, + 3405, 3399, 3166, 2876, 3228, 3165, 3397, 3378, 1261, 1262, + 1263, 1260, 2824, 3368, 3367, 3354, 3302, 1261, 1262, 1263, + 1260, 3353, 3253, 3188, 3185, 1554, 1554, 3298, 3203, 2734, + 3159, 3264, 3266, 206, 3255, 197, 168, 2733, 3126, 2876, + 3117, 2732, 3109, 3235, 3108, 2876, 2876, 3102, 3036, 3240, + 2623, 2619, 2618, 3249, 2297, 2290, 1261, 1262, 1263, 1260, + 2284, 2283, 2282, 3224, 1261, 1262, 1263, 1260, 1261, 1262, + 1263, 1260, 674, 3234, 2281, 2279, 3260, 3250, 3201, 3238, + 3239, 3275, 3246, 2275, 3276, 1067, 2274, 1069, 2272, 2263, + 2260, 1517, 2259, 3285, 2052, 2052, 3259, 2163, 2876, 1870, + 1869, 2410, 1868, 1833, 2409, 1832, 202, 1070, 1823, 1070, + 1566, 3303, 3304, 1552, 1552, 1070, 2731, 206, 3133, 3134, + 1564, 3286, 3281, 3282, 3135, 3136, 3137, 3138, 3300, 3139, + 3140, 3141, 3142, 3143, 3144, 3145, 3146, 3147, 3148, 3149, + 2728, 4083, 1070, 1261, 1262, 1263, 1260, 4040, 1188, 3957, + 1331, 3934, 2707, 2679, 1592, 3868, 3258, 3254, 3865, 3852, + 3366, 3847, 3256, 3257, 3748, 3747, 3729, 1261, 1262, 1263, + 1260, 3711, 3707, 3685, 3669, 3308, 3570, 1275, 1274, 1284, + 1285, 1277, 1278, 1279, 1280, 1281, 1282, 1283, 1276, 3567, + 202, 3538, 3328, 3329, 3537, 3534, 3533, 3314, 3313, 3499, + 1287, 3319, 1291, 3322, 3683, 3496, 3316, 674, 3326, 2727, + 3494, 3459, 4076, 2726, 3118, 3339, 1613, 3340, 1288, 1290, + 1286, 1624, 1289, 1275, 1274, 1284, 1285, 1277, 1278, 1279, + 1280, 1281, 1282, 1283, 1276, 3347, 1261, 1262, 1263, 1260, + 1261, 1262, 1263, 1260, 3350, 3351, 3352, 2720, 2559, 1615, + 1629, 1632, 1621, 1448, 2999, 2961, 3356, 2885, 1275, 1274, + 1284, 1285, 1277, 1278, 1279, 1280, 1281, 1282, 1283, 1276, + 3007, 2710, 2835, 2834, 1261, 1262, 1263, 1260, 2827, 2792, + 2136, 3420, 2742, 2633, 3422, 3379, 3283, 3681, 3424, 2706, + 2541, 2482, 3330, 3430, 2375, 3382, 2346, 3381, 1261, 1262, + 1263, 1260, 2345, 2318, 1754, 202, 2124, 1883, 3401, 2682, + 3386, 1697, 2687, 1647, 3346, 1622, 1261, 1262, 1263, 1260, + 1391, 1376, 1724, 1725, 1726, 1727, 1728, 3391, 674, 2052, + 3431, 3425, 1372, 3427, 3385, 3509, 1261, 1262, 1263, 1260, + 3464, 1275, 1274, 1284, 1285, 1277, 1278, 1279, 1280, 1281, + 1282, 1283, 1276, 1371, 1370, 1369, 1368, 2523, 2072, 3484, + 1367, 1366, 1365, 1364, 1769, 1363, 1362, 1361, 1773, 1774, + 1775, 1776, 1360, 1359, 1358, 1357, 3521, 1356, 1814, 3949, + 1355, 3419, 3502, 3417, 1354, 1188, 1824, 3413, 1353, 3512, + 1767, 1352, 3435, 1351, 3277, 1350, 1349, 1348, 1188, 1347, + 3507, 3434, 3437, 1344, 1343, 3529, 3530, 1342, 1340, 3440, + 1188, 3508, 3549, 1339, 1338, 1335, 1554, 1261, 1262, 1263, + 1260, 3486, 673, 1177, 1328, 1327, 1325, 3454, 1324, 1323, + 1322, 3452, 1321, 1186, 1320, 1319, 674, 1318, 2052, 1877, + 1317, 1316, 1188, 1315, 1314, 1309, 3532, 1308, 3513, 1307, + 142, 142, 142, 1068, 1306, 1305, 1214, 3483, 1225, 1171, + 3335, 3336, 3947, 3482, 3945, 3525, 3535, 3489, 1070, 2382, + 2360, 1213, 4074, 4024, 223, 1070, 3338, 2813, 2552, 2166, + 1224, 3002, 3345, 2997, 3560, 3503, 3003, 1188, 3563, 3539, + 3000, 3344, 3544, 3541, 2996, 3001, 3341, 3004, 3542, 2513, + 2514, 3548, 3551, 3574, 1552, 3006, 2995, 3572, 3976, 125, + 2897, 67, 3555, 3553, 66, 3573, 3884, 3557, 3558, 3690, + 3562, 1951, 2647, 2636, 3576, 3564, 1293, 3565, 1442, 3617, + 1941, 1942, 1936, 1937, 1938, 3220, 3273, 3082, 3274, 3561, + 3625, 2450, 2988, 3595, 3383, 3384, 3528, 1970, 2416, 3545, + 1188, 3357, 2040, 1607, 2631, 3485, 2652, 2653, 3196, 2671, + 1661, 1641, 2340, 3581, 3488, 3571, 3611, 3591, 3592, 2126, + 1188, 1554, 1554, 3517, 1219, 3189, 2863, 3232, 676, 3622, + 677, 3624, 2836, 678, 2402, 2370, 1945, 2988, 1912, 3663, + 1819, 1818, 3663, 1387, 1388, 3514, 3518, 3516, 3515, 1385, + 1386, 1383, 1384, 1381, 1382, 1188, 1877, 1188, 3679, 3651, + 4087, 1877, 1877, 3657, 3658, 3682, 3849, 3684, 3460, 3461, + 3462, 3305, 2495, 2488, 1554, 3467, 3468, 3633, 3635, 2053, + 3644, 3634, 1509, 3653, 1508, 1252, 3523, 3524, 2184, 3349, + 3030, 3630, 674, 2341, 1188, 1188, 2196, 3656, 1188, 1188, + 2876, 1461, 3668, 1460, 3486, 1433, 3667, 3652, 1484, 1552, + 1765, 2143, 3678, 2180, 2146, 4047, 4045, 2149, 4002, 3688, + 2151, 3973, 3726, 3731, 3972, 1380, 3532, 3970, 1947, 3911, + 3691, 3740, 3660, 3715, 3716, 3695, 3869, 3727, 3728, 3743, + 3531, 3742, 3680, 3749, 3750, 3525, 3587, 3402, 3375, 3374, + 3360, 2435, 3510, 2405, 1663, 1718, 1554, 1718, 3522, 3493, + 3359, 3495, 1765, 3040, 3737, 1458, 4078, 4077, 2508, 2512, + 2513, 2514, 2509, 2517, 2510, 2515, 2194, 3736, 2511, 3780, + 2516, 3421, 3085, 2767, 3738, 2262, 1395, 1210, 4077, 4078, + 3709, 3773, 3355, 1185, 914, 915, 916, 917, 1070, 1185, + 210, 3, 1476, 75, 2, 4100, 4101, 3760, 3756, 1, + 2748, 1881, 1389, 918, 913, 1530, 3806, 2533, 3784, 3768, + 3786, 2106, 3772, 1558, 1885, 920, 3813, 3013, 3014, 3789, + 3818, 3348, 3811, 3016, 2770, 2215, 1512, 2977, 3676, 3677, + 2486, 2350, 3761, 1523, 1552, 3603, 1188, 3604, 3214, 1443, + 975, 1825, 1678, 1202, 3800, 1675, 3835, 1201, 1199, 3841, + 1770, 801, 2169, 2962, 1560, 2936, 3739, 4086, 4121, 3812, + 4039, 4089, 3595, 2242, 1695, 785, 3964, 3815, 3814, 1563, + 3874, 2243, 4043, 680, 3827, 2248, 3831, 3876, 3527, 3759, + 1188, 2220, 1257, 2257, 3061, 1554, 1002, 1275, 1274, 1284, + 1285, 1277, 1278, 1279, 1280, 1281, 1282, 1283, 1276, 842, + 812, 1326, 1654, 3848, 3131, 3129, 811, 3449, 2803, 142, + 3744, 3033, 3820, 1003, 3809, 2152, 3871, 3757, 1608, 3857, + 2264, 1612, 2401, 3828, 3930, 3689, 3269, 2871, 2271, 1636, + 3925, 3497, 3607, 3605, 3606, 717, 1718, 2085, 648, 1052, + 3730, 3903, 2165, 3890, 718, 2381, 3989, 3851, 3870, 955, + 2288, 3866, 3867, 3432, 3526, 2293, 2294, 2295, 2359, 956, + 2298, 2299, 2300, 2301, 2302, 2303, 2304, 2305, 2306, 2307, + 3912, 3859, 3898, 1552, 3899, 948, 2822, 142, 2821, 3733, + 1070, 3900, 1735, 3734, 142, 3687, 1266, 1752, 3150, 3127, + 3151, 1303, 3906, 756, 2245, 3693, 2800, 142, 3914, 3929, + 142, 142, 3520, 1188, 3026, 74, 73, 72, 71, 231, + 803, 1554, 230, 142, 3954, 3781, 3648, 3960, 3923, 3961, + 3944, 3946, 3948, 3950, 4091, 782, 781, 3928, 780, 3732, + 779, 3962, 2501, 3937, 778, 777, 2506, 2507, 2505, 2503, + 2502, 2067, 3943, 1275, 1274, 1284, 1285, 1277, 1278, 1279, + 1280, 1281, 1282, 1283, 1276, 2066, 3039, 3358, 3969, 3967, + 2131, 2133, 3230, 2900, 1554, 2895, 1992, 3818, 1990, 2508, + 2512, 2513, 2514, 2509, 2517, 2510, 2515, 3981, 1521, 2511, + 2430, 2516, 2437, 4012, 1989, 4021, 3392, 3598, 3984, 4020, + 3940, 4003, 3941, 3706, 2946, 4005, 3594, 3953, 1935, 1552, + 2426, 2009, 2917, 4006, 4007, 2006, 2005, 2908, 3702, 3696, + 2037, 3816, 3662, 3504, 3505, 3511, 2369, 1121, 1117, 1119, + 4036, 4029, 1120, 4030, 1118, 4031, 2692, 4032, 3324, 2407, + 4033, 3191, 4046, 2786, 4048, 4049, 2785, 2783, 2782, 1418, + 3902, 3985, 4044, 4042, 3629, 2557, 2555, 1168, 3337, 4052, + 4004, 3890, 1552, 1188, 3333, 2177, 3342, 2998, 2192, 3081, + 2068, 2064, 2063, 1092, 1091, 1589, 2979, 2496, 3860, 3791, + 4053, 1940, 3841, 949, 4066, 2357, 109, 41, 122, 108, + 4068, 4067, 1877, 4069, 1877, 185, 59, 4075, 4073, 4085, + 184, 4093, 4072, 58, 4092, 120, 4079, 4080, 4081, 4082, + 182, 57, 103, 1877, 1877, 102, 119, 180, 56, 4097, + 4105, 215, 214, 217, 216, 213, 1188, 2609, 2610, 212, + 1596, 211, 3974, 3666, 1929, 3956, 4110, 908, 3929, 1934, + 4113, 4111, 44, 43, 4119, 1592, 186, 42, 110, 4123, + 60, 40, 39, 38, 34, 3913, 4120, 13, 12, 35, + 22, 3917, 3918, 4064, 21, 1682, 20, 26, 32, 31, + 135, 134, 30, 133, 132, 131, 130, 129, 128, 4131, + 127, 29, 19, 51, 50, 49, 4093, 4139, 48, 4092, + 4138, 47, 3938, 46, 2641, 9, 2644, 123, 4123, 4140, + 118, 116, 28, 117, 4144, 114, 115, 113, 112, 111, + 106, 1987, 1988, 104, 86, 85, 84, 99, 98, 97, + 96, 95, 94, 92, 93, 1001, 1718, 83, 82, 81, + 80, 79, 101, 107, 105, 90, 100, 2071, 91, 89, + 88, 87, 78, 77, 76, 166, 165, 164, 163, 162, + 160, 161, 159, 158, 157, 156, 155, 154, 52, 53, + 2684, 54, 55, 2690, 176, 206, 64, 197, 168, 175, + 2113, 177, 179, 181, 2708, 2709, 2113, 2113, 2113, 178, + 183, 173, 2711, 2712, 198, 171, 174, 172, 170, 69, + 11, 189, 121, 18, 4, 199, 0, 0, 2717, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 142, 0, 140, 142, 142, 0, 142, 0, + 0, 0, 0, 0, 0, 0, 0, 1724, 1877, 126, + 0, 0, 0, 4055, 4056, 0, 0, 0, 202, 0, + 4060, 4061, 4062, 4063, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1068, 0, + 0, 142, 0, 0, 0, 0, 0, 0, 0, 0, + 1068, 0, 0, 0, 0, 0, 1140, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 142, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 2853, 2854, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 148, 149, 0, 150, 151, + 0, 0, 0, 152, 0, 0, 153, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 206, 64, 197, 168, 0, + 0, 0, 0, 0, 1261, 1262, 1263, 1260, 0, 0, + 0, 0, 0, 0, 198, 0, 0, 1293, 0, 0, + 0, 189, 0, 0, 0, 199, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 167, + 195, 204, 196, 124, 140, 0, 0, 0, 0, 0, + 1125, 1803, 0, 0, 0, 0, 0, 0, 0, 126, + 0, 0, 194, 188, 187, 0, 0, 0, 202, 70, + 0, 1148, 1152, 1154, 1156, 1158, 1159, 1161, 0, 1166, + 1162, 1163, 1164, 1165, 1803, 1143, 1144, 1145, 1146, 1123, + 1124, 1149, 0, 1126, 1877, 1128, 1129, 1130, 1131, 1127, + 1132, 1133, 1134, 1135, 1136, 1139, 1141, 1137, 1138, 1147, + 0, 0, 0, 0, 0, 0, 0, 1151, 1153, 1155, + 1157, 1160, 0, 0, 0, 0, 0, 0, 0, 0, + 190, 191, 192, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 148, 149, 0, 150, 151, + 0, 0, 0, 152, 0, 0, 153, 1142, 0, 0, + 0, 0, 0, 0, 0, 0, 2347, 2348, 2349, 0, + 200, 0, 0, 0, 0, 3046, 0, 3048, 0, 0, + 0, 2365, 2366, 2367, 2368, 0, 0, 0, 0, 0, + 0, 136, 0, 0, 0, 193, 1877, 137, 0, 0, + 0, 1877, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 2194, 0, 0, 0, 0, 0, 167, + 195, 204, 196, 124, 0, 0, 1799, 0, 0, 0, + 0, 0, 0, 1796, 0, 0, 0, 1798, 1795, 1797, + 1801, 1802, 194, 188, 187, 1800, 0, 0, 3101, 70, + 0, 0, 0, 0, 138, 0, 0, 0, 0, 1799, + 0, 0, 0, 0, 0, 0, 1796, 63, 0, 0, + 1798, 1795, 1797, 1801, 1802, 0, 3125, 2038, 1800, 0, + 0, 0, 1999, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 2688, 2689, 0, 0, 1523, + 190, 191, 192, 2040, 2008, 0, 65, 0, 0, 0, + 0, 0, 0, 2041, 2042, 0, 0, 0, 0, 0, + 0, 0, 2526, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 2007, + 200, 146, 203, 0, 147, 0, 1560, 0, 0, 169, + 0, 0, 0, 0, 61, 0, 0, 2015, 0, 2113, + 0, 136, 0, 0, 0, 193, 0, 137, 1784, 1785, + 1786, 1787, 1788, 1789, 1790, 1791, 1792, 1793, 1794, 1806, + 1807, 1808, 1809, 1810, 1811, 1804, 1805, 2071, 0, 0, + 0, 0, 0, 0, 0, 142, 0, 0, 0, 0, + 0, 1784, 1785, 1786, 1787, 1788, 1789, 1790, 1791, 1792, + 1793, 1794, 1806, 1807, 1808, 1809, 1810, 1811, 1804, 1805, + 139, 45, 0, 0, 138, 2031, 0, 62, 0, 0, + 0, 5, 0, 0, 0, 0, 0, 63, 3284, 1150, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 143, 144, 0, 0, 145, 0, 0, 0, 729, 728, + 735, 725, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 732, 733, 0, 734, 738, 0, 0, 719, 0, + 0, 0, 0, 0, 0, 0, 65, 0, 743, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 1998, + 2000, 1997, 0, 0, 1994, 0, 0, 0, 0, 2019, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2025, 146, 203, 0, 147, 0, 0, 0, 2010, 169, + 1993, 0, 0, 0, 61, 0, 0, 0, 0, 0, + 2013, 2047, 0, 0, 2014, 2016, 2018, 0, 2020, 2021, + 2022, 2026, 2027, 2028, 2030, 2033, 2034, 2035, 0, 0, + 0, 0, 0, 0, 0, 2023, 2032, 2024, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 2002, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 139, 45, 2039, 0, 0, 0, 0, 62, 0, 0, + 0, 0, 2840, 0, 0, 0, 0, 0, 142, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 142, 0, + 143, 144, 0, 0, 145, 1995, 1996, 0, 0, 0, + 0, 0, 2038, 0, 0, 0, 0, 1999, 0, 0, + 0, 0, 0, 2036, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2012, 0, 0, 0, 3394, 0, 0, 2011, 2040, 2008, + 0, 3396, 720, 722, 721, 0, 0, 0, 2041, 2042, + 0, 0, 0, 727, 0, 0, 0, 0, 0, 0, + 0, 2029, 0, 0, 0, 731, 0, 0, 0, 0, + 2017, 0, 746, 3411, 2007, 0, 0, 0, 0, 724, + 0, 0, 0, 2044, 2043, 0, 0, 0, 0, 0, + 0, 0, 2015, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 2071, 2071, 2071, 2071, 2071, + 2071, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 2071, 0, 0, 0, 2004, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 3031, 3032, 0, 0, 0, 0, 0, 0, + 2031, 0, 0, 0, 0, 0, 0, 0, 0, 1140, + 0, 0, 0, 0, 0, 0, 0, 0, 2046, 0, + 0, 2045, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 726, 730, + 736, 0, 737, 739, 0, 0, 740, 741, 742, 0, + 0, 744, 745, 0, 0, 0, 0, 0, 0, 0, + 0, 142, 0, 0, 0, 0, 142, 0, 0, 1877, + 0, 0, 0, 0, 1998, 2866, 1997, 0, 0, 2865, + 0, 0, 0, 0, 2019, 1877, 0, 142, 3566, 0, + 0, 3568, 0, 0, 0, 2025, 0, 0, 0, 142, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 3575, 0, 0, 2013, 2047, 0, 0, 2014, + 2016, 2018, 0, 2020, 2021, 2022, 2026, 2027, 2028, 2030, + 2033, 2034, 2035, 1125, 0, 0, 0, 1115, 0, 0, + 2023, 2032, 2024, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 2002, 0, 1148, 1152, 1154, 1156, 1158, 1159, + 1161, 0, 1166, 1162, 1163, 1164, 1165, 0, 1143, 1144, + 1145, 1146, 1123, 1124, 1149, 0, 1126, 2039, 1128, 1129, + 1130, 1131, 1127, 1132, 1133, 1134, 1135, 1136, 1139, 1141, + 1137, 1138, 1147, 1140, 0, 0, 0, 0, 0, 0, + 1151, 1153, 1155, 1157, 1160, 0, 0, 723, 0, 0, + 1995, 1996, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 729, 728, 735, 725, 0, 0, 0, 2036, 0, + 0, 0, 0, 0, 732, 733, 0, 734, 738, 0, + 1142, 719, 0, 0, 0, 2012, 0, 0, 0, 0, + 0, 743, 2011, 0, 3223, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 3236, 0, 3237, 0, 2029, 0, 0, 0, + 0, 1068, 0, 142, 0, 2017, 0, 0, 0, 142, + 0, 0, 0, 0, 0, 0, 2071, 747, 2044, 2043, + 749, 0, 0, 0, 0, 748, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 142, 1125, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 1148, 1152, + 1154, 1156, 1158, 1159, 1161, 2038, 1166, 1162, 1163, 1164, + 1165, 2004, 1143, 1144, 1145, 1146, 1123, 1124, 1149, 0, + 1126, 0, 1128, 1129, 1130, 1131, 1127, 1132, 1133, 1134, + 1135, 1136, 1139, 1141, 1137, 1138, 1147, 0, 0, 0, + 0, 2040, 0, 0, 1151, 1153, 1155, 1157, 1160, 0, + 0, 0, 0, 2046, 0, 0, 2045, 0, 0, 0, + 0, 0, 2113, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 729, 728, 735, 725, 0, 0, 0, + 0, 0, 0, 0, 1142, 3840, 732, 733, 0, 734, + 738, 0, 0, 719, 0, 2015, 0, 0, 0, 0, + 0, 0, 0, 743, 0, 720, 722, 721, 0, 0, + 0, 0, 0, 0, 0, 0, 727, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 731, 0, + 0, 0, 0, 0, 0, 746, 0, 0, 0, 0, + 0, 0, 724, 0, 0, 0, 714, 0, 0, 747, + 0, 0, 749, 0, 0, 0, 0, 748, 0, 0, + 0, 0, 0, 2031, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1313, 0, 1150, 0, 0, 0, 0, 3388, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 2019, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 2025, 0, + 3936, 726, 730, 736, 0, 737, 739, 0, 0, 740, + 741, 742, 0, 0, 744, 745, 0, 0, 2013, 2047, + 0, 0, 2014, 2016, 2018, 0, 2020, 2021, 2022, 2026, + 2027, 2028, 2030, 2033, 2034, 2035, 0, 720, 722, 721, + 0, 0, 142, 2023, 2032, 2024, 0, 0, 727, 142, + 0, 0, 0, 0, 0, 0, 0, 0, 2113, 0, + 731, 0, 0, 0, 0, 0, 0, 746, 0, 0, + 0, 0, 0, 0, 724, 0, 0, 0, 0, 0, + 2039, 0, 0, 0, 0, 0, 0, 4017, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2071, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1150, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 2036, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 2012, 0, + 0, 0, 0, 0, 0, 2011, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 2113, 4017, 0, 0, + 723, 0, 0, 0, 0, 0, 0, 0, 0, 2029, + 0, 0, 0, 0, 0, 0, 0, 0, 2017, 0, + 0, 0, 0, 726, 730, 736, 0, 737, 739, 0, + 0, 740, 741, 742, 0, 0, 744, 745, 0, 0, + 0, 0, 0, 0, 0, 0, 142, 0, 0, 0, + 0, 0, 0, 0, 4017, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 819, 0, 0, 0, + 0, 0, 0, 0, 0, 402, 0, 0, 533, 566, + 555, 639, 521, 0, 0, 0, 0, 0, 0, 771, + 4142, 0, 0, 337, 0, 0, 370, 570, 552, 562, + 553, 538, 539, 540, 547, 349, 541, 542, 543, 513, + 544, 514, 545, 546, 810, 569, 520, 435, 386, 587, + 586, 0, 142, 879, 887, 0, 0, 0, 0, 0, + 0, 0, 0, 875, 0, 0, 0, 0, 763, 0, + 0, 800, 855, 854, 787, 797, 0, 0, 310, 229, + 515, 635, 517, 516, 788, 0, 789, 793, 796, 792, + 790, 791, 723, 870, 0, 0, 0, 0, 0, 0, + 755, 767, 3714, 772, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 764, 765, 0, + 0, 0, 0, 820, 0, 766, 0, 0, 815, 794, + 798, 0, 0, 0, 0, 300, 442, 461, 311, 430, + 474, 316, 438, 453, 306, 401, 427, 0, 0, 302, + 459, 437, 383, 360, 361, 301, 0, 421, 335, 351, + 332, 399, 795, 818, 822, 331, 893, 816, 469, 304, + 0, 468, 398, 455, 460, 384, 377, 0, 303, 457, + 382, 376, 364, 341, 894, 365, 366, 355, 410, 374, + 411, 356, 388, 387, 389, 0, 0, 0, 0, 0, + 497, 498, 0, 0, 646, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 628, 813, 0, 632, + 0, 471, 0, 0, 877, 0, 0, 0, 441, 0, + 0, 367, 0, 0, 142, 817, 0, 424, 404, 890, + 0, 0, 422, 372, 456, 412, 462, 443, 470, 418, + 413, 294, 444, 334, 385, 307, 309, 329, 336, 338, + 342, 343, 394, 395, 407, 429, 446, 447, 448, 333, + 317, 423, 318, 353, 319, 295, 325, 323, 326, 431, + 327, 297, 408, 452, 0, 348, 419, 380, 298, 379, + 409, 451, 450, 308, 478, 484, 485, 574, 0, 490, + 662, 663, 664, 499, 0, 414, 0, 504, 505, 506, + 508, 509, 510, 511, 575, 592, 559, 529, 492, 583, + 526, 530, 531, 358, 595, 1827, 1826, 1828, 483, 368, + 369, 0, 340, 339, 381, 417, 299, 346, 291, 292, + 657, 874, 400, 597, 630, 631, 522, 0, 889, 869, + 871, 872, 876, 880, 881, 882, 883, 884, 886, 888, + 892, 656, 0, 576, 591, 660, 590, 653, 406, 0, + 428, 588, 535, 0, 580, 554, 0, 581, 550, 585, + 0, 524, 0, 436, 464, 476, 493, 496, 525, 610, + 611, 612, 296, 495, 614, 615, 616, 617, 618, 619, + 620, 613, 891, 557, 534, 560, 475, 537, 536, 0, + 0, 571, 821, 572, 573, 390, 391, 392, 393, 878, + 598, 315, 494, 416, 0, 558, 0, 0, 0, 0, + 0, 0, 0, 0, 563, 564, 561, 665, 0, 621, + 622, 0, 0, 488, 489, 345, 352, 507, 354, 314, + 405, 347, 473, 362, 0, 500, 565, 501, 624, 627, + 625, 626, 397, 357, 359, 432, 363, 373, 420, 472, + 403, 425, 312, 463, 434, 378, 551, 578, 900, 873, + 899, 901, 902, 898, 903, 904, 885, 776, 0, 828, + 896, 895, 897, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 606, 605, 604, 603, 602, 601, + 600, 599, 0, 0, 548, 449, 324, 285, 320, 321, + 328, 654, 651, 454, 655, 783, 293, 528, 371, 0, + 415, 344, 593, 594, 0, 645, 862, 835, 836, 837, + 773, 838, 832, 833, 774, 834, 863, 826, 859, 860, + 802, 829, 839, 858, 840, 861, 864, 865, 905, 906, + 846, 830, 257, 907, 843, 866, 857, 856, 841, 827, + 867, 868, 809, 804, 844, 845, 831, 850, 851, 852, + 775, 823, 824, 825, 847, 848, 805, 806, 807, 808, + 0, 0, 0, 479, 480, 481, 503, 0, 465, 527, + 652, 0, 0, 0, 0, 0, 0, 0, 577, 589, + 623, 0, 633, 634, 636, 638, 853, 640, 439, 440, + 647, 0, 849, 643, 644, 641, 375, 426, 445, 433, + 819, 658, 518, 519, 659, 629, 0, 768, 0, 402, + 0, 0, 533, 566, 555, 639, 521, 0, 0, 0, + 0, 0, 0, 771, 0, 0, 0, 337, 1878, 0, + 370, 570, 552, 562, 553, 538, 539, 540, 547, 349, + 541, 542, 543, 513, 544, 514, 545, 546, 810, 569, + 520, 435, 386, 587, 586, 0, 0, 879, 887, 0, + 0, 0, 0, 0, 0, 0, 0, 875, 0, 2097, + 0, 0, 763, 0, 0, 800, 855, 854, 787, 797, + 0, 0, 310, 229, 515, 635, 517, 516, 788, 0, + 789, 793, 796, 792, 790, 791, 0, 870, 0, 0, + 0, 0, 0, 0, 755, 767, 0, 772, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 764, 765, 0, 0, 0, 0, 820, 0, 766, + 0, 0, 2098, 794, 798, 0, 0, 0, 0, 300, + 442, 461, 311, 430, 474, 316, 438, 453, 306, 401, + 427, 0, 0, 302, 459, 437, 383, 360, 361, 301, + 0, 421, 335, 351, 332, 399, 795, 818, 822, 331, + 893, 816, 469, 304, 0, 468, 398, 455, 460, 384, + 377, 0, 303, 457, 382, 376, 364, 341, 894, 365, + 366, 355, 410, 374, 411, 356, 388, 387, 389, 0, + 0, 0, 0, 0, 497, 498, 0, 0, 646, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 628, 813, 0, 632, 0, 471, 0, 0, 877, 0, + 0, 0, 441, 0, 0, 367, 0, 0, 0, 817, + 0, 424, 404, 890, 0, 0, 422, 372, 456, 412, + 462, 443, 470, 418, 413, 294, 444, 334, 385, 307, + 309, 329, 336, 338, 342, 343, 394, 395, 407, 429, + 446, 447, 448, 333, 317, 423, 318, 353, 319, 295, + 325, 323, 326, 431, 327, 297, 408, 452, 0, 348, + 419, 380, 298, 379, 409, 451, 450, 308, 478, 484, + 485, 574, 0, 490, 662, 663, 664, 499, 0, 414, + 0, 504, 505, 506, 508, 509, 510, 511, 575, 592, + 559, 529, 492, 583, 526, 530, 531, 358, 595, 0, + 0, 0, 483, 368, 369, 0, 340, 339, 381, 417, + 299, 346, 291, 292, 657, 874, 400, 597, 630, 631, + 522, 0, 889, 869, 871, 872, 876, 880, 881, 882, + 883, 884, 886, 888, 892, 656, 0, 576, 591, 660, + 590, 653, 406, 0, 428, 588, 535, 0, 580, 554, + 0, 581, 550, 585, 0, 524, 0, 436, 464, 476, + 493, 496, 525, 610, 611, 612, 296, 495, 614, 615, + 616, 617, 618, 619, 620, 613, 891, 557, 534, 560, + 475, 537, 536, 0, 0, 571, 821, 572, 573, 390, + 391, 392, 393, 878, 598, 315, 494, 416, 0, 558, + 0, 0, 0, 0, 0, 0, 0, 0, 563, 564, + 561, 665, 0, 621, 622, 0, 0, 488, 489, 345, + 352, 507, 354, 314, 405, 347, 473, 362, 0, 500, + 565, 501, 624, 627, 625, 626, 397, 357, 359, 432, + 363, 373, 420, 472, 403, 425, 312, 463, 434, 378, + 551, 578, 900, 873, 899, 901, 902, 898, 903, 904, + 885, 776, 0, 828, 896, 895, 897, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 606, 605, + 604, 603, 602, 601, 600, 599, 0, 0, 548, 449, + 324, 285, 320, 321, 328, 654, 651, 454, 655, 783, + 293, 528, 371, 0, 415, 344, 593, 594, 0, 645, + 862, 835, 836, 837, 773, 838, 832, 833, 774, 834, + 863, 826, 859, 860, 802, 829, 839, 858, 840, 861, + 864, 865, 905, 906, 846, 830, 257, 907, 843, 866, + 857, 856, 841, 827, 867, 868, 809, 804, 844, 845, + 831, 850, 851, 852, 775, 823, 824, 825, 847, 848, + 805, 806, 807, 808, 0, 0, 0, 479, 480, 481, + 503, 0, 465, 527, 652, 0, 0, 0, 0, 0, + 0, 0, 577, 589, 623, 0, 633, 634, 636, 638, + 853, 640, 439, 440, 647, 0, 849, 643, 644, 641, + 375, 426, 445, 433, 0, 658, 518, 519, 659, 629, + 0, 768, 206, 819, 0, 0, 0, 0, 0, 0, + 0, 0, 402, 0, 0, 533, 566, 555, 639, 521, + 0, 0, 0, 0, 0, 0, 771, 0, 0, 0, + 337, 0, 0, 370, 570, 552, 562, 553, 538, 539, + 540, 547, 349, 541, 542, 543, 513, 544, 514, 545, + 546, 1296, 569, 520, 435, 386, 587, 586, 0, 0, + 879, 887, 0, 0, 0, 0, 0, 0, 0, 0, + 875, 0, 0, 0, 0, 763, 0, 0, 800, 855, + 854, 787, 797, 0, 0, 310, 229, 515, 635, 517, + 516, 788, 0, 789, 793, 796, 792, 790, 791, 0, + 870, 0, 0, 0, 0, 0, 0, 755, 767, 0, + 772, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 764, 765, 0, 0, 0, 0, + 820, 0, 766, 0, 0, 815, 794, 798, 0, 0, + 0, 0, 300, 442, 461, 311, 430, 474, 316, 438, + 453, 306, 401, 427, 0, 0, 302, 459, 437, 383, + 360, 361, 301, 0, 421, 335, 351, 332, 399, 795, + 818, 822, 331, 893, 816, 469, 304, 0, 468, 398, + 455, 460, 384, 377, 0, 303, 457, 382, 376, 364, + 341, 894, 365, 366, 355, 410, 374, 411, 356, 388, + 387, 389, 0, 0, 0, 0, 0, 497, 498, 0, + 0, 646, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 628, 813, 0, 632, 0, 471, 0, + 0, 877, 0, 0, 0, 441, 0, 0, 367, 0, + 0, 0, 817, 0, 424, 404, 890, 0, 0, 422, + 372, 456, 412, 462, 443, 470, 418, 413, 294, 444, + 334, 385, 307, 309, 329, 336, 338, 342, 343, 394, + 395, 407, 429, 446, 447, 448, 333, 317, 423, 318, + 353, 319, 295, 325, 323, 326, 431, 327, 297, 408, + 452, 0, 348, 419, 380, 298, 379, 409, 451, 450, + 308, 478, 484, 485, 574, 0, 490, 662, 663, 664, + 499, 0, 414, 0, 504, 505, 506, 508, 509, 510, + 511, 575, 592, 559, 529, 492, 583, 526, 530, 531, + 358, 595, 0, 0, 0, 483, 368, 369, 0, 340, + 339, 381, 417, 299, 346, 291, 292, 657, 874, 400, + 597, 630, 631, 522, 0, 889, 869, 871, 872, 876, + 880, 881, 882, 883, 884, 886, 888, 892, 656, 0, + 576, 591, 660, 590, 653, 406, 0, 428, 588, 535, + 0, 580, 554, 0, 581, 550, 585, 0, 524, 0, + 436, 464, 476, 493, 496, 525, 610, 611, 612, 296, + 495, 614, 615, 616, 617, 618, 619, 620, 613, 891, + 557, 534, 560, 475, 537, 536, 0, 0, 571, 821, + 572, 573, 390, 391, 392, 393, 878, 598, 315, 494, + 416, 0, 558, 0, 0, 0, 0, 0, 0, 0, + 0, 563, 564, 561, 665, 0, 621, 622, 0, 0, + 488, 489, 345, 352, 507, 354, 314, 405, 347, 473, + 362, 0, 500, 565, 501, 624, 627, 625, 626, 397, + 357, 359, 432, 363, 373, 420, 472, 403, 425, 312, + 463, 434, 378, 551, 578, 900, 873, 899, 901, 902, + 898, 903, 904, 885, 776, 0, 828, 896, 895, 897, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 606, 605, 604, 603, 602, 601, 600, 599, 0, + 0, 548, 449, 324, 285, 320, 321, 328, 654, 651, + 454, 655, 783, 293, 528, 371, 169, 415, 344, 593, + 594, 0, 645, 862, 835, 836, 837, 773, 838, 832, + 833, 774, 834, 863, 826, 859, 860, 802, 829, 839, + 858, 840, 861, 864, 865, 905, 906, 846, 830, 257, + 907, 843, 866, 857, 856, 841, 827, 867, 868, 809, + 804, 844, 845, 831, 850, 851, 852, 775, 823, 824, + 825, 847, 848, 805, 806, 807, 808, 0, 0, 0, + 479, 480, 481, 503, 0, 465, 527, 652, 0, 0, + 0, 0, 0, 0, 0, 577, 589, 623, 0, 633, + 634, 636, 638, 853, 640, 439, 440, 647, 0, 849, + 643, 644, 641, 375, 426, 445, 433, 819, 658, 518, + 519, 659, 629, 0, 768, 0, 402, 0, 0, 533, + 566, 555, 639, 521, 0, 0, 0, 0, 0, 0, + 771, 0, 0, 0, 337, 4141, 0, 370, 570, 552, + 562, 553, 538, 539, 540, 547, 349, 541, 542, 543, + 513, 544, 514, 545, 546, 810, 569, 520, 435, 386, + 587, 586, 0, 0, 879, 887, 0, 0, 0, 0, + 0, 0, 0, 0, 875, 0, 0, 0, 0, 763, + 0, 0, 800, 855, 854, 787, 797, 0, 0, 310, + 229, 515, 635, 517, 516, 788, 0, 789, 793, 796, + 792, 790, 791, 0, 870, 0, 0, 0, 0, 0, + 0, 755, 767, 0, 772, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 764, 765, + 0, 0, 0, 0, 820, 0, 766, 0, 0, 815, + 794, 798, 0, 0, 0, 0, 300, 442, 461, 311, + 430, 474, 316, 438, 453, 306, 401, 427, 0, 0, + 302, 459, 437, 383, 360, 361, 301, 0, 421, 335, + 351, 332, 399, 795, 818, 822, 331, 893, 816, 469, + 304, 0, 468, 398, 455, 460, 384, 377, 0, 303, + 457, 382, 376, 364, 341, 894, 365, 366, 355, 410, + 374, 411, 356, 388, 387, 389, 0, 0, 0, 0, + 0, 497, 498, 0, 0, 646, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 628, 813, 0, + 632, 0, 471, 0, 0, 877, 0, 0, 0, 441, + 0, 0, 367, 0, 0, 0, 817, 0, 424, 404, + 890, 0, 0, 422, 372, 456, 412, 462, 443, 470, + 418, 413, 294, 444, 334, 385, 307, 309, 329, 336, + 338, 342, 343, 394, 395, 407, 429, 446, 447, 448, + 333, 317, 423, 318, 353, 319, 295, 325, 323, 326, + 431, 327, 297, 408, 452, 0, 348, 419, 380, 298, + 379, 409, 451, 450, 308, 478, 484, 485, 574, 0, + 490, 662, 663, 664, 499, 0, 414, 0, 504, 505, + 506, 508, 509, 510, 511, 575, 592, 559, 529, 492, + 583, 526, 530, 531, 358, 595, 0, 0, 0, 483, + 368, 369, 0, 340, 339, 381, 417, 299, 346, 291, + 292, 657, 874, 400, 597, 630, 631, 522, 0, 889, + 869, 871, 872, 876, 880, 881, 882, 883, 884, 886, + 888, 892, 656, 0, 576, 591, 660, 590, 653, 406, + 0, 428, 588, 535, 0, 580, 554, 0, 581, 550, + 585, 0, 524, 0, 436, 464, 476, 493, 496, 525, + 610, 611, 612, 296, 495, 614, 615, 616, 617, 618, + 619, 620, 613, 891, 557, 534, 560, 475, 537, 536, + 0, 0, 571, 821, 572, 573, 390, 391, 392, 393, + 878, 598, 315, 494, 416, 0, 558, 0, 0, 0, + 0, 0, 0, 0, 0, 563, 564, 561, 665, 0, + 621, 622, 0, 0, 488, 489, 345, 352, 507, 354, + 314, 405, 347, 473, 362, 0, 500, 565, 501, 624, + 627, 625, 626, 397, 357, 359, 432, 363, 373, 420, + 472, 403, 425, 312, 463, 434, 378, 551, 578, 900, + 873, 899, 901, 902, 898, 903, 904, 885, 776, 0, + 828, 896, 895, 897, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 606, 605, 604, 603, 602, + 601, 600, 599, 0, 0, 548, 449, 324, 285, 320, + 321, 328, 654, 651, 454, 655, 783, 293, 528, 371, + 0, 415, 344, 593, 594, 0, 645, 862, 835, 836, + 837, 773, 838, 832, 833, 774, 834, 863, 826, 859, + 860, 802, 829, 839, 858, 840, 861, 864, 865, 905, + 906, 846, 830, 257, 907, 843, 866, 857, 856, 841, + 827, 867, 868, 809, 804, 844, 845, 831, 850, 851, + 852, 775, 823, 824, 825, 847, 848, 805, 806, 807, + 808, 0, 0, 0, 479, 480, 481, 503, 0, 465, + 527, 652, 0, 0, 0, 0, 0, 0, 0, 577, + 589, 623, 0, 633, 634, 636, 638, 853, 640, 439, + 440, 647, 0, 849, 643, 644, 641, 375, 426, 445, + 433, 819, 658, 518, 519, 659, 629, 0, 768, 0, + 402, 0, 0, 533, 566, 555, 639, 521, 0, 0, + 0, 0, 0, 0, 771, 0, 0, 0, 337, 0, + 0, 370, 570, 552, 562, 553, 538, 539, 540, 547, + 349, 541, 542, 543, 513, 544, 514, 545, 546, 810, + 569, 520, 435, 386, 587, 586, 0, 0, 879, 887, + 0, 0, 0, 0, 0, 0, 0, 0, 875, 0, + 0, 0, 0, 763, 0, 0, 800, 855, 854, 787, + 797, 0, 0, 310, 229, 515, 635, 517, 516, 788, + 0, 789, 793, 796, 792, 790, 791, 0, 870, 0, + 0, 0, 0, 0, 0, 755, 767, 0, 772, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 764, 765, 0, 0, 0, 0, 820, 0, + 766, 0, 0, 815, 794, 798, 0, 0, 0, 0, + 300, 442, 461, 311, 430, 474, 316, 438, 453, 306, + 401, 427, 0, 0, 302, 459, 437, 383, 360, 361, + 301, 0, 421, 335, 351, 332, 399, 795, 818, 822, + 331, 893, 816, 469, 304, 0, 468, 398, 455, 460, + 384, 377, 0, 303, 457, 382, 376, 364, 341, 894, + 365, 366, 355, 410, 374, 411, 356, 388, 387, 389, + 0, 0, 0, 0, 0, 497, 498, 0, 0, 646, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 628, 813, 0, 632, 0, 471, 0, 0, 877, + 0, 0, 0, 441, 0, 0, 367, 0, 0, 0, + 817, 0, 424, 404, 890, 4018, 0, 422, 372, 456, + 412, 462, 443, 470, 418, 413, 294, 444, 334, 385, + 307, 309, 329, 336, 338, 342, 343, 394, 395, 407, + 429, 446, 447, 448, 333, 317, 423, 318, 353, 319, + 295, 325, 323, 326, 431, 327, 297, 408, 452, 0, + 348, 419, 380, 298, 379, 409, 451, 450, 308, 478, + 484, 485, 574, 0, 490, 662, 663, 664, 499, 0, + 414, 0, 504, 505, 506, 508, 509, 510, 511, 575, + 592, 559, 529, 492, 583, 526, 530, 531, 358, 595, + 0, 0, 0, 483, 368, 369, 0, 340, 339, 381, + 417, 299, 346, 291, 292, 657, 874, 400, 597, 630, + 631, 522, 0, 889, 869, 871, 872, 876, 880, 881, + 882, 883, 884, 886, 888, 892, 656, 0, 576, 591, + 660, 590, 653, 406, 0, 428, 588, 535, 0, 580, + 554, 0, 581, 550, 585, 0, 524, 0, 436, 464, + 476, 493, 496, 525, 610, 611, 612, 296, 495, 614, + 615, 616, 617, 618, 619, 620, 613, 891, 557, 534, + 560, 475, 537, 536, 0, 0, 571, 821, 572, 573, + 390, 391, 392, 393, 878, 598, 315, 494, 416, 0, + 558, 0, 0, 0, 0, 0, 0, 0, 0, 563, + 564, 561, 665, 0, 621, 622, 0, 0, 488, 489, + 345, 352, 507, 354, 314, 405, 347, 473, 362, 0, + 500, 565, 501, 624, 627, 625, 626, 397, 357, 359, + 432, 363, 373, 420, 472, 403, 425, 312, 463, 434, + 378, 551, 578, 900, 873, 899, 901, 902, 898, 903, + 904, 885, 776, 0, 828, 896, 895, 897, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 606, + 605, 604, 603, 602, 601, 600, 599, 0, 0, 548, + 449, 324, 285, 320, 321, 328, 654, 651, 454, 655, + 783, 293, 528, 371, 0, 415, 344, 593, 594, 0, + 645, 862, 835, 836, 837, 773, 838, 832, 833, 774, + 834, 863, 826, 859, 860, 802, 829, 839, 858, 840, + 861, 864, 865, 905, 906, 846, 830, 257, 907, 843, + 866, 857, 856, 841, 827, 867, 868, 809, 804, 844, + 845, 831, 850, 851, 852, 775, 823, 824, 825, 847, + 848, 805, 806, 807, 808, 0, 0, 0, 479, 480, + 481, 503, 0, 465, 527, 652, 0, 0, 0, 0, + 0, 0, 0, 577, 589, 623, 0, 633, 634, 636, + 638, 853, 640, 439, 440, 647, 0, 849, 643, 644, + 641, 375, 426, 445, 433, 819, 658, 518, 519, 659, + 629, 0, 768, 0, 402, 0, 0, 533, 566, 555, + 639, 521, 0, 0, 0, 0, 0, 0, 771, 0, + 0, 0, 337, 1878, 0, 370, 570, 552, 562, 553, + 538, 539, 540, 547, 349, 541, 542, 543, 513, 544, + 514, 545, 546, 810, 569, 520, 435, 386, 587, 586, + 0, 0, 879, 887, 0, 0, 0, 0, 0, 0, + 0, 0, 875, 0, 0, 0, 0, 763, 0, 0, + 800, 855, 854, 787, 797, 0, 0, 310, 229, 515, + 635, 517, 516, 788, 0, 789, 793, 796, 792, 790, + 791, 0, 870, 0, 0, 0, 0, 0, 0, 755, + 767, 0, 772, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 764, 765, 0, 0, + 0, 0, 820, 0, 766, 0, 0, 815, 794, 798, + 0, 0, 0, 0, 300, 442, 461, 311, 430, 474, + 316, 438, 453, 306, 401, 427, 0, 0, 302, 459, + 437, 383, 360, 361, 301, 0, 421, 335, 351, 332, + 399, 795, 818, 822, 331, 893, 816, 469, 304, 0, + 468, 398, 455, 460, 384, 377, 0, 303, 457, 382, + 376, 364, 341, 894, 365, 366, 355, 410, 374, 411, + 356, 388, 387, 389, 0, 0, 0, 0, 0, 497, + 498, 0, 0, 646, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 628, 813, 0, 632, 0, + 471, 0, 0, 877, 0, 0, 0, 441, 0, 0, + 367, 0, 0, 0, 817, 0, 424, 404, 890, 0, + 0, 422, 372, 456, 412, 462, 443, 470, 418, 413, + 294, 444, 334, 385, 307, 309, 329, 336, 338, 342, + 343, 394, 395, 407, 429, 446, 447, 448, 333, 317, + 423, 318, 353, 319, 295, 325, 323, 326, 431, 327, + 297, 408, 452, 0, 348, 419, 380, 298, 379, 409, + 451, 450, 308, 478, 484, 485, 574, 0, 490, 662, + 663, 664, 499, 0, 414, 0, 504, 505, 506, 508, + 509, 510, 511, 575, 592, 559, 529, 492, 583, 526, + 530, 531, 358, 595, 0, 0, 0, 483, 368, 369, + 0, 340, 339, 381, 417, 299, 346, 291, 292, 657, + 874, 400, 597, 630, 631, 522, 0, 889, 869, 871, + 872, 876, 880, 881, 882, 883, 884, 886, 888, 892, + 656, 0, 576, 591, 660, 590, 653, 406, 0, 428, + 588, 535, 0, 580, 554, 0, 581, 550, 585, 0, + 524, 0, 436, 464, 476, 493, 496, 525, 610, 611, + 612, 296, 495, 614, 615, 616, 617, 618, 619, 620, + 613, 891, 557, 534, 560, 475, 537, 536, 0, 0, + 571, 821, 572, 573, 390, 391, 392, 393, 878, 598, + 315, 494, 416, 0, 558, 0, 0, 0, 0, 0, + 0, 0, 0, 563, 564, 561, 665, 0, 621, 622, + 0, 0, 488, 489, 345, 352, 507, 354, 314, 405, + 347, 473, 362, 0, 500, 565, 501, 624, 627, 625, + 626, 397, 357, 359, 432, 363, 373, 420, 472, 403, + 425, 312, 463, 434, 378, 551, 578, 900, 873, 899, + 901, 902, 898, 903, 904, 885, 776, 0, 828, 896, + 895, 897, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 606, 605, 604, 603, 602, 601, 600, + 599, 0, 0, 548, 449, 324, 285, 320, 321, 328, + 654, 651, 454, 655, 783, 293, 528, 371, 0, 415, + 344, 593, 594, 0, 645, 862, 835, 836, 837, 773, + 838, 832, 833, 774, 834, 863, 826, 859, 860, 802, + 829, 839, 858, 840, 861, 864, 865, 905, 906, 846, + 830, 257, 907, 843, 866, 857, 856, 841, 827, 867, + 868, 809, 804, 844, 845, 831, 850, 851, 852, 775, + 823, 824, 825, 847, 848, 805, 806, 807, 808, 0, + 0, 0, 479, 480, 481, 503, 0, 465, 527, 652, + 0, 0, 0, 0, 0, 0, 0, 577, 589, 623, + 0, 633, 634, 636, 638, 853, 640, 439, 440, 647, + 0, 849, 643, 644, 641, 375, 426, 445, 433, 819, + 658, 518, 519, 659, 629, 0, 768, 0, 402, 0, + 0, 533, 566, 555, 639, 521, 0, 0, 0, 0, + 0, 0, 771, 0, 0, 0, 337, 0, 0, 370, + 570, 552, 562, 553, 538, 539, 540, 547, 349, 541, + 542, 543, 513, 544, 514, 545, 546, 810, 569, 520, + 435, 386, 587, 586, 0, 0, 879, 887, 0, 0, + 0, 0, 0, 0, 0, 0, 875, 0, 0, 0, + 0, 763, 0, 0, 800, 855, 854, 787, 797, 0, + 0, 310, 229, 515, 635, 517, 516, 788, 0, 789, + 793, 796, 792, 790, 791, 0, 870, 0, 0, 0, + 0, 0, 0, 755, 767, 0, 772, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 764, 765, 1591, 0, 0, 0, 820, 0, 766, 0, + 0, 815, 794, 798, 0, 0, 0, 0, 300, 442, + 461, 311, 430, 474, 316, 438, 453, 306, 401, 427, + 0, 0, 302, 459, 437, 383, 360, 361, 301, 0, + 421, 335, 351, 332, 399, 795, 818, 822, 331, 893, + 816, 469, 304, 0, 468, 398, 455, 460, 384, 377, + 0, 303, 457, 382, 376, 364, 341, 894, 365, 366, + 355, 410, 374, 411, 356, 388, 387, 389, 0, 0, + 0, 0, 0, 497, 498, 0, 0, 646, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 628, + 813, 0, 632, 0, 471, 0, 0, 877, 0, 0, + 0, 441, 0, 0, 367, 0, 0, 0, 817, 0, + 424, 404, 890, 0, 0, 422, 372, 456, 412, 462, + 443, 470, 418, 413, 294, 444, 334, 385, 307, 309, + 329, 336, 338, 342, 343, 394, 395, 407, 429, 446, + 447, 448, 333, 317, 423, 318, 353, 319, 295, 325, + 323, 326, 431, 327, 297, 408, 452, 0, 348, 419, + 380, 298, 379, 409, 451, 450, 308, 478, 484, 485, + 574, 0, 490, 662, 663, 664, 499, 0, 414, 0, + 504, 505, 506, 508, 509, 510, 511, 575, 592, 559, + 529, 492, 583, 526, 530, 531, 358, 595, 0, 0, + 0, 483, 368, 369, 0, 340, 339, 381, 417, 299, + 346, 291, 292, 657, 874, 400, 597, 630, 631, 522, + 0, 889, 869, 871, 872, 876, 880, 881, 882, 883, + 884, 886, 888, 892, 656, 0, 576, 591, 660, 590, + 653, 406, 0, 428, 588, 535, 0, 580, 554, 0, + 581, 550, 585, 0, 524, 0, 436, 464, 476, 493, + 496, 525, 610, 611, 612, 296, 495, 614, 615, 616, + 617, 618, 619, 620, 613, 891, 557, 534, 560, 475, + 537, 536, 0, 0, 571, 821, 572, 573, 390, 391, + 392, 393, 878, 598, 315, 494, 416, 0, 558, 0, + 0, 0, 0, 0, 0, 0, 0, 563, 564, 561, + 665, 0, 621, 622, 0, 0, 488, 489, 345, 352, + 507, 354, 314, 405, 347, 473, 362, 0, 500, 565, + 501, 624, 627, 625, 626, 397, 357, 359, 432, 363, + 373, 420, 472, 403, 425, 312, 463, 434, 378, 551, + 578, 900, 873, 899, 901, 902, 898, 903, 904, 885, + 776, 0, 828, 896, 895, 897, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 606, 605, 604, + 603, 602, 601, 600, 599, 0, 0, 548, 449, 324, + 285, 320, 321, 328, 654, 651, 454, 655, 783, 293, + 528, 371, 0, 415, 344, 593, 594, 0, 645, 862, + 835, 836, 837, 773, 838, 832, 833, 774, 834, 863, + 826, 859, 860, 802, 829, 839, 858, 840, 861, 864, + 865, 905, 906, 846, 830, 257, 907, 843, 866, 857, + 856, 841, 827, 867, 868, 809, 804, 844, 845, 831, + 850, 851, 852, 775, 823, 824, 825, 847, 848, 805, + 806, 807, 808, 0, 0, 0, 479, 480, 481, 503, + 0, 465, 527, 652, 0, 0, 0, 0, 0, 0, + 0, 577, 589, 623, 0, 633, 634, 636, 638, 853, + 640, 439, 440, 647, 0, 849, 643, 644, 641, 375, + 426, 445, 433, 0, 658, 518, 519, 659, 629, 819, + 768, 0, 2270, 0, 0, 0, 0, 0, 402, 0, + 0, 533, 566, 555, 639, 521, 0, 0, 0, 0, + 0, 0, 771, 0, 0, 0, 337, 0, 0, 370, + 570, 552, 562, 553, 538, 539, 540, 547, 349, 541, + 542, 543, 513, 544, 514, 545, 546, 810, 569, 520, + 435, 386, 587, 586, 0, 0, 879, 887, 0, 0, + 0, 0, 0, 0, 0, 0, 875, 0, 0, 0, + 0, 763, 0, 0, 800, 855, 854, 787, 797, 0, + 0, 310, 229, 515, 635, 517, 516, 788, 0, 789, + 793, 796, 792, 790, 791, 0, 870, 0, 0, 0, + 0, 0, 0, 755, 767, 0, 772, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 764, 765, 0, 0, 0, 0, 820, 0, 766, 0, + 0, 815, 794, 798, 0, 0, 0, 0, 300, 442, + 461, 311, 430, 474, 316, 438, 453, 306, 401, 427, + 0, 0, 302, 459, 437, 383, 360, 361, 301, 0, + 421, 335, 351, 332, 399, 795, 818, 822, 331, 893, + 816, 469, 304, 0, 468, 398, 455, 460, 384, 377, + 0, 303, 457, 382, 376, 364, 341, 894, 365, 366, + 355, 410, 374, 411, 356, 388, 387, 389, 0, 0, + 0, 0, 0, 497, 498, 0, 0, 646, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 628, + 813, 0, 632, 0, 471, 0, 0, 877, 0, 0, + 0, 441, 0, 0, 367, 0, 0, 0, 817, 0, + 424, 404, 890, 0, 0, 422, 372, 456, 412, 462, + 443, 470, 418, 413, 294, 444, 334, 385, 307, 309, + 329, 336, 338, 342, 343, 394, 395, 407, 429, 446, + 447, 448, 333, 317, 423, 318, 353, 319, 295, 325, + 323, 326, 431, 327, 297, 408, 452, 0, 348, 419, + 380, 298, 379, 409, 451, 450, 308, 478, 484, 485, + 574, 0, 490, 662, 663, 664, 499, 0, 414, 0, + 504, 505, 506, 508, 509, 510, 511, 575, 592, 559, + 529, 492, 583, 526, 530, 531, 358, 595, 0, 0, + 0, 483, 368, 369, 0, 340, 339, 381, 417, 299, + 346, 291, 292, 657, 874, 400, 597, 630, 631, 522, + 0, 889, 869, 871, 872, 876, 880, 881, 882, 883, + 884, 886, 888, 892, 656, 0, 576, 591, 660, 590, + 653, 406, 0, 428, 588, 535, 0, 580, 554, 0, + 581, 550, 585, 0, 524, 0, 436, 464, 476, 493, + 496, 525, 610, 611, 612, 296, 495, 614, 615, 616, + 617, 618, 619, 620, 613, 891, 557, 534, 560, 475, + 537, 536, 0, 0, 571, 821, 572, 573, 390, 391, + 392, 393, 878, 598, 315, 494, 416, 0, 558, 0, + 0, 0, 0, 0, 0, 0, 0, 563, 564, 561, + 665, 0, 621, 622, 0, 0, 488, 489, 345, 352, + 507, 354, 314, 405, 347, 473, 362, 0, 500, 565, + 501, 624, 627, 625, 626, 397, 357, 359, 432, 363, + 373, 420, 472, 403, 425, 312, 463, 434, 378, 551, + 578, 900, 873, 899, 901, 902, 898, 903, 904, 885, + 776, 0, 828, 896, 895, 897, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 606, 605, 604, + 603, 602, 601, 600, 599, 0, 0, 548, 449, 324, + 285, 320, 321, 328, 654, 651, 454, 655, 783, 293, + 528, 371, 0, 415, 344, 593, 594, 0, 645, 862, + 835, 836, 837, 773, 838, 832, 833, 774, 834, 863, + 826, 859, 860, 802, 829, 839, 858, 840, 861, 864, + 865, 905, 906, 846, 830, 257, 907, 843, 866, 857, + 856, 841, 827, 867, 868, 809, 804, 844, 845, 831, + 850, 851, 852, 775, 823, 824, 825, 847, 848, 805, + 806, 807, 808, 0, 0, 0, 479, 480, 481, 503, + 0, 465, 527, 652, 0, 0, 0, 0, 0, 0, + 0, 577, 589, 623, 0, 633, 634, 636, 638, 853, + 640, 439, 440, 647, 0, 849, 643, 644, 641, 375, + 426, 445, 433, 819, 658, 518, 519, 659, 629, 0, + 768, 0, 402, 0, 0, 533, 566, 555, 639, 521, + 0, 0, 0, 0, 0, 0, 771, 0, 0, 0, + 337, 0, 0, 370, 570, 552, 562, 553, 538, 539, + 540, 547, 349, 541, 542, 543, 513, 544, 514, 545, + 546, 810, 569, 520, 435, 386, 587, 586, 0, 0, + 879, 887, 0, 0, 0, 0, 0, 0, 0, 0, + 875, 0, 0, 0, 0, 763, 0, 0, 800, 855, + 854, 787, 797, 0, 0, 310, 229, 515, 635, 517, + 516, 788, 0, 789, 793, 796, 792, 790, 791, 0, + 870, 0, 0, 0, 0, 0, 0, 755, 767, 0, + 772, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 764, 765, 1871, 0, 0, 0, + 820, 0, 766, 0, 0, 815, 794, 798, 0, 0, + 0, 0, 300, 442, 461, 311, 430, 474, 316, 438, + 453, 306, 401, 427, 0, 0, 302, 459, 437, 383, + 360, 361, 301, 0, 421, 335, 351, 332, 399, 795, + 818, 822, 331, 893, 816, 469, 304, 0, 468, 398, + 455, 460, 384, 377, 0, 303, 457, 382, 376, 364, + 341, 894, 365, 366, 355, 410, 374, 411, 356, 388, + 387, 389, 0, 0, 0, 0, 0, 497, 498, 0, + 0, 646, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 628, 813, 0, 632, 0, 471, 0, + 0, 877, 0, 0, 0, 441, 0, 0, 367, 0, + 0, 0, 817, 0, 424, 404, 890, 0, 0, 422, + 372, 456, 412, 462, 443, 470, 418, 413, 294, 444, + 334, 385, 307, 309, 329, 336, 338, 342, 343, 394, + 395, 407, 429, 446, 447, 448, 333, 317, 423, 318, + 353, 319, 295, 325, 323, 326, 431, 327, 297, 408, + 452, 0, 348, 419, 380, 298, 379, 409, 451, 450, + 308, 478, 484, 485, 574, 0, 490, 662, 663, 664, + 499, 0, 414, 0, 504, 505, 506, 508, 509, 510, + 511, 575, 592, 559, 529, 492, 583, 526, 530, 531, + 358, 595, 0, 0, 0, 483, 368, 369, 0, 340, + 339, 381, 417, 299, 346, 291, 292, 657, 874, 400, + 597, 630, 631, 522, 0, 889, 869, 871, 872, 876, + 880, 881, 882, 883, 884, 886, 888, 892, 656, 0, + 576, 591, 660, 590, 653, 406, 0, 428, 588, 535, + 0, 580, 554, 0, 581, 550, 585, 0, 524, 0, + 436, 464, 476, 493, 496, 525, 610, 611, 612, 296, + 495, 614, 615, 616, 617, 618, 619, 620, 613, 891, + 557, 534, 560, 475, 537, 536, 0, 0, 571, 821, + 572, 573, 390, 391, 392, 393, 878, 598, 315, 494, + 416, 0, 558, 0, 0, 0, 0, 0, 0, 0, + 0, 563, 564, 561, 665, 0, 621, 622, 0, 0, + 488, 489, 345, 352, 507, 354, 314, 405, 347, 473, + 362, 0, 500, 565, 501, 624, 627, 625, 626, 397, + 357, 359, 432, 363, 373, 420, 472, 403, 425, 312, + 463, 434, 378, 551, 578, 900, 873, 899, 901, 902, + 898, 903, 904, 885, 776, 0, 828, 896, 895, 897, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 606, 605, 604, 603, 602, 601, 600, 599, 0, + 0, 548, 449, 324, 285, 320, 321, 328, 654, 651, + 454, 655, 783, 293, 528, 371, 0, 415, 344, 593, + 594, 0, 645, 862, 835, 836, 837, 773, 838, 832, + 833, 774, 834, 863, 826, 859, 860, 802, 829, 839, + 858, 840, 861, 864, 865, 905, 906, 846, 830, 257, + 907, 843, 866, 857, 856, 841, 827, 867, 868, 809, + 804, 844, 845, 831, 850, 851, 852, 775, 823, 824, + 825, 847, 848, 805, 806, 807, 808, 0, 0, 0, + 479, 480, 481, 503, 0, 465, 527, 652, 0, 0, + 0, 0, 0, 0, 0, 577, 589, 623, 0, 633, + 634, 636, 638, 853, 640, 439, 440, 647, 0, 849, + 643, 644, 641, 375, 426, 445, 433, 819, 658, 518, + 519, 659, 629, 0, 768, 0, 402, 0, 0, 533, + 566, 555, 639, 521, 0, 0, 0, 0, 0, 0, + 771, 0, 0, 0, 337, 0, 0, 370, 570, 552, + 562, 553, 538, 539, 540, 547, 349, 541, 542, 543, + 513, 544, 514, 545, 546, 810, 569, 520, 435, 386, + 587, 586, 0, 0, 879, 887, 0, 0, 0, 0, + 0, 0, 0, 0, 875, 0, 0, 0, 0, 763, + 0, 0, 800, 855, 854, 787, 797, 0, 0, 310, + 229, 515, 635, 517, 516, 788, 0, 789, 793, 796, + 792, 790, 791, 0, 870, 0, 0, 0, 0, 0, + 0, 755, 767, 0, 772, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 764, 765, + 0, 0, 0, 0, 820, 0, 766, 0, 0, 815, + 794, 798, 0, 0, 0, 0, 300, 442, 461, 311, + 430, 474, 316, 438, 453, 306, 401, 427, 0, 0, + 302, 459, 437, 383, 360, 361, 301, 0, 421, 335, + 351, 332, 399, 795, 818, 822, 331, 893, 816, 469, + 304, 0, 468, 398, 455, 460, 384, 377, 0, 303, + 457, 382, 376, 364, 341, 894, 365, 366, 355, 410, + 374, 411, 356, 388, 387, 389, 0, 0, 0, 0, + 0, 497, 498, 0, 0, 646, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 628, 813, 0, + 632, 0, 471, 0, 0, 877, 0, 0, 0, 441, + 0, 0, 367, 0, 0, 0, 817, 0, 424, 404, + 890, 0, 0, 422, 372, 456, 412, 462, 443, 470, + 418, 413, 294, 444, 334, 385, 307, 309, 329, 336, + 338, 342, 343, 394, 395, 407, 429, 446, 447, 448, + 333, 317, 423, 318, 353, 319, 295, 325, 323, 326, + 431, 327, 297, 408, 452, 0, 348, 419, 380, 298, + 379, 409, 451, 450, 308, 478, 484, 485, 574, 0, + 490, 662, 663, 664, 499, 0, 414, 0, 504, 505, + 506, 508, 509, 510, 511, 575, 592, 559, 529, 492, + 583, 526, 530, 531, 358, 595, 0, 0, 0, 483, + 368, 369, 0, 340, 339, 381, 417, 299, 346, 291, + 292, 657, 874, 400, 597, 630, 631, 522, 0, 889, + 869, 871, 872, 876, 880, 881, 882, 883, 884, 886, + 888, 892, 656, 0, 576, 591, 660, 590, 653, 406, + 0, 428, 588, 535, 0, 580, 554, 0, 581, 550, + 585, 0, 524, 0, 436, 464, 476, 493, 496, 525, + 610, 611, 612, 296, 495, 614, 615, 616, 617, 618, + 619, 620, 613, 891, 557, 534, 560, 475, 537, 536, + 0, 0, 571, 821, 572, 573, 390, 391, 392, 393, + 878, 598, 315, 494, 416, 0, 558, 0, 0, 0, + 0, 0, 0, 0, 0, 563, 564, 561, 665, 0, + 621, 622, 0, 0, 488, 489, 345, 352, 507, 354, + 314, 405, 347, 473, 362, 0, 500, 565, 501, 624, + 627, 625, 626, 397, 357, 359, 432, 363, 373, 420, + 472, 403, 425, 312, 463, 434, 378, 551, 578, 900, + 873, 899, 901, 902, 898, 903, 904, 885, 776, 0, + 828, 896, 895, 897, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 606, 605, 604, 603, 602, + 601, 600, 599, 0, 0, 548, 449, 324, 285, 320, + 321, 328, 654, 651, 454, 655, 783, 293, 528, 371, + 0, 415, 344, 593, 594, 0, 645, 862, 835, 836, + 837, 773, 838, 832, 833, 774, 834, 863, 826, 859, + 860, 802, 829, 839, 858, 840, 861, 864, 865, 905, + 906, 846, 830, 257, 907, 843, 866, 857, 856, 841, + 827, 867, 868, 809, 804, 844, 845, 831, 850, 851, + 852, 775, 823, 824, 825, 847, 848, 805, 806, 807, + 808, 0, 0, 0, 479, 480, 481, 503, 0, 465, + 527, 652, 0, 0, 0, 0, 0, 0, 0, 577, + 589, 623, 0, 633, 634, 636, 638, 853, 640, 439, + 440, 647, 0, 849, 643, 644, 641, 375, 426, 445, + 433, 819, 658, 518, 519, 659, 629, 0, 768, 0, + 402, 0, 0, 533, 566, 555, 639, 521, 0, 0, + 0, 0, 0, 0, 771, 0, 0, 0, 337, 0, + 0, 370, 570, 552, 562, 553, 538, 539, 540, 547, + 349, 541, 542, 543, 513, 544, 514, 545, 546, 810, + 569, 520, 435, 386, 587, 586, 0, 0, 879, 887, + 0, 0, 0, 0, 0, 0, 0, 0, 875, 0, + 0, 0, 0, 763, 0, 0, 800, 855, 854, 787, + 797, 0, 0, 310, 229, 515, 635, 517, 516, 788, + 0, 789, 793, 796, 792, 790, 791, 0, 870, 0, + 0, 0, 0, 0, 0, 755, 767, 0, 772, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 764, 765, 0, 0, 0, 0, 820, 0, + 766, 0, 0, 815, 794, 798, 0, 0, 0, 0, + 300, 442, 461, 311, 430, 474, 316, 438, 453, 306, + 401, 427, 0, 0, 302, 459, 437, 383, 360, 361, + 301, 0, 421, 335, 351, 332, 399, 795, 818, 822, + 331, 893, 816, 469, 304, 0, 468, 398, 455, 460, + 384, 377, 0, 303, 457, 382, 376, 364, 341, 894, + 365, 366, 355, 410, 374, 411, 356, 388, 387, 389, + 0, 0, 0, 0, 0, 497, 498, 0, 0, 646, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 628, 813, 0, 632, 0, 471, 0, 0, 877, + 0, 0, 0, 441, 0, 0, 367, 0, 0, 0, + 817, 0, 424, 404, 890, 0, 0, 422, 372, 456, + 412, 462, 443, 470, 418, 413, 294, 444, 334, 385, + 307, 309, 329, 336, 338, 342, 343, 394, 395, 407, + 429, 446, 447, 448, 333, 317, 423, 318, 353, 319, + 295, 325, 323, 326, 431, 327, 297, 408, 452, 0, + 348, 419, 380, 298, 379, 409, 451, 450, 308, 478, + 484, 485, 574, 0, 490, 662, 663, 664, 499, 0, + 414, 0, 504, 505, 506, 508, 509, 510, 511, 575, + 592, 559, 529, 492, 583, 526, 530, 531, 358, 595, + 0, 0, 0, 483, 368, 369, 0, 340, 339, 381, + 417, 299, 346, 291, 292, 657, 874, 400, 597, 630, + 631, 522, 0, 889, 869, 871, 872, 876, 880, 881, + 882, 883, 884, 886, 888, 892, 656, 0, 576, 591, + 660, 590, 653, 406, 0, 428, 588, 535, 0, 580, + 554, 0, 581, 550, 585, 0, 524, 0, 436, 464, + 476, 493, 496, 525, 610, 611, 612, 296, 495, 614, + 615, 616, 617, 618, 619, 620, 613, 891, 557, 534, + 560, 475, 537, 536, 0, 0, 571, 821, 572, 573, + 390, 391, 392, 393, 878, 598, 315, 494, 416, 0, + 558, 0, 0, 0, 0, 0, 0, 0, 0, 563, + 564, 561, 665, 0, 621, 622, 0, 0, 488, 489, + 345, 352, 507, 354, 314, 405, 347, 473, 362, 0, + 500, 565, 501, 624, 627, 625, 626, 397, 357, 359, + 432, 363, 373, 420, 472, 403, 425, 312, 463, 434, + 378, 551, 578, 900, 873, 899, 901, 902, 898, 903, + 904, 885, 776, 0, 828, 896, 895, 897, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 606, + 605, 604, 603, 602, 601, 600, 599, 0, 0, 548, + 449, 324, 285, 320, 321, 328, 654, 651, 454, 655, + 783, 293, 528, 371, 0, 415, 344, 593, 594, 0, + 645, 862, 835, 836, 837, 773, 838, 832, 833, 774, + 834, 863, 826, 859, 860, 802, 829, 839, 858, 840, + 861, 864, 865, 905, 906, 846, 830, 257, 907, 843, + 866, 857, 856, 841, 827, 867, 868, 809, 804, 844, + 845, 831, 850, 851, 852, 775, 823, 824, 825, 847, + 848, 805, 806, 807, 808, 0, 0, 0, 479, 480, + 481, 503, 0, 465, 527, 652, 0, 0, 0, 0, + 0, 0, 0, 577, 589, 623, 0, 633, 634, 636, + 638, 853, 640, 439, 440, 647, 0, 3577, 643, 3578, + 3579, 375, 426, 445, 433, 819, 658, 518, 519, 659, + 629, 0, 768, 0, 402, 0, 0, 533, 566, 555, + 639, 521, 0, 0, 0, 0, 0, 0, 771, 0, + 0, 0, 337, 0, 0, 370, 570, 552, 562, 553, + 538, 539, 540, 547, 349, 541, 542, 543, 513, 544, + 514, 545, 546, 810, 569, 520, 435, 386, 587, 586, + 0, 0, 879, 887, 0, 0, 0, 0, 0, 0, + 0, 0, 875, 0, 0, 0, 0, 763, 0, 0, + 800, 855, 854, 787, 797, 0, 0, 310, 229, 515, + 635, 517, 516, 2745, 0, 2746, 793, 796, 792, 790, + 791, 0, 870, 0, 0, 0, 0, 0, 0, 755, + 767, 0, 772, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 764, 765, 0, 0, + 0, 0, 820, 0, 766, 0, 0, 815, 794, 798, + 0, 0, 0, 0, 300, 442, 461, 311, 430, 474, + 316, 438, 453, 306, 401, 427, 0, 0, 302, 459, + 437, 383, 360, 361, 301, 0, 421, 335, 351, 332, + 399, 795, 818, 822, 331, 893, 816, 469, 304, 0, + 468, 398, 455, 460, 384, 377, 0, 303, 457, 382, + 376, 364, 341, 894, 365, 366, 355, 410, 374, 411, + 356, 388, 387, 389, 0, 0, 0, 0, 0, 497, + 498, 0, 0, 646, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 628, 813, 0, 632, 0, + 471, 0, 0, 877, 0, 0, 0, 441, 0, 0, + 367, 0, 0, 0, 817, 0, 424, 404, 890, 0, + 0, 422, 372, 456, 412, 462, 443, 470, 418, 413, + 294, 444, 334, 385, 307, 309, 329, 336, 338, 342, + 343, 394, 395, 407, 429, 446, 447, 448, 333, 317, + 423, 318, 353, 319, 295, 325, 323, 326, 431, 327, + 297, 408, 452, 0, 348, 419, 380, 298, 379, 409, + 451, 450, 308, 478, 484, 485, 574, 0, 490, 662, + 663, 664, 499, 0, 414, 0, 504, 505, 506, 508, + 509, 510, 511, 575, 592, 559, 529, 492, 583, 526, + 530, 531, 358, 595, 0, 0, 0, 483, 368, 369, + 0, 340, 339, 381, 417, 299, 346, 291, 292, 657, + 874, 400, 597, 630, 631, 522, 0, 889, 869, 871, + 872, 876, 880, 881, 882, 883, 884, 886, 888, 892, + 656, 0, 576, 591, 660, 590, 653, 406, 0, 428, + 588, 535, 0, 580, 554, 0, 581, 550, 585, 0, + 524, 0, 436, 464, 476, 493, 496, 525, 610, 611, + 612, 296, 495, 614, 615, 616, 617, 618, 619, 620, + 613, 891, 557, 534, 560, 475, 537, 536, 0, 0, + 571, 821, 572, 573, 390, 391, 392, 393, 878, 598, + 315, 494, 416, 0, 558, 0, 0, 0, 0, 0, + 0, 0, 0, 563, 564, 561, 665, 0, 621, 622, + 0, 0, 488, 489, 345, 352, 507, 354, 314, 405, + 347, 473, 362, 0, 500, 565, 501, 624, 627, 625, + 626, 397, 357, 359, 432, 363, 373, 420, 472, 403, + 425, 312, 463, 434, 378, 551, 578, 900, 873, 899, + 901, 902, 898, 903, 904, 885, 776, 0, 828, 896, + 895, 897, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 606, 605, 604, 603, 602, 601, 600, + 599, 0, 0, 548, 449, 324, 285, 320, 321, 328, + 654, 651, 454, 655, 783, 293, 528, 371, 0, 415, + 344, 593, 594, 0, 645, 862, 835, 836, 837, 773, + 838, 832, 833, 774, 834, 863, 826, 859, 860, 802, + 829, 839, 858, 840, 861, 864, 865, 905, 906, 846, + 830, 257, 907, 843, 866, 857, 856, 841, 827, 867, + 868, 809, 804, 844, 845, 831, 850, 851, 852, 775, + 823, 824, 825, 847, 848, 805, 806, 807, 808, 0, + 0, 0, 479, 480, 481, 503, 0, 465, 527, 652, + 0, 0, 0, 0, 0, 0, 0, 577, 589, 623, + 0, 633, 634, 636, 638, 853, 640, 439, 440, 647, + 0, 849, 643, 644, 641, 375, 426, 445, 433, 819, + 658, 518, 519, 659, 629, 0, 768, 0, 402, 0, + 0, 533, 566, 555, 639, 521, 0, 0, 1736, 0, + 0, 0, 771, 0, 0, 0, 337, 0, 0, 370, + 570, 552, 562, 553, 538, 539, 540, 547, 349, 541, + 542, 543, 513, 544, 514, 545, 546, 810, 569, 520, + 435, 386, 587, 586, 0, 0, 879, 887, 0, 0, + 0, 0, 0, 0, 0, 0, 875, 0, 0, 0, + 0, 763, 0, 0, 800, 855, 854, 787, 797, 0, + 0, 310, 229, 515, 635, 517, 516, 788, 0, 789, + 793, 796, 792, 790, 791, 0, 870, 0, 0, 0, + 0, 0, 0, 0, 767, 0, 772, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 764, 765, 0, 0, 0, 0, 820, 0, 766, 0, + 0, 815, 794, 798, 0, 0, 0, 0, 300, 442, + 461, 311, 430, 474, 316, 438, 453, 306, 401, 427, + 0, 0, 302, 459, 437, 383, 360, 361, 301, 0, + 421, 335, 351, 332, 399, 795, 818, 822, 331, 893, + 816, 469, 304, 0, 468, 398, 455, 460, 384, 377, + 0, 303, 457, 382, 376, 364, 341, 894, 365, 366, + 355, 410, 374, 411, 356, 388, 387, 389, 0, 0, + 0, 0, 0, 497, 498, 0, 0, 646, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 628, + 813, 0, 632, 0, 471, 0, 0, 877, 0, 0, + 0, 441, 0, 0, 367, 0, 0, 0, 817, 0, + 424, 404, 890, 0, 0, 422, 372, 456, 412, 462, + 443, 470, 418, 413, 294, 444, 334, 385, 307, 309, + 329, 336, 338, 342, 343, 394, 395, 407, 429, 446, + 447, 448, 333, 317, 423, 318, 353, 319, 295, 325, + 323, 326, 431, 327, 297, 408, 452, 0, 348, 419, + 380, 298, 379, 409, 451, 450, 308, 478, 1737, 1738, + 574, 0, 490, 662, 663, 664, 499, 0, 414, 0, + 504, 505, 506, 508, 509, 510, 511, 575, 592, 559, + 529, 492, 583, 526, 530, 531, 358, 595, 0, 0, + 0, 483, 368, 369, 0, 340, 339, 381, 417, 299, + 346, 291, 292, 657, 874, 400, 597, 630, 631, 522, + 0, 889, 869, 871, 872, 876, 880, 881, 882, 883, + 884, 886, 888, 892, 656, 0, 576, 591, 660, 590, + 653, 406, 0, 428, 588, 535, 0, 580, 554, 0, + 581, 550, 585, 0, 524, 0, 436, 464, 476, 493, + 496, 525, 610, 611, 612, 296, 495, 614, 615, 616, + 617, 618, 619, 620, 613, 891, 557, 534, 560, 475, + 537, 536, 0, 0, 571, 821, 572, 573, 390, 391, + 392, 393, 878, 598, 315, 494, 416, 0, 558, 0, + 0, 0, 0, 0, 0, 0, 0, 563, 564, 561, + 665, 0, 621, 622, 0, 0, 488, 489, 345, 352, + 507, 354, 314, 405, 347, 473, 362, 0, 500, 565, + 501, 624, 627, 625, 626, 397, 357, 359, 432, 363, + 373, 420, 472, 403, 425, 312, 463, 434, 378, 551, + 578, 900, 873, 899, 901, 902, 898, 903, 904, 885, + 776, 0, 828, 896, 895, 897, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 606, 605, 604, + 603, 602, 601, 600, 599, 0, 0, 548, 449, 324, + 285, 320, 321, 328, 654, 651, 454, 655, 783, 293, + 528, 371, 0, 415, 344, 593, 594, 0, 645, 862, + 835, 836, 837, 773, 838, 832, 833, 774, 834, 863, + 826, 859, 860, 802, 829, 839, 858, 840, 861, 864, + 865, 905, 906, 846, 830, 257, 907, 843, 866, 857, + 856, 841, 827, 867, 868, 809, 804, 844, 845, 831, + 850, 851, 852, 775, 823, 824, 825, 847, 848, 805, + 806, 807, 808, 0, 0, 0, 479, 480, 481, 503, + 0, 465, 527, 652, 0, 0, 0, 0, 0, 0, + 0, 577, 589, 623, 0, 633, 634, 636, 638, 853, + 640, 439, 440, 647, 0, 849, 643, 644, 641, 375, + 426, 445, 433, 819, 658, 518, 519, 659, 629, 0, + 768, 0, 402, 0, 0, 533, 566, 555, 639, 521, + 0, 0, 0, 0, 0, 0, 771, 0, 0, 0, + 337, 0, 0, 370, 570, 552, 562, 553, 538, 539, + 540, 547, 349, 541, 542, 543, 513, 544, 514, 545, + 546, 810, 569, 520, 435, 386, 587, 586, 0, 0, + 879, 887, 0, 0, 0, 0, 0, 0, 0, 0, + 875, 0, 0, 0, 0, 763, 0, 0, 800, 855, + 854, 787, 797, 0, 0, 310, 229, 515, 635, 517, + 516, 788, 0, 789, 793, 796, 792, 790, 791, 0, + 870, 0, 0, 0, 0, 0, 0, 0, 767, 0, + 772, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 764, 765, 0, 0, 0, 0, + 820, 0, 766, 0, 0, 815, 794, 798, 0, 0, + 0, 0, 300, 442, 461, 311, 430, 474, 316, 438, + 453, 306, 401, 427, 0, 0, 302, 459, 437, 383, + 360, 361, 301, 0, 421, 335, 351, 332, 399, 795, + 818, 822, 331, 893, 816, 469, 304, 0, 468, 398, + 455, 460, 384, 377, 0, 303, 457, 382, 376, 364, + 341, 894, 365, 366, 355, 410, 374, 411, 356, 388, + 387, 389, 0, 0, 0, 0, 0, 497, 498, 0, + 0, 646, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 628, 813, 0, 632, 0, 471, 0, + 0, 877, 0, 0, 0, 441, 0, 0, 367, 0, + 0, 0, 817, 0, 424, 404, 890, 0, 0, 422, + 372, 456, 412, 462, 443, 470, 418, 413, 294, 444, + 334, 385, 307, 309, 329, 336, 338, 342, 343, 394, + 395, 407, 429, 446, 447, 448, 333, 317, 423, 318, + 353, 319, 295, 325, 323, 326, 431, 327, 297, 408, + 452, 0, 348, 419, 380, 298, 379, 409, 451, 450, + 308, 478, 484, 485, 574, 0, 490, 662, 663, 664, + 499, 0, 414, 0, 504, 505, 506, 508, 509, 510, + 511, 575, 592, 559, 529, 492, 583, 526, 530, 531, + 358, 595, 0, 0, 0, 483, 368, 369, 0, 340, + 339, 381, 417, 299, 346, 291, 292, 657, 874, 400, + 597, 630, 631, 522, 0, 889, 869, 871, 872, 876, + 880, 881, 882, 883, 884, 886, 888, 892, 656, 0, + 576, 591, 660, 590, 653, 406, 0, 428, 588, 535, + 0, 580, 554, 0, 581, 550, 585, 0, 524, 0, + 436, 464, 476, 493, 496, 525, 610, 611, 612, 296, + 495, 614, 615, 616, 617, 618, 619, 620, 613, 891, + 557, 534, 560, 475, 537, 536, 0, 0, 571, 821, + 572, 573, 390, 391, 392, 393, 878, 598, 315, 494, + 416, 0, 558, 0, 0, 0, 0, 0, 0, 0, + 0, 563, 564, 561, 665, 0, 621, 622, 0, 0, + 488, 489, 345, 352, 507, 354, 314, 405, 347, 473, + 362, 0, 500, 565, 501, 624, 627, 625, 626, 397, + 357, 359, 432, 363, 373, 420, 472, 403, 425, 312, + 463, 434, 378, 551, 578, 900, 873, 899, 901, 902, + 898, 903, 904, 885, 776, 0, 828, 896, 895, 897, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 606, 605, 604, 603, 602, 601, 600, 599, 0, + 0, 548, 449, 324, 285, 320, 321, 328, 654, 651, + 454, 655, 783, 293, 528, 371, 0, 415, 344, 593, + 594, 0, 645, 862, 835, 836, 837, 773, 838, 832, + 833, 774, 834, 863, 826, 859, 860, 802, 829, 839, + 858, 840, 861, 864, 865, 905, 906, 846, 830, 257, + 907, 843, 866, 857, 856, 841, 827, 867, 868, 809, + 804, 844, 845, 831, 850, 851, 852, 775, 823, 824, + 825, 847, 848, 805, 806, 807, 808, 0, 0, 0, + 479, 480, 481, 503, 0, 465, 527, 652, 0, 0, + 0, 0, 0, 0, 0, 577, 589, 623, 0, 633, + 634, 636, 638, 853, 640, 439, 440, 647, 0, 849, + 643, 644, 641, 375, 426, 445, 433, 819, 658, 518, + 519, 659, 629, 0, 768, 0, 402, 0, 0, 533, + 566, 555, 639, 521, 0, 0, 0, 0, 0, 0, + 771, 0, 0, 0, 337, 0, 0, 370, 570, 552, + 562, 553, 538, 539, 540, 547, 349, 541, 542, 543, + 513, 544, 514, 545, 546, 810, 569, 520, 435, 386, + 587, 586, 0, 0, 879, 887, 0, 0, 0, 0, + 0, 0, 0, 0, 875, 0, 0, 0, 0, 0, + 0, 0, 800, 855, 854, 787, 797, 0, 0, 310, + 229, 515, 635, 517, 516, 788, 0, 789, 793, 796, + 792, 790, 791, 0, 870, 0, 0, 0, 0, 0, + 0, 755, 767, 0, 772, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 764, 765, + 0, 0, 0, 0, 820, 0, 766, 0, 0, 815, + 794, 798, 0, 0, 0, 0, 300, 442, 461, 311, + 430, 474, 316, 438, 453, 306, 401, 427, 0, 0, + 302, 459, 437, 383, 360, 361, 301, 0, 421, 335, + 351, 332, 399, 795, 818, 822, 331, 893, 816, 469, + 304, 0, 468, 398, 455, 460, 384, 377, 0, 303, + 457, 382, 376, 364, 341, 894, 365, 366, 355, 410, + 374, 411, 356, 388, 387, 389, 0, 0, 0, 0, + 0, 497, 498, 0, 0, 646, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 628, 813, 0, + 632, 0, 471, 0, 0, 877, 0, 0, 0, 441, + 0, 0, 367, 0, 0, 0, 817, 0, 424, 404, + 890, 0, 0, 422, 372, 456, 412, 462, 443, 470, + 418, 413, 294, 444, 334, 385, 307, 309, 329, 336, + 338, 342, 343, 394, 395, 407, 429, 446, 447, 448, + 333, 317, 423, 318, 353, 319, 295, 325, 323, 326, + 431, 327, 297, 408, 452, 0, 348, 419, 380, 298, + 379, 409, 451, 450, 308, 478, 484, 485, 574, 0, + 490, 662, 663, 664, 499, 0, 414, 0, 504, 505, + 506, 508, 509, 510, 511, 575, 592, 559, 529, 492, + 583, 526, 530, 531, 358, 595, 0, 0, 0, 483, + 368, 369, 0, 340, 339, 381, 417, 299, 346, 291, + 292, 657, 874, 400, 597, 630, 631, 522, 0, 889, + 869, 871, 872, 876, 880, 881, 882, 883, 884, 886, + 888, 892, 656, 0, 576, 591, 660, 590, 653, 406, + 0, 428, 588, 535, 0, 580, 554, 0, 581, 550, + 585, 0, 524, 0, 436, 464, 476, 493, 496, 525, + 610, 611, 612, 296, 495, 614, 615, 616, 617, 618, + 619, 620, 613, 891, 557, 534, 560, 475, 537, 536, + 0, 0, 571, 821, 572, 573, 390, 391, 392, 393, + 878, 598, 315, 494, 416, 0, 558, 0, 0, 0, + 0, 0, 0, 0, 0, 563, 564, 561, 665, 0, + 621, 622, 0, 0, 488, 489, 345, 352, 507, 354, + 314, 405, 347, 473, 362, 0, 500, 565, 501, 624, + 627, 625, 626, 397, 357, 359, 432, 363, 373, 420, + 472, 403, 425, 312, 463, 434, 378, 551, 578, 900, + 873, 899, 901, 902, 898, 903, 904, 885, 776, 0, + 828, 896, 895, 897, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 606, 605, 604, 603, 602, + 601, 600, 599, 0, 0, 548, 449, 324, 285, 320, + 321, 328, 654, 651, 454, 655, 783, 293, 528, 371, + 0, 415, 344, 593, 594, 0, 645, 862, 835, 836, + 837, 773, 838, 832, 833, 774, 834, 863, 826, 859, + 860, 802, 829, 839, 858, 840, 861, 864, 865, 905, + 906, 846, 830, 257, 907, 843, 866, 857, 856, 841, + 827, 867, 868, 809, 804, 844, 845, 831, 850, 851, + 852, 775, 823, 824, 825, 847, 848, 805, 806, 807, + 808, 0, 0, 0, 479, 480, 481, 503, 0, 465, + 527, 652, 0, 0, 0, 0, 0, 0, 0, 577, + 589, 623, 0, 633, 634, 636, 638, 853, 640, 439, + 440, 647, 0, 849, 643, 644, 641, 375, 426, 445, + 433, 0, 658, 518, 519, 659, 629, 0, 768, 206, + 64, 197, 168, 0, 0, 0, 0, 0, 0, 402, + 0, 0, 533, 566, 555, 639, 521, 0, 198, 0, + 0, 0, 0, 0, 0, 189, 0, 337, 0, 199, + 370, 570, 552, 562, 553, 538, 539, 540, 547, 349, + 541, 542, 543, 513, 544, 514, 545, 546, 140, 569, + 520, 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, 126, 0, 0, 0, 0, 0, 0, 0, 0, 202, 0, 0, 228, 0, 0, 0, 0, - 0, 0, 309, 229, 514, 634, 516, 515, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 312, 0, 0, + 0, 0, 310, 229, 515, 635, 517, 516, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 313, 0, 0, 0, 0, 0, 0, 0, 0, 0, 220, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 299, - 441, 460, 310, 429, 473, 315, 437, 452, 305, 400, - 426, 0, 0, 301, 458, 436, 382, 359, 360, 300, - 0, 420, 334, 350, 331, 398, 0, 457, 485, 330, - 476, 0, 468, 303, 0, 467, 397, 454, 459, 383, - 376, 0, 302, 456, 381, 375, 363, 340, 501, 364, - 365, 354, 409, 373, 410, 355, 387, 386, 388, 0, - 0, 0, 0, 0, 496, 497, 0, 0, 645, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 300, + 442, 461, 311, 430, 474, 316, 438, 453, 306, 401, + 427, 0, 0, 302, 459, 437, 383, 360, 361, 301, + 0, 421, 335, 351, 332, 399, 0, 458, 486, 331, + 477, 0, 469, 304, 0, 468, 398, 455, 460, 384, + 377, 0, 303, 457, 382, 376, 364, 341, 502, 365, + 366, 355, 410, 374, 411, 356, 388, 387, 389, 0, + 0, 0, 0, 0, 497, 498, 0, 0, 646, 0, 0, 0, 0, 167, 195, 204, 196, 124, 0, 0, - 627, 0, 0, 631, 0, 470, 0, 0, 221, 0, - 0, 0, 440, 0, 0, 366, 194, 188, 187, 486, - 0, 423, 403, 233, 0, 0, 421, 371, 455, 411, - 461, 442, 469, 417, 412, 294, 443, 333, 384, 306, - 308, 328, 335, 337, 341, 342, 393, 394, 406, 428, - 445, 446, 447, 332, 316, 422, 317, 352, 318, 295, - 324, 322, 325, 430, 326, 297, 407, 451, 0, 347, - 418, 379, 298, 378, 408, 450, 449, 307, 477, 483, - 484, 573, 0, 489, 606, 607, 608, 498, 0, 413, - 0, 503, 504, 505, 507, 508, 509, 510, 574, 591, - 558, 528, 491, 582, 525, 529, 530, 357, 594, 0, - 0, 0, 482, 367, 368, 0, 339, 338, 380, 416, - 345, 291, 292, 465, 329, 399, 596, 629, 630, 521, - 0, 583, 522, 531, 321, 555, 567, 566, 395, 481, - 224, 578, 581, 511, 234, 0, 575, 590, 548, 589, - 235, 405, 0, 427, 587, 534, 0, 579, 553, 0, - 580, 549, 584, 0, 523, 0, 435, 463, 475, 492, - 495, 524, 609, 610, 611, 296, 494, 613, 614, 615, - 616, 617, 618, 619, 612, 466, 556, 533, 559, 474, - 536, 535, 0, 0, 570, 490, 571, 572, 389, 390, - 391, 392, 349, 597, 314, 493, 415, 138, 557, 0, - 0, 0, 0, 0, 0, 0, 0, 562, 563, 560, - 232, 0, 620, 621, 0, 0, 487, 488, 344, 351, - 506, 353, 313, 404, 346, 472, 361, 0, 499, 564, - 500, 623, 626, 624, 625, 396, 356, 358, 431, 362, - 372, 419, 471, 402, 424, 311, 462, 433, 377, 550, - 577, 0, 0, 0, 0, 0, 0, 0, 0, 65, - 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 605, 604, 603, - 602, 601, 600, 599, 598, 0, 0, 547, 448, 323, - 285, 319, 320, 327, 239, 304, 453, 240, 0, 293, - 527, 370, 169, 414, 343, 592, 593, 61, 644, 241, - 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, - 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, - 263, 264, 265, 595, 256, 257, 266, 267, 268, 269, - 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, - 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, - 282, 283, 284, 0, 0, 0, 478, 479, 480, 502, - 0, 464, 526, 236, 45, 222, 225, 227, 226, 0, - 62, 576, 588, 622, 5, 632, 633, 635, 637, 636, - 639, 438, 439, 646, 0, 641, 642, 643, 640, 374, - 425, 444, 432, 143, 237, 517, 518, 238, 628, 206, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 401, - 0, 0, 532, 565, 554, 638, 520, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 336, 0, 0, - 369, 569, 551, 561, 552, 537, 538, 539, 546, 348, - 540, 541, 542, 512, 543, 513, 544, 545, 140, 568, - 519, 434, 385, 586, 585, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 202, 0, 0, 228, 0, 0, 0, 0, - 0, 0, 309, 229, 514, 634, 516, 515, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 312, 2417, 2420, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 299, - 441, 460, 310, 429, 473, 315, 437, 452, 305, 400, - 426, 0, 0, 301, 458, 436, 382, 359, 360, 300, - 0, 420, 334, 350, 331, 398, 0, 457, 485, 330, - 476, 0, 468, 303, 0, 467, 397, 454, 459, 383, - 376, 0, 302, 456, 381, 375, 363, 340, 501, 364, - 365, 354, 409, 373, 410, 355, 387, 386, 388, 0, - 0, 0, 0, 0, 496, 497, 0, 0, 645, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 627, 0, 0, 631, 2421, 470, 0, 0, 0, 2416, - 0, 2415, 440, 2413, 2418, 366, 0, 0, 0, 486, - 0, 423, 403, 660, 0, 0, 421, 371, 455, 411, - 461, 442, 469, 417, 412, 294, 443, 333, 384, 306, - 308, 328, 335, 337, 341, 342, 393, 394, 406, 428, - 445, 446, 447, 332, 316, 422, 317, 352, 318, 295, - 324, 322, 325, 430, 326, 297, 407, 451, 2419, 347, - 418, 379, 298, 378, 408, 450, 449, 307, 477, 483, - 484, 573, 0, 489, 661, 662, 663, 498, 0, 413, - 0, 503, 504, 505, 507, 508, 509, 510, 574, 591, - 558, 528, 491, 582, 525, 529, 530, 357, 594, 0, - 0, 0, 482, 367, 368, 0, 339, 338, 380, 416, - 345, 291, 292, 656, 329, 399, 596, 629, 630, 521, - 0, 583, 522, 531, 321, 555, 567, 566, 395, 481, - 0, 578, 581, 511, 655, 0, 575, 590, 659, 589, - 652, 405, 0, 427, 587, 534, 0, 579, 553, 0, - 580, 549, 584, 0, 523, 0, 435, 463, 475, 492, - 495, 524, 609, 610, 611, 296, 494, 613, 614, 615, - 616, 617, 618, 619, 612, 466, 556, 533, 559, 474, - 536, 535, 0, 0, 570, 490, 571, 572, 389, 390, - 391, 392, 349, 597, 314, 493, 415, 0, 557, 0, - 0, 0, 0, 0, 0, 0, 0, 562, 563, 560, - 664, 0, 620, 621, 0, 0, 487, 488, 344, 351, - 506, 353, 313, 404, 346, 472, 361, 0, 499, 564, - 500, 623, 626, 624, 625, 396, 356, 358, 431, 362, - 372, 419, 471, 402, 424, 311, 462, 433, 377, 550, - 577, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 605, 604, 603, - 602, 601, 600, 599, 598, 0, 0, 547, 448, 323, - 285, 319, 320, 327, 653, 650, 453, 654, 0, 293, - 527, 370, 169, 414, 343, 592, 593, 0, 644, 241, - 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, - 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, - 263, 264, 265, 595, 256, 257, 266, 267, 268, 269, - 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, - 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, - 282, 283, 284, 0, 0, 0, 478, 479, 480, 502, - 0, 464, 526, 651, 0, 0, 0, 0, 0, 0, - 0, 576, 588, 622, 0, 632, 633, 635, 637, 636, - 639, 438, 439, 646, 0, 641, 642, 643, 640, 374, - 425, 444, 432, 0, 657, 517, 518, 658, 628, 401, - 0, 0, 532, 565, 554, 638, 520, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 336, 0, 0, - 369, 569, 551, 561, 552, 537, 538, 539, 546, 348, - 540, 541, 542, 512, 543, 513, 544, 545, 0, 568, - 519, 434, 385, 586, 585, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1331, 0, 0, 228, 0, 0, 786, 796, - 0, 0, 309, 229, 514, 634, 516, 515, 787, 0, - 788, 792, 795, 791, 789, 790, 0, 312, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 793, 0, 0, 0, 0, 0, 299, - 441, 460, 310, 429, 473, 315, 437, 452, 305, 400, - 426, 0, 0, 301, 458, 436, 382, 359, 360, 300, - 0, 420, 334, 350, 331, 398, 794, 457, 485, 330, - 476, 0, 468, 303, 0, 467, 397, 454, 459, 383, - 376, 0, 302, 456, 381, 375, 363, 340, 501, 364, - 365, 354, 409, 373, 410, 355, 387, 386, 388, 0, - 0, 0, 0, 0, 496, 497, 0, 0, 645, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 627, 0, 0, 631, 0, 470, 0, 0, 0, 0, - 0, 0, 440, 0, 0, 366, 0, 0, 0, 486, - 0, 423, 403, 660, 0, 0, 421, 371, 455, 411, - 461, 442, 469, 417, 412, 294, 443, 333, 384, 306, - 308, 328, 335, 337, 341, 342, 393, 394, 406, 428, - 445, 446, 447, 332, 316, 422, 317, 352, 318, 295, - 324, 322, 325, 430, 326, 297, 407, 451, 0, 347, - 418, 379, 298, 378, 408, 450, 449, 307, 477, 483, - 484, 573, 0, 489, 661, 662, 663, 498, 0, 413, - 0, 503, 504, 505, 507, 508, 509, 510, 574, 591, - 558, 528, 491, 582, 525, 529, 530, 357, 594, 0, - 0, 0, 482, 367, 368, 0, 339, 338, 380, 416, - 345, 291, 292, 656, 329, 399, 596, 629, 630, 521, - 0, 583, 522, 531, 321, 555, 567, 566, 395, 481, - 0, 578, 581, 511, 655, 0, 575, 590, 659, 589, - 652, 405, 0, 427, 587, 534, 0, 579, 553, 0, - 580, 549, 584, 0, 523, 0, 435, 463, 475, 492, - 495, 524, 609, 610, 611, 296, 494, 613, 614, 615, - 616, 617, 618, 619, 612, 466, 556, 533, 559, 474, - 536, 535, 0, 0, 570, 490, 571, 572, 389, 390, - 391, 392, 349, 597, 314, 493, 415, 0, 557, 0, - 0, 0, 0, 0, 0, 0, 0, 562, 563, 560, - 664, 0, 620, 621, 0, 0, 487, 488, 344, 351, - 506, 353, 313, 404, 346, 472, 361, 0, 499, 564, - 500, 623, 626, 624, 625, 396, 356, 358, 431, 362, - 372, 419, 471, 402, 424, 311, 462, 433, 377, 550, - 577, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 605, 604, 603, - 602, 601, 600, 599, 598, 0, 0, 547, 448, 323, - 285, 319, 320, 327, 653, 650, 453, 654, 0, 293, - 527, 370, 0, 414, 343, 592, 593, 0, 644, 241, - 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, - 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, - 263, 264, 265, 595, 256, 257, 266, 267, 268, 269, - 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, - 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, - 282, 283, 284, 0, 0, 0, 478, 479, 480, 502, - 0, 464, 526, 651, 0, 0, 0, 0, 0, 0, - 0, 576, 588, 622, 0, 632, 633, 635, 637, 636, - 639, 438, 439, 646, 0, 641, 642, 643, 640, 374, - 425, 444, 432, 0, 657, 517, 518, 658, 628, 206, - 64, 197, 168, 0, 0, 0, 0, 0, 0, 401, - 683, 0, 532, 565, 554, 638, 520, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 336, 0, 0, - 369, 569, 551, 561, 552, 537, 538, 539, 546, 348, - 540, 541, 542, 512, 543, 513, 544, 545, 0, 568, - 519, 434, 385, 586, 585, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 690, 0, 0, 0, 0, 0, - 0, 0, 689, 0, 0, 228, 0, 0, 0, 0, - 0, 0, 309, 229, 514, 634, 516, 515, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 312, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 299, - 441, 460, 310, 429, 473, 315, 437, 452, 305, 400, - 426, 0, 0, 301, 458, 436, 382, 359, 360, 300, - 0, 420, 334, 350, 331, 398, 0, 457, 485, 330, - 476, 0, 468, 303, 0, 467, 397, 454, 459, 383, - 376, 0, 302, 456, 381, 375, 363, 340, 501, 364, - 365, 354, 409, 373, 410, 355, 387, 386, 388, 0, - 0, 0, 0, 0, 496, 497, 0, 0, 645, 0, - 0, 0, 0, 0, 0, 0, 0, 687, 688, 0, - 627, 0, 0, 631, 0, 470, 0, 0, 0, 0, - 0, 0, 440, 0, 0, 366, 0, 0, 0, 486, - 0, 423, 403, 660, 0, 0, 421, 371, 455, 411, - 461, 442, 469, 417, 412, 294, 443, 333, 384, 306, - 308, 328, 335, 337, 341, 342, 393, 394, 406, 428, - 445, 446, 447, 332, 316, 422, 317, 352, 318, 295, - 324, 322, 325, 430, 326, 297, 407, 451, 0, 347, - 418, 379, 298, 378, 408, 450, 449, 307, 477, 483, - 484, 573, 0, 489, 661, 662, 663, 498, 0, 413, - 0, 503, 504, 505, 507, 508, 509, 510, 574, 591, - 558, 528, 491, 582, 525, 529, 530, 357, 594, 0, - 0, 0, 482, 367, 368, 0, 339, 338, 380, 416, - 345, 291, 292, 656, 329, 399, 596, 629, 630, 521, - 0, 583, 522, 531, 321, 555, 567, 566, 395, 481, - 0, 578, 581, 511, 655, 0, 575, 590, 659, 589, - 652, 405, 0, 427, 587, 534, 0, 579, 553, 0, - 580, 549, 584, 0, 523, 0, 435, 463, 475, 492, - 495, 524, 609, 610, 611, 296, 494, 613, 614, 615, - 616, 617, 618, 619, 612, 466, 556, 533, 559, 474, - 536, 535, 0, 0, 570, 490, 571, 572, 389, 390, - 391, 392, 684, 686, 314, 493, 415, 698, 557, 0, - 0, 0, 0, 0, 0, 0, 0, 562, 563, 560, - 664, 0, 620, 621, 0, 0, 487, 488, 344, 351, - 506, 353, 313, 404, 346, 472, 361, 0, 499, 564, - 500, 623, 626, 624, 625, 396, 356, 358, 431, 362, - 372, 419, 471, 402, 424, 311, 462, 433, 377, 550, - 577, 0, 0, 0, 0, 0, 0, 0, 0, 65, - 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 605, 604, 603, - 602, 601, 600, 599, 598, 0, 0, 547, 448, 323, - 285, 319, 320, 327, 653, 650, 453, 654, 0, 293, - 527, 370, 169, 414, 343, 592, 593, 0, 644, 241, - 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, - 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, - 263, 264, 265, 595, 256, 257, 266, 267, 268, 269, - 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, - 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, - 282, 283, 284, 0, 0, 0, 478, 479, 480, 502, - 0, 464, 526, 651, 0, 0, 0, 0, 0, 0, - 0, 576, 588, 622, 0, 632, 633, 635, 637, 636, - 639, 438, 439, 646, 0, 641, 642, 643, 640, 374, - 425, 444, 432, 0, 657, 517, 518, 658, 628, 401, - 0, 0, 532, 565, 554, 638, 520, 0, 1139, 0, - 0, 0, 0, 0, 0, 0, 0, 336, 0, 0, - 369, 569, 551, 561, 552, 537, 538, 539, 546, 348, - 540, 541, 542, 512, 543, 513, 544, 545, 0, 568, - 519, 434, 385, 586, 585, 0, 0, 0, 0, 0, + 628, 0, 0, 632, 0, 471, 0, 0, 221, 0, + 0, 0, 441, 0, 0, 367, 194, 188, 187, 487, + 0, 424, 404, 233, 0, 0, 422, 372, 456, 412, + 462, 443, 470, 418, 413, 294, 444, 334, 385, 307, + 309, 329, 336, 338, 342, 343, 394, 395, 407, 429, + 446, 447, 448, 333, 317, 423, 318, 353, 319, 295, + 325, 323, 326, 431, 327, 297, 408, 452, 0, 348, + 419, 380, 298, 379, 409, 451, 450, 308, 478, 484, + 485, 574, 0, 490, 607, 608, 609, 499, 0, 414, + 0, 504, 505, 506, 508, 509, 510, 511, 575, 592, + 559, 529, 492, 583, 526, 530, 531, 358, 595, 0, + 0, 0, 483, 368, 369, 0, 340, 339, 381, 417, + 299, 346, 291, 292, 466, 330, 400, 597, 630, 631, + 522, 0, 584, 523, 532, 322, 556, 568, 567, 396, + 482, 224, 579, 582, 512, 234, 0, 576, 591, 549, + 590, 235, 406, 0, 428, 588, 535, 0, 580, 554, + 0, 581, 550, 585, 0, 524, 0, 436, 464, 476, + 493, 496, 525, 610, 611, 612, 296, 495, 614, 615, + 616, 617, 618, 619, 620, 613, 467, 557, 534, 560, + 475, 537, 536, 0, 0, 571, 491, 572, 573, 390, + 391, 392, 393, 350, 598, 315, 494, 416, 138, 558, + 0, 0, 0, 0, 0, 0, 0, 0, 563, 564, + 561, 232, 0, 621, 622, 0, 0, 488, 489, 345, + 352, 507, 354, 314, 405, 347, 473, 362, 0, 500, + 565, 501, 624, 627, 625, 626, 397, 357, 359, 432, + 363, 373, 420, 472, 403, 425, 312, 463, 434, 378, + 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, + 65, 0, 0, 280, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 606, 605, + 604, 603, 602, 601, 600, 599, 0, 0, 548, 449, + 324, 285, 320, 321, 328, 239, 305, 454, 240, 0, + 293, 528, 371, 169, 415, 344, 593, 594, 61, 645, + 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, + 250, 251, 252, 253, 254, 255, 258, 259, 260, 261, + 262, 263, 264, 265, 596, 256, 257, 266, 267, 268, + 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, + 279, 0, 0, 0, 287, 288, 289, 290, 0, 0, + 281, 282, 283, 284, 0, 0, 0, 479, 480, 481, + 503, 0, 465, 527, 236, 45, 222, 225, 227, 226, + 0, 62, 577, 589, 623, 5, 633, 634, 636, 638, + 637, 640, 439, 440, 647, 0, 642, 643, 644, 641, + 375, 426, 445, 433, 143, 237, 518, 519, 238, 629, + 206, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 402, 0, 0, 533, 566, 555, 639, 521, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 337, 0, + 0, 370, 570, 552, 562, 553, 538, 539, 540, 547, + 349, 541, 542, 543, 513, 544, 514, 545, 546, 140, + 569, 520, 435, 386, 587, 586, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 202, 0, 0, 228, 0, 0, 0, + 0, 0, 0, 310, 229, 515, 635, 517, 516, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 313, 2418, + 2421, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 300, 442, 461, 311, 430, 474, 316, 438, 453, 306, + 401, 427, 0, 0, 302, 459, 437, 383, 360, 361, + 301, 0, 421, 335, 351, 332, 399, 0, 458, 486, + 331, 477, 0, 469, 304, 0, 468, 398, 455, 460, + 384, 377, 0, 303, 457, 382, 376, 364, 341, 502, + 365, 366, 355, 410, 374, 411, 356, 388, 387, 389, + 0, 0, 0, 0, 0, 497, 498, 0, 0, 646, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 628, 0, 0, 632, 2422, 471, 0, 0, 0, + 2417, 0, 2416, 441, 2414, 2419, 367, 0, 0, 0, + 487, 0, 424, 404, 661, 0, 0, 422, 372, 456, + 412, 462, 443, 470, 418, 413, 294, 444, 334, 385, + 307, 309, 329, 336, 338, 342, 343, 394, 395, 407, + 429, 446, 447, 448, 333, 317, 423, 318, 353, 319, + 295, 325, 323, 326, 431, 327, 297, 408, 452, 2420, + 348, 419, 380, 298, 379, 409, 451, 450, 308, 478, + 484, 485, 574, 0, 490, 662, 663, 664, 499, 0, + 414, 0, 504, 505, 506, 508, 509, 510, 511, 575, + 592, 559, 529, 492, 583, 526, 530, 531, 358, 595, + 0, 0, 0, 483, 368, 369, 0, 340, 339, 381, + 417, 299, 346, 291, 292, 657, 330, 400, 597, 630, + 631, 522, 0, 584, 523, 532, 322, 556, 568, 567, + 396, 482, 0, 579, 582, 512, 656, 0, 576, 591, + 660, 590, 653, 406, 0, 428, 588, 535, 0, 580, + 554, 0, 581, 550, 585, 0, 524, 0, 436, 464, + 476, 493, 496, 525, 610, 611, 612, 296, 495, 614, + 615, 616, 617, 618, 619, 620, 613, 467, 557, 534, + 560, 475, 537, 536, 0, 0, 571, 491, 572, 573, + 390, 391, 392, 393, 350, 598, 315, 494, 416, 0, + 558, 0, 0, 0, 0, 0, 0, 0, 0, 563, + 564, 561, 665, 0, 621, 622, 0, 0, 488, 489, + 345, 352, 507, 354, 314, 405, 347, 473, 362, 0, + 500, 565, 501, 624, 627, 625, 626, 397, 357, 359, + 432, 363, 373, 420, 472, 403, 425, 312, 463, 434, + 378, 551, 578, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 606, + 605, 604, 603, 602, 601, 600, 599, 0, 0, 548, + 449, 324, 285, 320, 321, 328, 654, 651, 454, 655, + 0, 293, 528, 371, 169, 415, 344, 593, 594, 0, + 645, 241, 242, 243, 244, 245, 246, 247, 248, 286, + 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, + 261, 262, 263, 264, 265, 596, 256, 257, 266, 267, + 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, + 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, + 0, 281, 282, 283, 284, 0, 0, 0, 479, 480, + 481, 503, 0, 465, 527, 652, 0, 0, 0, 0, + 0, 0, 0, 577, 589, 623, 0, 633, 634, 636, + 638, 637, 640, 439, 440, 647, 0, 642, 643, 644, + 641, 375, 426, 445, 433, 0, 658, 518, 519, 659, + 629, 402, 0, 0, 533, 566, 555, 639, 521, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 337, + 0, 0, 370, 570, 552, 562, 553, 538, 539, 540, + 547, 349, 541, 542, 543, 513, 544, 514, 545, 546, + 0, 569, 520, 435, 386, 587, 586, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 1332, 0, 0, 228, 0, 0, + 787, 797, 0, 0, 310, 229, 515, 635, 517, 516, + 788, 0, 789, 793, 796, 792, 790, 791, 0, 313, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 794, 0, 0, 0, 0, + 0, 300, 442, 461, 311, 430, 474, 316, 438, 453, + 306, 401, 427, 0, 0, 302, 459, 437, 383, 360, + 361, 301, 0, 421, 335, 351, 332, 399, 795, 458, + 486, 331, 477, 0, 469, 304, 0, 468, 398, 455, + 460, 384, 377, 0, 303, 457, 382, 376, 364, 341, + 502, 365, 366, 355, 410, 374, 411, 356, 388, 387, + 389, 0, 0, 0, 0, 0, 497, 498, 0, 0, + 646, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 628, 0, 0, 632, 0, 471, 0, 0, + 0, 0, 0, 0, 441, 0, 0, 367, 0, 0, + 0, 487, 0, 424, 404, 661, 0, 0, 422, 372, + 456, 412, 462, 443, 470, 418, 413, 294, 444, 334, + 385, 307, 309, 329, 336, 338, 342, 343, 394, 395, + 407, 429, 446, 447, 448, 333, 317, 423, 318, 353, + 319, 295, 325, 323, 326, 431, 327, 297, 408, 452, + 0, 348, 419, 380, 298, 379, 409, 451, 450, 308, + 478, 484, 485, 574, 0, 490, 662, 663, 664, 499, + 0, 414, 0, 504, 505, 506, 508, 509, 510, 511, + 575, 592, 559, 529, 492, 583, 526, 530, 531, 358, + 595, 0, 0, 0, 483, 368, 369, 0, 340, 339, + 381, 417, 299, 346, 291, 292, 657, 330, 400, 597, + 630, 631, 522, 0, 584, 523, 532, 322, 556, 568, + 567, 396, 482, 0, 579, 582, 512, 656, 0, 576, + 591, 660, 590, 653, 406, 0, 428, 588, 535, 0, + 580, 554, 0, 581, 550, 585, 0, 524, 0, 436, + 464, 476, 493, 496, 525, 610, 611, 612, 296, 495, + 614, 615, 616, 617, 618, 619, 620, 613, 467, 557, + 534, 560, 475, 537, 536, 0, 0, 571, 491, 572, + 573, 390, 391, 392, 393, 350, 598, 315, 494, 416, + 0, 558, 0, 0, 0, 0, 0, 0, 0, 0, + 563, 564, 561, 665, 0, 621, 622, 0, 0, 488, + 489, 345, 352, 507, 354, 314, 405, 347, 473, 362, + 0, 500, 565, 501, 624, 627, 625, 626, 397, 357, + 359, 432, 363, 373, 420, 472, 403, 425, 312, 463, + 434, 378, 551, 578, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 606, 605, 604, 603, 602, 601, 600, 599, 0, 0, + 548, 449, 324, 285, 320, 321, 328, 654, 651, 454, + 655, 0, 293, 528, 371, 0, 415, 344, 593, 594, + 0, 645, 241, 242, 243, 244, 245, 246, 247, 248, + 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, + 260, 261, 262, 263, 264, 265, 596, 256, 257, 266, + 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, + 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, + 0, 0, 281, 282, 283, 284, 0, 0, 0, 479, + 480, 481, 503, 0, 465, 527, 652, 0, 0, 0, + 0, 0, 0, 0, 577, 589, 623, 0, 633, 634, + 636, 638, 637, 640, 439, 440, 647, 0, 642, 643, + 644, 641, 375, 426, 445, 433, 0, 658, 518, 519, + 659, 629, 206, 64, 197, 168, 0, 0, 0, 0, + 0, 0, 402, 684, 0, 533, 566, 555, 639, 521, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 337, 0, 0, 370, 570, 552, 562, 553, 538, 539, + 540, 547, 349, 541, 542, 543, 513, 544, 514, 545, + 546, 0, 569, 520, 435, 386, 587, 586, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 691, 0, 0, + 0, 0, 0, 0, 0, 690, 0, 0, 228, 0, + 0, 0, 0, 0, 0, 310, 229, 515, 635, 517, + 516, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 313, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 300, 442, 461, 311, 430, 474, 316, 438, + 453, 306, 401, 427, 0, 0, 302, 459, 437, 383, + 360, 361, 301, 0, 421, 335, 351, 332, 399, 0, + 458, 486, 331, 477, 0, 469, 304, 0, 468, 398, + 455, 460, 384, 377, 0, 303, 457, 382, 376, 364, + 341, 502, 365, 366, 355, 410, 374, 411, 356, 388, + 387, 389, 0, 0, 0, 0, 0, 497, 498, 0, + 0, 646, 0, 0, 0, 0, 0, 0, 0, 0, + 688, 689, 0, 628, 0, 0, 632, 0, 471, 0, + 0, 0, 0, 0, 0, 441, 0, 0, 367, 0, + 0, 0, 487, 0, 424, 404, 661, 0, 0, 422, + 372, 456, 412, 462, 443, 470, 418, 413, 294, 444, + 334, 385, 307, 309, 329, 336, 338, 342, 343, 394, + 395, 407, 429, 446, 447, 448, 333, 317, 423, 318, + 353, 319, 295, 325, 323, 326, 431, 327, 297, 408, + 452, 0, 348, 419, 380, 298, 379, 409, 451, 450, + 308, 478, 484, 485, 574, 0, 490, 662, 663, 664, + 499, 0, 414, 0, 504, 505, 506, 508, 509, 510, + 511, 575, 592, 559, 529, 492, 583, 526, 530, 531, + 358, 595, 0, 0, 0, 483, 368, 369, 0, 340, + 339, 381, 417, 299, 346, 291, 292, 657, 330, 400, + 597, 630, 631, 522, 0, 584, 523, 532, 322, 556, + 568, 567, 396, 482, 0, 579, 582, 512, 656, 0, + 576, 591, 660, 590, 653, 406, 0, 428, 588, 535, + 0, 580, 554, 0, 581, 550, 585, 0, 524, 0, + 436, 464, 476, 493, 496, 525, 610, 611, 612, 296, + 495, 614, 615, 616, 617, 618, 619, 620, 613, 467, + 557, 534, 560, 475, 537, 536, 0, 0, 571, 491, + 572, 573, 390, 391, 392, 393, 685, 687, 315, 494, + 416, 699, 558, 0, 0, 0, 0, 0, 0, 0, + 0, 563, 564, 561, 665, 0, 621, 622, 0, 0, + 488, 489, 345, 352, 507, 354, 314, 405, 347, 473, + 362, 0, 500, 565, 501, 624, 627, 625, 626, 397, + 357, 359, 432, 363, 373, 420, 472, 403, 425, 312, + 463, 434, 378, 551, 578, 0, 0, 0, 0, 0, + 0, 0, 0, 65, 0, 0, 280, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 606, 605, 604, 603, 602, 601, 600, 599, 0, + 0, 548, 449, 324, 285, 320, 321, 328, 654, 651, + 454, 655, 0, 293, 528, 371, 169, 415, 344, 593, + 594, 0, 645, 241, 242, 243, 244, 245, 246, 247, + 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, + 259, 260, 261, 262, 263, 264, 265, 596, 256, 257, + 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, + 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, + 290, 0, 0, 281, 282, 283, 284, 0, 0, 0, + 479, 480, 481, 503, 0, 465, 527, 652, 0, 0, + 0, 0, 0, 0, 0, 577, 589, 623, 0, 633, + 634, 636, 638, 637, 640, 439, 440, 647, 0, 642, + 643, 644, 641, 375, 426, 445, 433, 0, 658, 518, + 519, 659, 629, 402, 0, 0, 533, 566, 555, 639, + 521, 0, 1140, 0, 0, 0, 0, 0, 0, 0, + 0, 337, 0, 0, 370, 570, 552, 562, 553, 538, + 539, 540, 547, 349, 541, 542, 543, 513, 544, 514, + 545, 546, 0, 569, 520, 435, 386, 587, 586, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 228, + 0, 0, 0, 0, 0, 0, 310, 229, 515, 635, + 517, 516, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 313, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1125, 0, 0, 0, + 0, 0, 0, 300, 442, 461, 311, 430, 474, 316, + 438, 453, 306, 401, 427, 0, 0, 2581, 2584, 2585, + 2586, 2587, 2588, 2589, 0, 2594, 2590, 2591, 2592, 2593, + 0, 2576, 2577, 2578, 2579, 1123, 2560, 2582, 0, 2561, + 398, 2562, 2563, 2564, 2565, 1127, 2566, 2567, 2568, 2569, + 2570, 2573, 2574, 2571, 2572, 2580, 410, 374, 411, 356, + 388, 387, 389, 1151, 1153, 1155, 1157, 1160, 497, 498, + 0, 0, 646, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 628, 0, 0, 632, 0, 471, + 0, 0, 0, 0, 0, 0, 441, 0, 0, 367, + 0, 0, 0, 2575, 0, 424, 404, 661, 0, 0, + 422, 372, 456, 412, 462, 443, 470, 418, 413, 294, + 444, 334, 385, 307, 309, 329, 336, 338, 342, 343, + 394, 395, 407, 429, 446, 447, 448, 333, 317, 423, + 318, 353, 319, 295, 325, 323, 326, 431, 327, 297, + 408, 452, 0, 348, 419, 380, 298, 379, 409, 451, + 450, 308, 478, 484, 485, 574, 0, 490, 662, 663, + 664, 499, 0, 414, 0, 504, 505, 506, 508, 509, + 510, 511, 575, 592, 559, 529, 492, 583, 526, 530, + 531, 358, 595, 0, 0, 0, 483, 368, 369, 0, + 340, 339, 381, 417, 299, 346, 291, 292, 657, 330, + 400, 597, 630, 631, 522, 0, 584, 523, 532, 322, + 556, 568, 567, 396, 482, 0, 579, 582, 512, 656, + 0, 576, 591, 660, 590, 653, 406, 0, 428, 588, + 535, 0, 580, 554, 0, 581, 550, 585, 0, 524, + 0, 436, 464, 476, 493, 496, 525, 610, 611, 612, + 296, 495, 614, 615, 616, 617, 618, 619, 620, 613, + 467, 557, 534, 560, 475, 537, 536, 0, 0, 571, + 491, 572, 573, 390, 391, 392, 393, 350, 598, 315, + 494, 416, 0, 558, 0, 0, 0, 0, 0, 0, + 0, 0, 563, 564, 561, 665, 0, 621, 622, 0, + 0, 488, 489, 345, 352, 507, 354, 314, 405, 347, + 473, 362, 0, 500, 565, 501, 624, 627, 625, 626, + 397, 357, 359, 432, 363, 373, 420, 472, 403, 425, + 312, 463, 434, 378, 551, 578, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 606, 605, 604, 603, 602, 601, 600, 599, + 0, 0, 548, 449, 324, 285, 320, 321, 328, 654, + 651, 454, 655, 0, 293, 2583, 371, 0, 415, 344, + 593, 594, 0, 645, 241, 242, 243, 244, 245, 246, + 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, + 258, 259, 260, 261, 262, 263, 264, 265, 596, 256, + 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, + 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, + 289, 290, 0, 0, 281, 282, 283, 284, 0, 0, + 0, 479, 480, 481, 503, 0, 465, 527, 652, 0, + 0, 0, 0, 0, 0, 0, 577, 589, 623, 0, + 633, 634, 636, 638, 637, 640, 439, 440, 647, 0, + 642, 643, 644, 641, 375, 426, 445, 433, 0, 658, + 518, 519, 659, 629, 402, 0, 0, 533, 566, 555, + 639, 521, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 337, 0, 0, 370, 570, 552, 562, 553, + 538, 539, 540, 547, 349, 541, 542, 543, 513, 544, + 514, 545, 546, 0, 569, 520, 435, 386, 587, 586, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 228, 0, 0, 0, 0, 0, 0, 310, 229, 515, + 635, 517, 516, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 313, 2418, 2421, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 300, 442, 461, 311, 430, 474, + 316, 438, 453, 306, 401, 427, 0, 0, 302, 459, + 437, 383, 360, 361, 301, 0, 421, 335, 351, 332, + 399, 0, 458, 486, 331, 477, 0, 469, 304, 0, + 468, 398, 455, 460, 384, 377, 0, 303, 457, 382, + 376, 364, 341, 502, 365, 366, 355, 410, 374, 411, + 356, 388, 387, 389, 0, 0, 0, 0, 0, 497, + 498, 0, 0, 646, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 628, 0, 0, 632, 2422, + 471, 0, 0, 0, 2417, 0, 2416, 441, 2414, 2419, + 367, 0, 0, 0, 487, 0, 424, 404, 661, 0, + 0, 422, 372, 456, 412, 462, 443, 470, 418, 413, + 294, 444, 334, 385, 307, 309, 329, 336, 338, 342, + 343, 394, 395, 407, 429, 446, 447, 448, 333, 317, + 423, 318, 353, 319, 295, 325, 323, 326, 431, 327, + 297, 408, 452, 2420, 348, 419, 380, 298, 379, 409, + 451, 450, 308, 478, 484, 485, 574, 0, 490, 662, + 663, 664, 499, 0, 414, 0, 504, 505, 506, 508, + 509, 510, 511, 575, 592, 559, 529, 492, 583, 526, + 530, 531, 358, 595, 0, 0, 0, 483, 368, 369, + 0, 340, 339, 381, 417, 299, 346, 291, 292, 657, + 330, 400, 597, 630, 631, 522, 0, 584, 523, 532, + 322, 556, 568, 567, 396, 482, 0, 579, 582, 512, + 656, 0, 576, 591, 660, 590, 653, 406, 0, 428, + 588, 535, 0, 580, 554, 0, 581, 550, 585, 0, + 524, 0, 436, 464, 476, 493, 496, 525, 610, 611, + 612, 296, 495, 614, 615, 616, 617, 618, 619, 620, + 613, 467, 557, 534, 560, 475, 537, 536, 0, 0, + 571, 491, 572, 573, 390, 391, 392, 393, 350, 598, + 315, 494, 416, 0, 558, 0, 0, 0, 0, 0, + 0, 0, 0, 563, 564, 561, 665, 0, 621, 622, + 0, 0, 488, 489, 345, 352, 507, 354, 314, 405, + 347, 473, 362, 0, 500, 565, 501, 624, 627, 625, + 626, 397, 357, 359, 432, 363, 373, 420, 472, 403, + 425, 312, 463, 434, 378, 551, 578, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 606, 605, 604, 603, 602, 601, 600, + 599, 0, 0, 548, 449, 324, 285, 320, 321, 328, + 654, 651, 454, 655, 0, 293, 528, 371, 0, 415, + 344, 593, 594, 0, 645, 241, 242, 243, 244, 245, + 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, + 255, 258, 259, 260, 261, 262, 263, 264, 265, 596, + 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, + 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, + 288, 289, 290, 0, 0, 281, 282, 283, 284, 0, + 0, 0, 479, 480, 481, 503, 0, 465, 527, 652, + 0, 0, 0, 0, 0, 0, 0, 577, 589, 623, + 0, 633, 634, 636, 638, 637, 640, 439, 440, 647, + 0, 642, 643, 644, 641, 375, 426, 445, 433, 0, + 658, 518, 519, 659, 629, 402, 0, 0, 533, 566, + 555, 639, 521, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 337, 0, 0, 370, 570, 552, 562, + 553, 538, 539, 540, 547, 349, 541, 542, 543, 513, + 544, 514, 545, 546, 0, 569, 520, 435, 386, 587, + 586, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 228, 0, 0, 0, 0, 0, 0, 310, 229, + 515, 635, 517, 516, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 313, 0, 2439, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 300, 442, 461, 311, 430, + 474, 316, 438, 453, 306, 401, 427, 0, 0, 302, + 459, 437, 383, 360, 361, 301, 0, 421, 335, 351, + 332, 399, 0, 458, 486, 331, 477, 0, 469, 304, + 0, 468, 398, 455, 460, 384, 377, 0, 303, 457, + 382, 376, 364, 341, 502, 365, 366, 355, 410, 374, + 411, 356, 388, 387, 389, 0, 0, 0, 0, 0, + 497, 498, 0, 0, 646, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 628, 0, 0, 632, + 2438, 471, 0, 0, 0, 2444, 2441, 2443, 441, 0, + 2442, 367, 0, 0, 0, 487, 0, 424, 404, 661, + 0, 2436, 422, 372, 456, 412, 462, 443, 470, 418, + 413, 294, 444, 334, 385, 307, 309, 329, 336, 338, + 342, 343, 394, 395, 407, 429, 446, 447, 448, 333, + 317, 423, 318, 353, 319, 295, 325, 323, 326, 431, + 327, 297, 408, 452, 0, 348, 419, 380, 298, 379, + 409, 451, 450, 308, 478, 484, 485, 574, 0, 490, + 662, 663, 664, 499, 0, 414, 0, 504, 505, 506, + 508, 509, 510, 511, 575, 592, 559, 529, 492, 583, + 526, 530, 531, 358, 595, 0, 0, 0, 483, 368, + 369, 0, 340, 339, 381, 417, 299, 346, 291, 292, + 657, 330, 400, 597, 630, 631, 522, 0, 584, 523, + 532, 322, 556, 568, 567, 396, 482, 0, 579, 582, + 512, 656, 0, 576, 591, 660, 590, 653, 406, 0, + 428, 588, 535, 0, 580, 554, 0, 581, 550, 585, + 0, 524, 0, 436, 464, 476, 493, 496, 525, 610, + 611, 612, 296, 495, 614, 615, 616, 617, 618, 619, + 620, 613, 467, 557, 534, 560, 475, 537, 536, 0, + 0, 571, 491, 572, 573, 390, 391, 392, 393, 350, + 598, 315, 494, 416, 0, 558, 0, 0, 0, 0, + 0, 0, 0, 0, 563, 564, 561, 665, 0, 621, + 622, 0, 0, 488, 489, 345, 352, 507, 354, 314, + 405, 347, 473, 362, 0, 500, 565, 501, 624, 627, + 625, 626, 397, 357, 359, 432, 363, 373, 420, 472, + 403, 425, 312, 463, 434, 378, 551, 578, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 606, 605, 604, 603, 602, 601, + 600, 599, 0, 0, 548, 449, 324, 285, 320, 321, + 328, 654, 651, 454, 655, 0, 293, 528, 371, 0, + 415, 344, 593, 594, 0, 645, 241, 242, 243, 244, + 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, + 254, 255, 258, 259, 260, 261, 262, 263, 264, 265, + 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, + 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, + 287, 288, 289, 290, 0, 0, 281, 282, 283, 284, + 0, 0, 0, 479, 480, 481, 503, 0, 465, 527, + 652, 0, 0, 0, 0, 0, 0, 0, 577, 589, + 623, 0, 633, 634, 636, 638, 637, 640, 439, 440, + 647, 0, 642, 643, 644, 641, 375, 426, 445, 433, + 0, 658, 518, 519, 659, 629, 402, 0, 0, 533, + 566, 555, 639, 521, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 337, 0, 0, 370, 570, 552, + 562, 553, 538, 539, 540, 547, 349, 541, 542, 543, + 513, 544, 514, 545, 546, 0, 569, 520, 435, 386, + 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 228, 0, 0, 0, 0, 0, 0, 310, + 229, 515, 635, 517, 516, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 313, 0, 2439, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 300, 442, 461, 311, + 430, 474, 316, 438, 453, 306, 401, 427, 0, 0, + 302, 459, 437, 383, 360, 361, 301, 0, 421, 335, + 351, 332, 399, 0, 458, 486, 331, 477, 0, 469, + 304, 0, 468, 398, 455, 460, 384, 377, 0, 303, + 457, 382, 376, 364, 341, 502, 365, 366, 355, 410, + 374, 411, 356, 388, 387, 389, 0, 0, 0, 0, + 0, 497, 498, 0, 0, 646, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 628, 0, 0, + 632, 2438, 471, 0, 0, 0, 2444, 2441, 2443, 441, + 0, 2442, 367, 0, 0, 0, 487, 0, 424, 404, + 661, 0, 0, 422, 372, 456, 412, 462, 443, 470, + 418, 413, 294, 444, 334, 385, 307, 309, 329, 336, + 338, 342, 343, 394, 395, 407, 429, 446, 447, 448, + 333, 317, 423, 318, 353, 319, 295, 325, 323, 326, + 431, 327, 297, 408, 452, 0, 348, 419, 380, 298, + 379, 409, 451, 450, 308, 478, 484, 485, 574, 0, + 490, 662, 663, 664, 499, 0, 414, 0, 504, 505, + 506, 508, 509, 510, 511, 575, 592, 559, 529, 492, + 583, 526, 530, 531, 358, 595, 0, 0, 0, 483, + 368, 369, 0, 340, 339, 381, 417, 299, 346, 291, + 292, 657, 330, 400, 597, 630, 631, 522, 0, 584, + 523, 532, 322, 556, 568, 567, 396, 482, 0, 579, + 582, 512, 656, 0, 576, 591, 660, 590, 653, 406, + 0, 428, 588, 535, 0, 580, 554, 0, 581, 550, + 585, 0, 524, 0, 436, 464, 476, 493, 496, 525, + 610, 611, 612, 296, 495, 614, 615, 616, 617, 618, + 619, 620, 613, 467, 557, 534, 560, 475, 537, 536, + 0, 0, 571, 491, 572, 573, 390, 391, 392, 393, + 350, 598, 315, 494, 416, 0, 558, 0, 0, 0, + 0, 0, 0, 0, 0, 563, 564, 561, 665, 0, + 621, 622, 0, 0, 488, 489, 345, 352, 507, 354, + 314, 405, 347, 473, 362, 0, 500, 565, 501, 624, + 627, 625, 626, 397, 357, 359, 432, 363, 373, 420, + 472, 403, 425, 312, 463, 434, 378, 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 228, 0, 0, 0, 0, - 0, 0, 309, 229, 514, 634, 516, 515, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 312, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 1124, 0, 0, 0, 0, 0, 0, 299, - 441, 460, 310, 429, 473, 315, 437, 452, 305, 400, - 426, 0, 0, 2580, 2583, 2584, 2585, 2586, 2587, 2588, - 0, 2593, 2589, 2590, 2591, 2592, 0, 2575, 2576, 2577, - 2578, 1122, 2559, 2581, 0, 2560, 397, 2561, 2562, 2563, - 2564, 1126, 2565, 2566, 2567, 2568, 2569, 2572, 2573, 2570, - 2571, 2579, 409, 373, 410, 355, 387, 386, 388, 1150, - 1152, 1154, 1156, 1159, 496, 497, 0, 0, 645, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 627, 0, 0, 631, 0, 470, 0, 0, 0, 0, - 0, 0, 440, 0, 0, 366, 0, 0, 0, 2574, - 0, 423, 403, 660, 0, 0, 421, 371, 455, 411, - 461, 442, 469, 417, 412, 294, 443, 333, 384, 306, - 308, 328, 335, 337, 341, 342, 393, 394, 406, 428, - 445, 446, 447, 332, 316, 422, 317, 352, 318, 295, - 324, 322, 325, 430, 326, 297, 407, 451, 0, 347, - 418, 379, 298, 378, 408, 450, 449, 307, 477, 483, - 484, 573, 0, 489, 661, 662, 663, 498, 0, 413, - 0, 503, 504, 505, 507, 508, 509, 510, 574, 591, - 558, 528, 491, 582, 525, 529, 530, 357, 594, 0, - 0, 0, 482, 367, 368, 0, 339, 338, 380, 416, - 345, 291, 292, 656, 329, 399, 596, 629, 630, 521, - 0, 583, 522, 531, 321, 555, 567, 566, 395, 481, - 0, 578, 581, 511, 655, 0, 575, 590, 659, 589, - 652, 405, 0, 427, 587, 534, 0, 579, 553, 0, - 580, 549, 584, 0, 523, 0, 435, 463, 475, 492, - 495, 524, 609, 610, 611, 296, 494, 613, 614, 615, - 616, 617, 618, 619, 612, 466, 556, 533, 559, 474, - 536, 535, 0, 0, 570, 490, 571, 572, 389, 390, - 391, 392, 349, 597, 314, 493, 415, 0, 557, 0, - 0, 0, 0, 0, 0, 0, 0, 562, 563, 560, - 664, 0, 620, 621, 0, 0, 487, 488, 344, 351, - 506, 353, 313, 404, 346, 472, 361, 0, 499, 564, - 500, 623, 626, 624, 625, 396, 356, 358, 431, 362, - 372, 419, 471, 402, 424, 311, 462, 433, 377, 550, - 577, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 605, 604, 603, - 602, 601, 600, 599, 598, 0, 0, 547, 448, 323, - 285, 319, 320, 327, 653, 650, 453, 654, 0, 293, - 2582, 370, 0, 414, 343, 592, 593, 0, 644, 241, - 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, - 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, - 263, 264, 265, 595, 256, 257, 266, 267, 268, 269, - 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, - 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, - 282, 283, 284, 0, 0, 0, 478, 479, 480, 502, - 0, 464, 526, 651, 0, 0, 0, 0, 0, 0, - 0, 576, 588, 622, 0, 632, 633, 635, 637, 636, - 639, 438, 439, 646, 0, 641, 642, 643, 640, 374, - 425, 444, 432, 0, 657, 517, 518, 658, 628, 401, - 0, 0, 532, 565, 554, 638, 520, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 336, 0, 0, - 369, 569, 551, 561, 552, 537, 538, 539, 546, 348, - 540, 541, 542, 512, 543, 513, 544, 545, 0, 568, - 519, 434, 385, 586, 585, 0, 0, 0, 0, 0, + 280, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 606, 605, 604, 603, 602, + 601, 600, 599, 0, 0, 548, 449, 324, 285, 320, + 321, 328, 654, 651, 454, 655, 0, 293, 528, 371, + 0, 415, 344, 593, 594, 0, 645, 241, 242, 243, + 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, + 253, 254, 255, 258, 259, 260, 261, 262, 263, 264, + 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, + 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, + 0, 287, 288, 289, 290, 0, 0, 281, 282, 283, + 284, 0, 0, 0, 479, 480, 481, 503, 0, 465, + 527, 652, 0, 0, 0, 0, 0, 0, 0, 577, + 589, 623, 0, 633, 634, 636, 638, 637, 640, 439, + 440, 647, 0, 642, 643, 644, 641, 375, 426, 445, + 433, 0, 658, 518, 519, 659, 629, 402, 0, 0, + 533, 566, 555, 639, 521, 0, 0, 0, 0, 0, + 2137, 0, 0, 0, 0, 337, 0, 0, 370, 570, + 552, 562, 553, 538, 539, 540, 547, 349, 541, 542, + 543, 513, 544, 514, 545, 546, 0, 569, 520, 435, + 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 228, 0, 0, 2138, 0, 0, 0, + 310, 229, 515, 635, 517, 516, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 313, 0, 0, 1261, 1262, + 1263, 1260, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 300, 442, 461, + 311, 430, 474, 316, 438, 453, 306, 401, 427, 0, + 0, 302, 459, 437, 383, 360, 361, 301, 0, 421, + 335, 351, 332, 399, 0, 458, 486, 331, 477, 0, + 469, 304, 0, 468, 398, 455, 460, 384, 377, 0, + 303, 457, 382, 376, 364, 341, 502, 365, 366, 355, + 410, 374, 411, 356, 388, 387, 389, 0, 0, 0, + 0, 0, 497, 498, 0, 0, 646, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 628, 0, + 0, 632, 0, 471, 0, 0, 0, 0, 0, 0, + 441, 0, 0, 367, 0, 0, 0, 487, 0, 424, + 404, 661, 0, 0, 422, 372, 456, 412, 462, 443, + 470, 418, 413, 294, 444, 334, 385, 307, 309, 329, + 336, 338, 342, 343, 394, 395, 407, 429, 446, 447, + 448, 333, 317, 423, 318, 353, 319, 295, 325, 323, + 326, 431, 327, 297, 408, 452, 0, 348, 419, 380, + 298, 379, 409, 451, 450, 308, 478, 484, 485, 574, + 0, 490, 662, 663, 664, 499, 0, 414, 0, 504, + 505, 506, 508, 509, 510, 511, 575, 592, 559, 529, + 492, 583, 526, 530, 531, 358, 595, 0, 0, 0, + 483, 368, 369, 0, 340, 339, 381, 417, 299, 346, + 291, 292, 657, 330, 400, 597, 630, 631, 522, 0, + 584, 523, 532, 322, 556, 568, 567, 396, 482, 0, + 579, 582, 512, 656, 0, 576, 591, 660, 590, 653, + 406, 0, 428, 588, 535, 0, 580, 554, 0, 581, + 550, 585, 0, 524, 0, 436, 464, 476, 493, 496, + 525, 610, 611, 612, 296, 495, 614, 615, 616, 617, + 618, 619, 620, 613, 467, 557, 534, 560, 475, 537, + 536, 0, 0, 571, 491, 572, 573, 390, 391, 392, + 393, 350, 598, 315, 494, 416, 0, 558, 0, 0, + 0, 0, 0, 0, 0, 0, 563, 564, 561, 665, + 0, 621, 622, 0, 0, 488, 489, 345, 352, 507, + 354, 314, 405, 347, 473, 362, 0, 500, 565, 501, + 624, 627, 625, 626, 397, 357, 359, 432, 363, 373, + 420, 472, 403, 425, 312, 463, 434, 378, 551, 578, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 606, 605, 604, 603, + 602, 601, 600, 599, 0, 0, 548, 449, 324, 285, + 320, 321, 328, 654, 651, 454, 655, 0, 293, 528, + 371, 0, 415, 344, 593, 594, 0, 645, 241, 242, + 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, + 252, 253, 254, 255, 258, 259, 260, 261, 262, 263, + 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, + 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, + 0, 0, 287, 288, 289, 290, 0, 0, 281, 282, + 283, 284, 0, 0, 0, 479, 480, 481, 503, 0, + 465, 527, 652, 0, 0, 0, 0, 0, 0, 0, + 577, 589, 623, 0, 633, 634, 636, 638, 637, 640, + 439, 440, 647, 0, 642, 643, 644, 641, 375, 426, + 445, 433, 206, 658, 518, 519, 659, 629, 0, 0, + 0, 0, 402, 0, 0, 533, 566, 555, 639, 521, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 337, 0, 0, 370, 570, 552, 562, 553, 538, 539, + 540, 547, 349, 541, 542, 543, 513, 544, 514, 545, + 546, 140, 569, 520, 435, 386, 587, 586, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 202, 2187, 0, 228, 0, + 0, 0, 0, 0, 0, 310, 229, 515, 635, 517, + 516, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 313, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 300, 442, 461, 311, 430, 474, 316, 438, + 453, 306, 401, 427, 0, 0, 302, 459, 437, 383, + 360, 361, 301, 0, 421, 335, 351, 332, 399, 0, + 458, 486, 331, 477, 0, 469, 304, 0, 468, 398, + 455, 460, 384, 377, 0, 303, 457, 382, 376, 364, + 341, 502, 365, 366, 355, 410, 374, 411, 356, 388, + 387, 389, 0, 0, 0, 0, 0, 497, 498, 0, + 0, 646, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 628, 0, 0, 632, 0, 471, 0, + 0, 0, 0, 0, 0, 441, 0, 0, 367, 0, + 0, 0, 487, 0, 424, 404, 661, 0, 0, 422, + 372, 456, 412, 462, 443, 470, 418, 413, 294, 444, + 334, 385, 307, 309, 329, 336, 338, 342, 343, 394, + 395, 407, 429, 446, 447, 448, 333, 317, 423, 318, + 353, 319, 295, 325, 323, 326, 431, 327, 297, 408, + 452, 0, 348, 419, 380, 298, 379, 409, 451, 450, + 308, 478, 484, 485, 574, 0, 490, 662, 663, 664, + 499, 0, 414, 0, 504, 505, 506, 508, 509, 510, + 511, 575, 592, 559, 529, 492, 583, 526, 530, 531, + 358, 595, 0, 0, 0, 483, 368, 369, 0, 340, + 339, 381, 417, 299, 346, 291, 292, 657, 330, 400, + 597, 630, 631, 522, 0, 584, 523, 532, 322, 556, + 568, 567, 396, 482, 0, 579, 582, 512, 656, 0, + 576, 591, 660, 590, 653, 406, 0, 428, 588, 535, + 0, 580, 554, 0, 581, 550, 585, 0, 524, 0, + 436, 464, 476, 493, 496, 525, 610, 611, 612, 296, + 495, 614, 615, 616, 617, 618, 619, 620, 613, 467, + 557, 534, 560, 475, 537, 536, 0, 0, 571, 491, + 572, 573, 390, 391, 392, 393, 350, 598, 315, 494, + 416, 0, 558, 0, 0, 0, 0, 0, 0, 0, + 0, 563, 564, 561, 665, 0, 621, 622, 0, 0, + 488, 489, 345, 352, 507, 354, 314, 405, 347, 473, + 362, 0, 500, 565, 501, 624, 627, 625, 626, 397, + 357, 359, 432, 363, 373, 420, 472, 403, 425, 312, + 463, 434, 378, 551, 578, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 228, 0, 0, 0, 0, - 0, 0, 309, 229, 514, 634, 516, 515, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 312, 2417, 2420, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 299, - 441, 460, 310, 429, 473, 315, 437, 452, 305, 400, - 426, 0, 0, 301, 458, 436, 382, 359, 360, 300, - 0, 420, 334, 350, 331, 398, 0, 457, 485, 330, - 476, 0, 468, 303, 0, 467, 397, 454, 459, 383, - 376, 0, 302, 456, 381, 375, 363, 340, 501, 364, - 365, 354, 409, 373, 410, 355, 387, 386, 388, 0, - 0, 0, 0, 0, 496, 497, 0, 0, 645, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 627, 0, 0, 631, 2421, 470, 0, 0, 0, 2416, - 0, 2415, 440, 2413, 2418, 366, 0, 0, 0, 486, - 0, 423, 403, 660, 0, 0, 421, 371, 455, 411, - 461, 442, 469, 417, 412, 294, 443, 333, 384, 306, - 308, 328, 335, 337, 341, 342, 393, 394, 406, 428, - 445, 446, 447, 332, 316, 422, 317, 352, 318, 295, - 324, 322, 325, 430, 326, 297, 407, 451, 2419, 347, - 418, 379, 298, 378, 408, 450, 449, 307, 477, 483, - 484, 573, 0, 489, 661, 662, 663, 498, 0, 413, - 0, 503, 504, 505, 507, 508, 509, 510, 574, 591, - 558, 528, 491, 582, 525, 529, 530, 357, 594, 0, - 0, 0, 482, 367, 368, 0, 339, 338, 380, 416, - 345, 291, 292, 656, 329, 399, 596, 629, 630, 521, - 0, 583, 522, 531, 321, 555, 567, 566, 395, 481, - 0, 578, 581, 511, 655, 0, 575, 590, 659, 589, - 652, 405, 0, 427, 587, 534, 0, 579, 553, 0, - 580, 549, 584, 0, 523, 0, 435, 463, 475, 492, - 495, 524, 609, 610, 611, 296, 494, 613, 614, 615, - 616, 617, 618, 619, 612, 466, 556, 533, 559, 474, - 536, 535, 0, 0, 570, 490, 571, 572, 389, 390, - 391, 392, 349, 597, 314, 493, 415, 0, 557, 0, - 0, 0, 0, 0, 0, 0, 0, 562, 563, 560, - 664, 0, 620, 621, 0, 0, 487, 488, 344, 351, - 506, 353, 313, 404, 346, 472, 361, 0, 499, 564, - 500, 623, 626, 624, 625, 396, 356, 358, 431, 362, - 372, 419, 471, 402, 424, 311, 462, 433, 377, 550, - 577, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 606, 605, 604, 603, 602, 601, 600, 599, 0, + 0, 548, 449, 324, 285, 320, 321, 328, 654, 651, + 454, 655, 0, 293, 528, 371, 169, 415, 344, 593, + 594, 0, 645, 241, 242, 243, 244, 245, 246, 247, + 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, + 259, 260, 261, 262, 263, 264, 265, 596, 256, 257, + 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, + 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, + 290, 0, 0, 281, 282, 283, 284, 0, 0, 0, + 479, 480, 481, 503, 0, 465, 527, 652, 0, 0, + 0, 0, 0, 0, 0, 577, 589, 623, 0, 633, + 634, 636, 638, 637, 640, 439, 440, 647, 0, 642, + 643, 644, 641, 375, 426, 445, 433, 206, 658, 518, + 519, 659, 629, 0, 0, 0, 0, 402, 0, 0, + 533, 566, 555, 639, 521, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 337, 0, 0, 370, 570, + 552, 562, 553, 538, 539, 540, 547, 349, 541, 542, + 543, 513, 544, 514, 545, 546, 140, 569, 520, 435, + 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 202, 2172, 0, 228, 0, 0, 0, 0, 0, 0, + 310, 229, 515, 635, 517, 516, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 313, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 300, 442, 461, + 311, 430, 474, 316, 438, 453, 306, 401, 427, 0, + 0, 302, 459, 437, 383, 360, 361, 301, 0, 421, + 335, 351, 332, 399, 0, 458, 486, 331, 477, 0, + 469, 304, 0, 468, 398, 455, 460, 384, 377, 0, + 303, 457, 382, 376, 364, 341, 502, 365, 366, 355, + 410, 374, 411, 356, 388, 387, 389, 0, 0, 0, + 0, 0, 497, 498, 0, 0, 646, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 628, 0, + 0, 632, 0, 471, 0, 0, 0, 0, 0, 0, + 441, 0, 0, 367, 0, 0, 0, 487, 0, 424, + 404, 661, 0, 0, 422, 372, 456, 412, 462, 443, + 470, 418, 413, 294, 444, 334, 385, 307, 309, 329, + 336, 338, 342, 343, 394, 395, 407, 429, 446, 447, + 448, 333, 317, 423, 318, 353, 319, 295, 325, 323, + 326, 431, 327, 297, 408, 452, 0, 348, 419, 380, + 298, 379, 409, 451, 450, 308, 478, 484, 485, 574, + 0, 490, 662, 663, 664, 499, 0, 414, 0, 504, + 505, 506, 508, 509, 510, 511, 575, 592, 559, 529, + 492, 583, 526, 530, 531, 358, 595, 0, 0, 0, + 483, 368, 369, 0, 340, 339, 381, 417, 299, 346, + 291, 292, 657, 330, 400, 597, 630, 631, 522, 0, + 584, 523, 532, 322, 556, 568, 567, 396, 482, 0, + 579, 582, 512, 656, 0, 576, 591, 660, 590, 653, + 406, 0, 428, 588, 535, 0, 580, 554, 0, 581, + 550, 585, 0, 524, 0, 436, 464, 476, 493, 496, + 525, 610, 611, 612, 296, 495, 614, 615, 616, 617, + 618, 619, 620, 613, 467, 557, 534, 560, 475, 537, + 536, 0, 0, 571, 491, 572, 573, 390, 391, 392, + 393, 350, 598, 315, 494, 416, 0, 558, 0, 0, + 0, 0, 0, 0, 0, 0, 563, 564, 561, 665, + 0, 621, 622, 0, 0, 488, 489, 345, 352, 507, + 354, 314, 405, 347, 473, 362, 0, 500, 565, 501, + 624, 627, 625, 626, 397, 357, 359, 432, 363, 373, + 420, 472, 403, 425, 312, 463, 434, 378, 551, 578, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 606, 605, 604, 603, + 602, 601, 600, 599, 0, 0, 548, 449, 324, 285, + 320, 321, 328, 654, 651, 454, 655, 0, 293, 528, + 371, 169, 415, 344, 593, 594, 0, 645, 241, 242, + 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, + 252, 253, 254, 255, 258, 259, 260, 261, 262, 263, + 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, + 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, + 0, 0, 287, 288, 289, 290, 0, 0, 281, 282, + 283, 284, 0, 0, 0, 479, 480, 481, 503, 0, + 465, 527, 652, 0, 0, 0, 0, 0, 0, 0, + 577, 589, 623, 0, 633, 634, 636, 638, 637, 640, + 439, 440, 647, 0, 642, 643, 644, 641, 375, 426, + 445, 433, 0, 658, 518, 519, 659, 629, 402, 0, + 0, 533, 566, 555, 639, 521, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 337, 1051, 0, 370, + 570, 552, 562, 553, 538, 539, 540, 547, 349, 541, + 542, 543, 513, 544, 514, 545, 546, 0, 569, 520, + 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 228, 1058, 1059, 0, 0, 0, + 0, 310, 229, 515, 635, 517, 516, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 1062, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 300, 442, + 1045, 311, 430, 474, 316, 438, 453, 306, 401, 427, + 0, 0, 302, 459, 437, 383, 360, 361, 301, 0, + 421, 335, 351, 332, 399, 0, 458, 486, 331, 477, + 1032, 469, 304, 1031, 468, 398, 455, 460, 384, 377, + 0, 303, 457, 382, 376, 364, 341, 502, 365, 366, + 355, 410, 374, 411, 356, 388, 387, 389, 0, 0, + 0, 0, 0, 497, 498, 0, 0, 646, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 628, + 0, 0, 632, 0, 471, 0, 0, 0, 0, 0, + 0, 441, 0, 0, 367, 0, 0, 0, 487, 0, + 424, 404, 661, 0, 0, 422, 372, 456, 412, 462, + 443, 470, 1049, 413, 294, 444, 334, 385, 307, 309, + 329, 336, 338, 342, 343, 394, 395, 407, 429, 446, + 447, 448, 333, 317, 423, 318, 353, 319, 295, 325, + 323, 326, 431, 327, 297, 408, 452, 0, 348, 419, + 380, 298, 379, 409, 451, 450, 308, 478, 484, 485, + 574, 0, 490, 662, 663, 664, 499, 0, 414, 0, + 504, 505, 506, 508, 509, 510, 511, 575, 592, 559, + 529, 492, 583, 526, 530, 531, 358, 595, 0, 0, + 0, 483, 368, 369, 0, 340, 339, 381, 417, 299, + 346, 291, 292, 657, 330, 400, 597, 630, 631, 522, + 0, 584, 523, 532, 322, 556, 568, 567, 396, 482, + 0, 579, 582, 512, 656, 0, 576, 591, 660, 590, + 653, 406, 0, 428, 588, 535, 0, 580, 554, 0, + 581, 550, 585, 0, 524, 0, 436, 464, 476, 493, + 496, 525, 610, 611, 612, 296, 495, 614, 615, 616, + 617, 618, 619, 1050, 613, 467, 557, 534, 560, 475, + 537, 536, 0, 0, 571, 1053, 572, 573, 390, 391, + 392, 393, 350, 598, 1048, 494, 416, 0, 558, 0, + 0, 0, 0, 0, 0, 0, 0, 563, 564, 561, + 665, 0, 621, 622, 0, 0, 488, 489, 345, 352, + 507, 354, 314, 405, 347, 473, 362, 0, 500, 565, + 501, 624, 627, 625, 626, 1060, 1046, 1056, 1047, 363, + 373, 420, 472, 403, 425, 312, 463, 434, 1057, 551, + 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 605, 604, 603, - 602, 601, 600, 599, 598, 0, 0, 547, 448, 323, - 285, 319, 320, 327, 653, 650, 453, 654, 0, 293, - 527, 370, 0, 414, 343, 592, 593, 0, 644, 241, + 0, 0, 0, 0, 0, 0, 0, 606, 605, 604, + 603, 602, 601, 600, 599, 0, 0, 548, 449, 324, + 285, 320, 321, 328, 654, 651, 454, 655, 0, 293, + 528, 371, 0, 415, 344, 593, 594, 0, 645, 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, - 263, 264, 265, 595, 256, 257, 266, 267, 268, 269, + 263, 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, - 282, 283, 284, 0, 0, 0, 478, 479, 480, 502, - 0, 464, 526, 651, 0, 0, 0, 0, 0, 0, - 0, 576, 588, 622, 0, 632, 633, 635, 637, 636, - 639, 438, 439, 646, 0, 641, 642, 643, 640, 374, - 425, 444, 432, 0, 657, 517, 518, 658, 628, 401, - 0, 0, 532, 565, 554, 638, 520, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 336, 0, 0, - 369, 569, 551, 561, 552, 537, 538, 539, 546, 348, - 540, 541, 542, 512, 543, 513, 544, 545, 0, 568, - 519, 434, 385, 586, 585, 0, 0, 0, 0, 0, + 282, 283, 284, 0, 0, 0, 479, 480, 481, 503, + 0, 465, 527, 652, 0, 0, 0, 0, 0, 0, + 0, 577, 589, 623, 0, 633, 634, 636, 638, 637, + 640, 439, 440, 647, 0, 642, 643, 644, 641, 1044, + 426, 445, 433, 206, 658, 518, 519, 659, 629, 0, + 0, 0, 0, 402, 0, 0, 533, 566, 555, 639, + 521, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 337, 0, 0, 370, 570, 552, 562, 553, 538, + 539, 540, 547, 349, 541, 542, 543, 513, 544, 514, + 545, 546, 140, 569, 520, 435, 386, 587, 586, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 2069, 0, 0, 228, + 0, 0, 0, 0, 0, 0, 310, 229, 515, 635, + 517, 516, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 313, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 300, 442, 461, 311, 430, 474, 316, + 438, 453, 306, 401, 427, 0, 0, 302, 459, 437, + 383, 360, 361, 301, 0, 421, 335, 351, 332, 399, + 0, 458, 486, 331, 477, 0, 469, 304, 0, 468, + 398, 455, 460, 384, 377, 0, 303, 457, 382, 376, + 364, 341, 502, 365, 366, 355, 410, 374, 411, 356, + 388, 387, 389, 0, 0, 0, 0, 0, 497, 498, + 0, 0, 646, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 628, 0, 0, 632, 0, 471, + 0, 0, 0, 0, 0, 0, 441, 0, 0, 367, + 0, 0, 0, 487, 0, 424, 404, 661, 0, 0, + 422, 372, 456, 412, 462, 443, 470, 418, 413, 294, + 444, 334, 385, 307, 309, 329, 336, 338, 342, 343, + 394, 395, 407, 429, 446, 447, 448, 333, 317, 423, + 318, 353, 319, 295, 325, 323, 326, 431, 327, 297, + 408, 452, 0, 348, 419, 380, 298, 379, 409, 451, + 450, 308, 478, 484, 485, 574, 0, 490, 662, 663, + 664, 499, 0, 414, 0, 504, 505, 506, 508, 509, + 510, 511, 575, 592, 559, 529, 492, 583, 526, 530, + 531, 358, 595, 0, 0, 0, 483, 368, 369, 0, + 340, 339, 381, 417, 299, 346, 291, 292, 657, 330, + 400, 597, 630, 631, 522, 0, 584, 523, 532, 322, + 556, 568, 567, 396, 482, 0, 579, 582, 512, 656, + 0, 576, 591, 660, 590, 653, 406, 0, 428, 588, + 535, 0, 580, 554, 0, 581, 550, 585, 0, 524, + 0, 436, 464, 476, 493, 496, 525, 610, 611, 612, + 296, 495, 614, 615, 616, 617, 618, 619, 620, 613, + 467, 557, 534, 560, 475, 537, 536, 0, 0, 571, + 491, 572, 573, 390, 391, 392, 393, 350, 598, 315, + 494, 416, 0, 558, 0, 0, 0, 0, 0, 0, + 0, 0, 563, 564, 561, 665, 0, 621, 622, 0, + 0, 488, 489, 345, 352, 507, 354, 314, 405, 347, + 473, 362, 0, 500, 565, 501, 624, 627, 625, 626, + 397, 357, 359, 432, 363, 373, 420, 472, 403, 425, + 312, 463, 434, 378, 551, 578, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 606, 605, 604, 603, 602, 601, 600, 599, + 0, 0, 548, 449, 324, 285, 320, 321, 328, 654, + 651, 454, 655, 0, 293, 528, 371, 169, 415, 344, + 593, 594, 0, 645, 241, 242, 243, 244, 245, 246, + 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, + 258, 259, 260, 261, 262, 263, 264, 265, 596, 256, + 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, + 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, + 289, 290, 0, 0, 281, 282, 283, 284, 0, 0, + 0, 479, 480, 481, 503, 0, 465, 527, 652, 0, + 0, 0, 0, 0, 0, 0, 577, 589, 623, 0, + 633, 634, 636, 638, 637, 640, 439, 440, 647, 0, + 642, 643, 644, 641, 375, 426, 445, 433, 0, 658, + 518, 519, 659, 629, 402, 0, 0, 533, 566, 555, + 639, 521, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 337, 0, 0, 370, 570, 552, 562, 553, + 538, 539, 540, 547, 349, 541, 542, 543, 513, 544, + 514, 545, 546, 0, 569, 520, 435, 386, 587, 586, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 228, 1058, 1059, 0, 0, 0, 0, 310, 229, 515, + 635, 517, 516, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1062, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 300, 442, 461, 311, 430, 474, + 316, 438, 453, 306, 401, 427, 0, 0, 302, 459, + 437, 383, 360, 361, 301, 0, 421, 335, 351, 332, + 399, 0, 458, 486, 331, 477, 1032, 469, 304, 1031, + 468, 398, 455, 460, 384, 377, 0, 303, 457, 382, + 376, 364, 341, 502, 365, 366, 355, 410, 374, 411, + 356, 388, 387, 389, 0, 0, 0, 0, 0, 497, + 498, 0, 0, 646, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 628, 0, 0, 632, 0, + 471, 0, 0, 0, 0, 0, 0, 441, 0, 0, + 367, 0, 0, 0, 487, 0, 424, 404, 661, 0, + 0, 422, 372, 456, 412, 462, 443, 470, 418, 413, + 294, 444, 334, 385, 307, 309, 329, 336, 338, 342, + 343, 394, 395, 407, 429, 446, 447, 448, 333, 317, + 423, 318, 353, 319, 295, 325, 323, 326, 431, 327, + 297, 408, 452, 0, 348, 419, 380, 298, 379, 409, + 451, 450, 308, 478, 484, 485, 574, 0, 490, 662, + 663, 664, 499, 0, 414, 0, 504, 505, 506, 508, + 509, 510, 511, 575, 592, 559, 529, 492, 583, 526, + 530, 531, 358, 595, 0, 0, 0, 483, 368, 369, + 0, 340, 339, 381, 417, 299, 346, 291, 292, 657, + 330, 400, 597, 630, 631, 522, 0, 584, 523, 532, + 322, 556, 568, 567, 396, 482, 0, 579, 582, 512, + 656, 0, 576, 591, 660, 590, 653, 406, 0, 428, + 588, 535, 0, 580, 554, 0, 581, 550, 585, 0, + 524, 0, 436, 464, 476, 493, 496, 525, 610, 611, + 612, 296, 495, 614, 615, 616, 617, 618, 619, 620, + 613, 467, 557, 534, 560, 475, 537, 536, 0, 0, + 571, 491, 572, 573, 390, 391, 392, 393, 350, 598, + 315, 494, 416, 0, 558, 0, 0, 0, 0, 0, + 0, 0, 0, 563, 564, 561, 665, 0, 621, 622, + 0, 0, 488, 489, 345, 352, 507, 354, 314, 405, + 347, 473, 362, 0, 500, 565, 501, 624, 627, 625, + 626, 1060, 2090, 1056, 2091, 363, 373, 420, 472, 403, + 425, 312, 463, 434, 1057, 551, 578, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 606, 605, 604, 603, 602, 601, 600, + 599, 0, 0, 548, 449, 324, 285, 320, 321, 328, + 654, 651, 454, 655, 0, 293, 528, 371, 0, 415, + 344, 593, 594, 0, 645, 241, 242, 243, 244, 245, + 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, + 255, 258, 259, 260, 261, 262, 263, 264, 265, 596, + 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, + 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, + 288, 289, 290, 0, 0, 281, 282, 283, 284, 0, + 0, 0, 479, 480, 481, 503, 0, 465, 527, 652, + 0, 0, 0, 0, 0, 0, 0, 577, 589, 623, + 0, 633, 634, 636, 638, 637, 640, 439, 440, 647, + 0, 642, 643, 644, 641, 375, 426, 445, 433, 0, + 658, 518, 519, 659, 629, 402, 0, 0, 533, 566, + 555, 639, 521, 0, 0, 2981, 0, 0, 0, 0, + 0, 0, 0, 337, 0, 0, 370, 570, 552, 562, + 553, 538, 539, 540, 547, 349, 541, 542, 543, 513, + 544, 514, 545, 546, 0, 569, 520, 435, 386, 587, + 586, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 228, 0, 0, 0, 0, 0, 0, 310, 229, + 515, 635, 517, 516, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 313, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 300, 442, 461, 311, 430, + 474, 316, 438, 453, 306, 401, 427, 0, 0, 302, + 459, 437, 383, 360, 361, 301, 0, 421, 335, 351, + 332, 399, 0, 458, 486, 331, 477, 0, 469, 304, + 0, 468, 398, 455, 460, 384, 377, 0, 303, 457, + 382, 376, 364, 341, 502, 365, 366, 355, 410, 374, + 411, 356, 388, 387, 389, 0, 0, 0, 0, 0, + 497, 498, 0, 0, 646, 0, 0, 0, 0, 0, + 0, 2984, 0, 0, 0, 2983, 628, 0, 0, 632, + 0, 471, 0, 0, 0, 0, 0, 0, 441, 0, + 0, 367, 0, 0, 0, 487, 0, 424, 404, 661, + 0, 0, 422, 372, 456, 412, 462, 443, 470, 418, + 413, 294, 444, 334, 385, 307, 309, 329, 336, 338, + 342, 343, 394, 395, 407, 429, 446, 447, 448, 333, + 317, 423, 318, 353, 319, 295, 325, 323, 326, 431, + 327, 297, 408, 452, 0, 348, 419, 380, 298, 379, + 409, 451, 450, 308, 478, 484, 485, 574, 0, 490, + 662, 663, 664, 499, 0, 414, 0, 504, 505, 506, + 508, 509, 510, 511, 575, 592, 559, 529, 492, 583, + 526, 530, 531, 358, 595, 0, 0, 0, 483, 368, + 369, 0, 340, 339, 381, 417, 299, 346, 291, 292, + 657, 330, 400, 597, 630, 631, 522, 0, 584, 523, + 532, 322, 556, 568, 567, 396, 482, 0, 579, 582, + 512, 656, 0, 576, 591, 660, 590, 653, 406, 0, + 428, 588, 535, 0, 580, 554, 0, 581, 550, 585, + 0, 524, 0, 436, 464, 476, 493, 496, 525, 610, + 611, 612, 296, 495, 614, 615, 616, 617, 618, 619, + 620, 613, 467, 557, 534, 560, 475, 537, 536, 0, + 0, 571, 491, 572, 573, 390, 391, 392, 393, 350, + 598, 315, 494, 416, 0, 558, 0, 0, 0, 0, + 0, 0, 0, 0, 563, 564, 561, 665, 0, 621, + 622, 0, 0, 488, 489, 345, 352, 507, 354, 314, + 405, 347, 473, 362, 0, 500, 565, 501, 624, 627, + 625, 626, 397, 357, 359, 432, 363, 373, 420, 472, + 403, 425, 312, 463, 434, 378, 551, 578, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 606, 605, 604, 603, 602, 601, + 600, 599, 0, 0, 548, 449, 324, 285, 320, 321, + 328, 654, 651, 454, 655, 0, 293, 528, 371, 0, + 415, 344, 593, 594, 0, 645, 241, 242, 243, 244, + 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, + 254, 255, 258, 259, 260, 261, 262, 263, 264, 265, + 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, + 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, + 287, 288, 289, 290, 0, 0, 281, 282, 283, 284, + 0, 0, 0, 479, 480, 481, 503, 0, 465, 527, + 652, 0, 0, 0, 0, 0, 0, 0, 577, 589, + 623, 0, 633, 634, 636, 638, 637, 640, 439, 440, + 647, 0, 642, 643, 644, 641, 375, 426, 445, 433, + 0, 658, 518, 519, 659, 629, 402, 0, 0, 533, + 566, 555, 639, 521, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 337, 1557, 0, 370, 570, 552, + 562, 553, 538, 539, 540, 547, 349, 541, 542, 543, + 513, 544, 514, 545, 546, 0, 569, 520, 435, 386, + 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 228, 0, 0, 1555, 0, 0, 0, 310, + 229, 515, 635, 517, 516, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 313, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 1553, + 0, 0, 0, 0, 0, 0, 300, 442, 461, 311, + 430, 474, 316, 438, 453, 306, 401, 427, 0, 0, + 302, 459, 437, 383, 360, 361, 301, 0, 421, 335, + 351, 332, 399, 0, 458, 486, 331, 477, 0, 469, + 304, 0, 468, 398, 455, 460, 384, 377, 0, 303, + 457, 382, 376, 364, 341, 502, 365, 366, 355, 410, + 374, 411, 356, 388, 387, 389, 0, 0, 0, 0, + 0, 497, 498, 0, 0, 646, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 628, 0, 0, + 632, 0, 471, 0, 0, 0, 0, 0, 0, 441, + 0, 0, 367, 0, 0, 0, 487, 0, 424, 404, + 661, 0, 0, 422, 372, 456, 412, 462, 443, 470, + 418, 413, 294, 444, 334, 385, 307, 309, 329, 336, + 338, 342, 343, 394, 395, 407, 429, 446, 447, 448, + 333, 317, 423, 318, 353, 319, 295, 325, 323, 326, + 431, 327, 297, 408, 452, 0, 348, 419, 380, 298, + 379, 409, 451, 450, 308, 478, 484, 485, 574, 0, + 490, 662, 663, 664, 499, 0, 414, 0, 504, 505, + 506, 508, 509, 510, 511, 575, 592, 559, 529, 492, + 583, 526, 530, 531, 358, 595, 0, 0, 0, 483, + 368, 369, 0, 340, 339, 381, 417, 299, 346, 291, + 292, 657, 330, 400, 597, 630, 631, 522, 0, 584, + 523, 532, 322, 556, 568, 567, 396, 482, 0, 579, + 582, 512, 656, 0, 576, 591, 660, 590, 653, 406, + 0, 428, 588, 535, 0, 580, 554, 0, 581, 550, + 585, 0, 524, 0, 436, 464, 476, 493, 496, 525, + 610, 611, 612, 296, 495, 614, 615, 616, 617, 618, + 619, 620, 613, 467, 557, 534, 560, 475, 537, 536, + 0, 0, 571, 491, 572, 573, 390, 391, 392, 393, + 350, 598, 315, 494, 416, 0, 558, 0, 0, 0, + 0, 0, 0, 0, 0, 563, 564, 561, 665, 0, + 621, 622, 0, 0, 488, 489, 345, 352, 507, 354, + 314, 405, 347, 473, 362, 0, 500, 565, 501, 624, + 627, 625, 626, 397, 357, 359, 432, 363, 373, 420, + 472, 403, 425, 312, 463, 434, 378, 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 228, 0, 0, 0, 0, - 0, 0, 309, 229, 514, 634, 516, 515, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 312, 0, 2438, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 299, - 441, 460, 310, 429, 473, 315, 437, 452, 305, 400, - 426, 0, 0, 301, 458, 436, 382, 359, 360, 300, - 0, 420, 334, 350, 331, 398, 0, 457, 485, 330, - 476, 0, 468, 303, 0, 467, 397, 454, 459, 383, - 376, 0, 302, 456, 381, 375, 363, 340, 501, 364, - 365, 354, 409, 373, 410, 355, 387, 386, 388, 0, - 0, 0, 0, 0, 496, 497, 0, 0, 645, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 627, 0, 0, 631, 2437, 470, 0, 0, 0, 2443, - 2440, 2442, 440, 0, 2441, 366, 0, 0, 0, 486, - 0, 423, 403, 660, 0, 2435, 421, 371, 455, 411, - 461, 442, 469, 417, 412, 294, 443, 333, 384, 306, - 308, 328, 335, 337, 341, 342, 393, 394, 406, 428, - 445, 446, 447, 332, 316, 422, 317, 352, 318, 295, - 324, 322, 325, 430, 326, 297, 407, 451, 0, 347, - 418, 379, 298, 378, 408, 450, 449, 307, 477, 483, - 484, 573, 0, 489, 661, 662, 663, 498, 0, 413, - 0, 503, 504, 505, 507, 508, 509, 510, 574, 591, - 558, 528, 491, 582, 525, 529, 530, 357, 594, 0, - 0, 0, 482, 367, 368, 0, 339, 338, 380, 416, - 345, 291, 292, 656, 329, 399, 596, 629, 630, 521, - 0, 583, 522, 531, 321, 555, 567, 566, 395, 481, - 0, 578, 581, 511, 655, 0, 575, 590, 659, 589, - 652, 405, 0, 427, 587, 534, 0, 579, 553, 0, - 580, 549, 584, 0, 523, 0, 435, 463, 475, 492, - 495, 524, 609, 610, 611, 296, 494, 613, 614, 615, - 616, 617, 618, 619, 612, 466, 556, 533, 559, 474, - 536, 535, 0, 0, 570, 490, 571, 572, 389, 390, - 391, 392, 349, 597, 314, 493, 415, 0, 557, 0, - 0, 0, 0, 0, 0, 0, 0, 562, 563, 560, - 664, 0, 620, 621, 0, 0, 487, 488, 344, 351, - 506, 353, 313, 404, 346, 472, 361, 0, 499, 564, - 500, 623, 626, 624, 625, 396, 356, 358, 431, 362, - 372, 419, 471, 402, 424, 311, 462, 433, 377, 550, - 577, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 280, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 606, 605, 604, 603, 602, + 601, 600, 599, 0, 0, 548, 449, 324, 285, 320, + 321, 328, 654, 651, 454, 655, 0, 293, 528, 371, + 0, 415, 344, 593, 594, 0, 645, 241, 242, 243, + 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, + 253, 254, 255, 258, 259, 260, 261, 262, 263, 264, + 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, + 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, + 0, 287, 288, 289, 290, 0, 0, 281, 282, 283, + 284, 0, 0, 0, 479, 480, 481, 503, 0, 465, + 527, 652, 0, 0, 0, 0, 0, 0, 0, 577, + 589, 623, 0, 633, 634, 636, 638, 637, 640, 439, + 440, 647, 0, 642, 643, 644, 641, 375, 426, 445, + 433, 0, 658, 518, 519, 659, 629, 402, 0, 0, + 533, 566, 555, 639, 521, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 337, 1551, 0, 370, 570, + 552, 562, 553, 538, 539, 540, 547, 349, 541, 542, + 543, 513, 544, 514, 545, 546, 0, 569, 520, 435, + 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 228, 0, 0, 1555, 0, 0, 0, + 310, 229, 515, 635, 517, 516, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 313, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1553, 0, 0, 0, 0, 0, 0, 300, 442, 461, + 311, 430, 474, 316, 438, 453, 306, 401, 427, 0, + 0, 302, 459, 437, 383, 360, 361, 301, 0, 421, + 335, 351, 332, 399, 0, 458, 486, 331, 477, 0, + 469, 304, 0, 468, 398, 455, 460, 384, 377, 0, + 303, 457, 382, 376, 364, 341, 502, 365, 366, 355, + 410, 374, 411, 356, 388, 387, 389, 0, 0, 0, + 0, 0, 497, 498, 0, 0, 646, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 628, 0, + 0, 632, 0, 471, 0, 0, 0, 0, 0, 0, + 441, 0, 0, 367, 0, 0, 0, 487, 0, 424, + 404, 661, 0, 0, 422, 372, 456, 412, 462, 443, + 470, 418, 413, 294, 444, 334, 385, 307, 309, 329, + 336, 338, 342, 343, 394, 395, 407, 429, 446, 447, + 448, 333, 317, 423, 318, 353, 319, 295, 325, 323, + 326, 431, 327, 297, 408, 452, 0, 348, 419, 380, + 298, 379, 409, 451, 450, 308, 478, 484, 485, 574, + 0, 490, 662, 663, 664, 499, 0, 414, 0, 504, + 505, 506, 508, 509, 510, 511, 575, 592, 559, 529, + 492, 583, 526, 530, 531, 358, 595, 0, 0, 0, + 483, 368, 369, 0, 340, 339, 381, 417, 299, 346, + 291, 292, 657, 330, 400, 597, 630, 631, 522, 0, + 584, 523, 532, 322, 556, 568, 567, 396, 482, 0, + 579, 582, 512, 656, 0, 576, 591, 660, 590, 653, + 406, 0, 428, 588, 535, 0, 580, 554, 0, 581, + 550, 585, 0, 524, 0, 436, 464, 476, 493, 496, + 525, 610, 611, 612, 296, 495, 614, 615, 616, 617, + 618, 619, 620, 613, 467, 557, 534, 560, 475, 537, + 536, 0, 0, 571, 491, 572, 573, 390, 391, 392, + 393, 350, 598, 315, 494, 416, 0, 558, 0, 0, + 0, 0, 0, 0, 0, 0, 563, 564, 561, 665, + 0, 621, 622, 0, 0, 488, 489, 345, 352, 507, + 354, 314, 405, 347, 473, 362, 0, 500, 565, 501, + 624, 627, 625, 626, 397, 357, 359, 432, 363, 373, + 420, 472, 403, 425, 312, 463, 434, 378, 551, 578, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 606, 605, 604, 603, + 602, 601, 600, 599, 0, 0, 548, 449, 324, 285, + 320, 321, 328, 654, 651, 454, 655, 0, 293, 528, + 371, 0, 415, 344, 593, 594, 0, 645, 241, 242, + 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, + 252, 253, 254, 255, 258, 259, 260, 261, 262, 263, + 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, + 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, + 0, 0, 287, 288, 289, 290, 0, 0, 281, 282, + 283, 284, 0, 0, 0, 479, 480, 481, 503, 0, + 465, 527, 652, 0, 0, 0, 0, 0, 0, 0, + 577, 589, 623, 0, 633, 634, 636, 638, 637, 640, + 439, 440, 647, 0, 642, 643, 644, 641, 375, 426, + 445, 433, 0, 658, 518, 519, 659, 629, 402, 0, + 0, 533, 566, 555, 639, 521, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 337, 0, 0, 370, + 570, 552, 562, 553, 538, 539, 540, 547, 349, 541, + 542, 543, 513, 544, 514, 545, 546, 0, 569, 520, + 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 4088, 0, 228, 855, 0, 0, 0, 0, + 0, 310, 229, 515, 635, 517, 516, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 313, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 300, 442, + 461, 311, 430, 474, 316, 438, 453, 306, 401, 427, + 0, 0, 302, 459, 437, 383, 360, 361, 301, 0, + 421, 335, 351, 332, 399, 0, 458, 486, 331, 477, + 0, 469, 304, 0, 468, 398, 455, 460, 384, 377, + 0, 303, 457, 382, 376, 364, 341, 502, 365, 366, + 355, 410, 374, 411, 356, 388, 387, 389, 0, 0, + 0, 0, 0, 497, 498, 0, 0, 646, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 628, + 0, 0, 632, 0, 471, 0, 0, 0, 0, 0, + 0, 441, 0, 0, 367, 0, 0, 0, 487, 0, + 424, 404, 661, 0, 0, 422, 372, 456, 412, 462, + 443, 470, 418, 413, 294, 444, 334, 385, 307, 309, + 329, 336, 338, 342, 343, 394, 395, 407, 429, 446, + 447, 448, 333, 317, 423, 318, 353, 319, 295, 325, + 323, 326, 431, 327, 297, 408, 452, 0, 348, 419, + 380, 298, 379, 409, 451, 450, 308, 478, 484, 485, + 574, 0, 490, 662, 663, 664, 499, 0, 414, 0, + 504, 505, 506, 508, 509, 510, 511, 575, 592, 559, + 529, 492, 583, 526, 530, 531, 358, 595, 0, 0, + 0, 483, 368, 369, 0, 340, 339, 381, 417, 299, + 346, 291, 292, 657, 330, 400, 597, 630, 631, 522, + 0, 584, 523, 532, 322, 556, 568, 567, 396, 482, + 0, 579, 582, 512, 656, 0, 576, 591, 660, 590, + 653, 406, 0, 428, 588, 535, 0, 580, 554, 0, + 581, 550, 585, 0, 524, 0, 436, 464, 476, 493, + 496, 525, 610, 611, 612, 296, 495, 614, 615, 616, + 617, 618, 619, 620, 613, 467, 557, 534, 560, 475, + 537, 536, 0, 0, 571, 491, 572, 573, 390, 391, + 392, 393, 350, 598, 315, 494, 416, 0, 558, 0, + 0, 0, 0, 0, 0, 0, 0, 563, 564, 561, + 665, 0, 621, 622, 0, 0, 488, 489, 345, 352, + 507, 354, 314, 405, 347, 473, 362, 0, 500, 565, + 501, 624, 627, 625, 626, 397, 357, 359, 432, 363, + 373, 420, 472, 403, 425, 312, 463, 434, 378, 551, + 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 605, 604, 603, - 602, 601, 600, 599, 598, 0, 0, 547, 448, 323, - 285, 319, 320, 327, 653, 650, 453, 654, 0, 293, - 527, 370, 0, 414, 343, 592, 593, 0, 644, 241, + 0, 0, 0, 0, 0, 0, 0, 606, 605, 604, + 603, 602, 601, 600, 599, 0, 0, 548, 449, 324, + 285, 320, 321, 328, 654, 651, 454, 655, 0, 293, + 528, 371, 0, 415, 344, 593, 594, 0, 645, 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, - 263, 264, 265, 595, 256, 257, 266, 267, 268, 269, + 263, 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, - 282, 283, 284, 0, 0, 0, 478, 479, 480, 502, - 0, 464, 526, 651, 0, 0, 0, 0, 0, 0, - 0, 576, 588, 622, 0, 632, 633, 635, 637, 636, - 639, 438, 439, 646, 0, 641, 642, 643, 640, 374, - 425, 444, 432, 0, 657, 517, 518, 658, 628, 401, - 0, 0, 532, 565, 554, 638, 520, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 336, 0, 0, - 369, 569, 551, 561, 552, 537, 538, 539, 546, 348, - 540, 541, 542, 512, 543, 513, 544, 545, 0, 568, - 519, 434, 385, 586, 585, 0, 0, 0, 0, 0, + 282, 283, 284, 0, 0, 0, 479, 480, 481, 503, + 0, 465, 527, 652, 0, 0, 0, 0, 0, 0, + 0, 577, 589, 623, 0, 633, 634, 636, 638, 637, + 640, 439, 440, 647, 0, 642, 643, 644, 641, 375, + 426, 445, 433, 0, 658, 518, 519, 659, 629, 402, + 0, 0, 533, 566, 555, 639, 521, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 337, 0, 0, + 370, 570, 552, 562, 553, 538, 539, 540, 547, 349, + 541, 542, 543, 513, 544, 514, 545, 546, 0, 569, + 520, 435, 386, 587, 586, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 228, 0, 0, 1555, 0, + 0, 0, 310, 229, 515, 635, 517, 516, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 313, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 1553, 0, 0, 0, 0, 0, 0, 300, + 442, 461, 311, 430, 474, 316, 438, 453, 306, 401, + 427, 0, 0, 302, 459, 437, 383, 360, 361, 301, + 0, 421, 335, 351, 332, 399, 0, 458, 486, 331, + 477, 0, 469, 304, 0, 468, 398, 455, 460, 384, + 377, 0, 303, 457, 382, 376, 364, 341, 502, 365, + 366, 355, 410, 374, 411, 356, 388, 387, 389, 0, + 0, 0, 0, 0, 497, 498, 0, 0, 646, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 628, 0, 0, 632, 0, 471, 0, 0, 0, 0, + 0, 0, 441, 0, 0, 367, 0, 0, 0, 487, + 0, 424, 404, 661, 0, 0, 422, 372, 456, 412, + 462, 443, 470, 418, 413, 294, 444, 334, 385, 307, + 309, 329, 336, 338, 342, 343, 394, 395, 407, 429, + 446, 447, 448, 333, 317, 423, 318, 353, 319, 295, + 325, 323, 326, 431, 327, 297, 408, 452, 0, 348, + 419, 380, 298, 379, 409, 451, 450, 308, 478, 484, + 485, 574, 0, 490, 662, 663, 664, 499, 0, 414, + 0, 504, 505, 506, 508, 509, 510, 511, 575, 592, + 559, 529, 492, 583, 526, 530, 531, 358, 595, 0, + 0, 0, 483, 368, 369, 0, 340, 339, 381, 417, + 299, 346, 291, 292, 657, 330, 400, 597, 630, 631, + 522, 0, 584, 523, 532, 322, 556, 568, 567, 396, + 482, 0, 579, 582, 512, 656, 0, 576, 591, 660, + 590, 653, 406, 0, 428, 588, 535, 0, 580, 554, + 0, 581, 550, 585, 0, 524, 0, 436, 464, 476, + 493, 496, 525, 610, 611, 612, 296, 495, 614, 615, + 616, 617, 618, 619, 620, 613, 467, 557, 534, 560, + 475, 537, 536, 0, 0, 571, 491, 572, 573, 390, + 391, 392, 393, 350, 598, 315, 494, 416, 0, 558, + 0, 0, 0, 0, 0, 0, 0, 0, 563, 564, + 561, 665, 0, 621, 622, 0, 0, 488, 489, 345, + 352, 507, 354, 314, 405, 347, 473, 362, 0, 500, + 565, 501, 624, 627, 625, 626, 397, 357, 359, 432, + 363, 373, 420, 472, 403, 425, 312, 463, 434, 378, + 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 606, 605, + 604, 603, 602, 601, 600, 599, 0, 0, 548, 449, + 324, 285, 320, 321, 328, 654, 651, 454, 655, 0, + 293, 528, 371, 0, 415, 344, 593, 594, 0, 645, + 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, + 250, 251, 252, 253, 254, 255, 258, 259, 260, 261, + 262, 263, 264, 265, 596, 256, 257, 266, 267, 268, + 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, + 279, 0, 0, 0, 287, 288, 289, 290, 0, 0, + 281, 282, 283, 284, 0, 0, 0, 479, 480, 481, + 503, 0, 465, 527, 652, 0, 0, 0, 0, 0, + 0, 0, 577, 589, 623, 0, 633, 634, 636, 638, + 637, 640, 439, 440, 647, 0, 642, 643, 644, 641, + 375, 426, 445, 433, 0, 658, 518, 519, 659, 629, + 402, 0, 0, 533, 566, 555, 639, 521, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 337, 0, + 0, 370, 570, 552, 562, 553, 538, 539, 540, 547, + 349, 541, 542, 543, 513, 544, 514, 545, 546, 0, + 569, 520, 435, 386, 587, 586, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 228, 0, 0, 1555, + 0, 0, 0, 310, 229, 515, 635, 517, 516, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 313, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 1766, 0, 0, 0, 0, 0, 0, + 300, 442, 461, 311, 430, 474, 316, 438, 453, 306, + 401, 427, 0, 0, 302, 459, 437, 383, 360, 361, + 301, 0, 421, 335, 351, 332, 399, 0, 458, 486, + 331, 477, 0, 469, 304, 0, 468, 398, 455, 460, + 384, 377, 0, 303, 457, 382, 376, 364, 341, 502, + 365, 366, 355, 410, 374, 411, 356, 388, 387, 389, + 0, 0, 0, 0, 0, 497, 498, 0, 0, 646, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 628, 0, 0, 632, 0, 471, 0, 0, 0, + 0, 0, 0, 441, 0, 0, 367, 0, 0, 0, + 487, 0, 424, 404, 661, 0, 0, 422, 372, 456, + 412, 462, 443, 470, 418, 413, 294, 444, 334, 385, + 307, 309, 329, 336, 338, 342, 343, 394, 395, 407, + 429, 446, 447, 448, 333, 317, 423, 318, 353, 319, + 295, 325, 323, 326, 431, 327, 297, 408, 452, 0, + 348, 419, 380, 298, 379, 409, 451, 450, 308, 478, + 484, 485, 574, 0, 490, 662, 663, 664, 499, 0, + 414, 0, 504, 505, 506, 508, 509, 510, 511, 575, + 592, 559, 529, 492, 583, 526, 530, 531, 358, 595, + 0, 0, 0, 483, 368, 369, 0, 340, 339, 381, + 417, 299, 346, 291, 292, 657, 330, 400, 597, 630, + 631, 522, 0, 584, 523, 532, 322, 556, 568, 567, + 396, 482, 0, 579, 582, 512, 656, 0, 576, 591, + 660, 590, 653, 406, 0, 428, 588, 535, 0, 580, + 554, 0, 581, 550, 585, 0, 524, 0, 436, 464, + 476, 493, 496, 525, 610, 611, 612, 296, 495, 614, + 615, 616, 617, 618, 619, 620, 613, 467, 557, 534, + 560, 475, 537, 536, 0, 0, 571, 491, 572, 573, + 390, 391, 392, 393, 350, 598, 315, 494, 416, 0, + 558, 0, 0, 0, 0, 0, 0, 0, 0, 563, + 564, 561, 665, 0, 621, 622, 0, 0, 488, 489, + 345, 352, 507, 354, 314, 405, 347, 473, 362, 0, + 500, 565, 501, 624, 627, 625, 626, 397, 357, 359, + 432, 363, 373, 420, 472, 403, 425, 312, 463, 434, + 378, 551, 578, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 606, + 605, 604, 603, 602, 601, 600, 599, 0, 0, 548, + 449, 324, 285, 320, 321, 328, 654, 651, 454, 655, + 0, 293, 528, 371, 0, 415, 344, 593, 594, 0, + 645, 241, 242, 243, 244, 245, 246, 247, 248, 286, + 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, + 261, 262, 263, 264, 265, 596, 256, 257, 266, 267, + 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, + 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, + 0, 281, 282, 283, 284, 0, 0, 0, 479, 480, + 481, 503, 0, 465, 527, 652, 0, 0, 0, 0, + 0, 0, 0, 577, 589, 623, 0, 633, 634, 636, + 638, 637, 640, 439, 440, 647, 0, 642, 643, 644, + 641, 375, 426, 445, 433, 0, 658, 518, 519, 659, + 629, 402, 0, 0, 533, 566, 555, 639, 521, 0, + 0, 0, 0, 0, 2522, 0, 0, 0, 0, 337, + 0, 0, 370, 570, 552, 562, 553, 538, 539, 540, + 547, 349, 541, 542, 543, 513, 544, 514, 545, 546, + 0, 569, 520, 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 228, 0, 0, 0, 0, - 0, 0, 309, 229, 514, 634, 516, 515, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 312, 0, 2438, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 299, - 441, 460, 310, 429, 473, 315, 437, 452, 305, 400, - 426, 0, 0, 301, 458, 436, 382, 359, 360, 300, - 0, 420, 334, 350, 331, 398, 0, 457, 485, 330, - 476, 0, 468, 303, 0, 467, 397, 454, 459, 383, - 376, 0, 302, 456, 381, 375, 363, 340, 501, 364, - 365, 354, 409, 373, 410, 355, 387, 386, 388, 0, - 0, 0, 0, 0, 496, 497, 0, 0, 645, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 627, 0, 0, 631, 2437, 470, 0, 0, 0, 2443, - 2440, 2442, 440, 0, 2441, 366, 0, 0, 0, 486, - 0, 423, 403, 660, 0, 0, 421, 371, 455, 411, - 461, 442, 469, 417, 412, 294, 443, 333, 384, 306, - 308, 328, 335, 337, 341, 342, 393, 394, 406, 428, - 445, 446, 447, 332, 316, 422, 317, 352, 318, 295, - 324, 322, 325, 430, 326, 297, 407, 451, 0, 347, - 418, 379, 298, 378, 408, 450, 449, 307, 477, 483, - 484, 573, 0, 489, 661, 662, 663, 498, 0, 413, - 0, 503, 504, 505, 507, 508, 509, 510, 574, 591, - 558, 528, 491, 582, 525, 529, 530, 357, 594, 0, - 0, 0, 482, 367, 368, 0, 339, 338, 380, 416, - 345, 291, 292, 656, 329, 399, 596, 629, 630, 521, - 0, 583, 522, 531, 321, 555, 567, 566, 395, 481, - 0, 578, 581, 511, 655, 0, 575, 590, 659, 589, - 652, 405, 0, 427, 587, 534, 0, 579, 553, 0, - 580, 549, 584, 0, 523, 0, 435, 463, 475, 492, - 495, 524, 609, 610, 611, 296, 494, 613, 614, 615, - 616, 617, 618, 619, 612, 466, 556, 533, 559, 474, - 536, 535, 0, 0, 570, 490, 571, 572, 389, 390, - 391, 392, 349, 597, 314, 493, 415, 0, 557, 0, - 0, 0, 0, 0, 0, 0, 0, 562, 563, 560, - 664, 0, 620, 621, 0, 0, 487, 488, 344, 351, - 506, 353, 313, 404, 346, 472, 361, 0, 499, 564, - 500, 623, 626, 624, 625, 396, 356, 358, 431, 362, - 372, 419, 471, 402, 424, 311, 462, 433, 377, 550, - 577, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 605, 604, 603, - 602, 601, 600, 599, 598, 0, 0, 547, 448, 323, - 285, 319, 320, 327, 653, 650, 453, 654, 0, 293, - 527, 370, 0, 414, 343, 592, 593, 0, 644, 241, - 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, - 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, - 263, 264, 265, 595, 256, 257, 266, 267, 268, 269, - 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, - 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, - 282, 283, 284, 0, 0, 0, 478, 479, 480, 502, - 0, 464, 526, 651, 0, 0, 0, 0, 0, 0, - 0, 576, 588, 622, 0, 632, 633, 635, 637, 636, - 639, 438, 439, 646, 0, 641, 642, 643, 640, 374, - 425, 444, 432, 0, 657, 517, 518, 658, 628, 401, - 0, 0, 532, 565, 554, 638, 520, 0, 0, 0, - 0, 0, 2136, 0, 0, 0, 0, 336, 0, 0, - 369, 569, 551, 561, 552, 537, 538, 539, 546, 348, - 540, 541, 542, 512, 543, 513, 544, 545, 0, 568, - 519, 434, 385, 586, 585, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 228, 0, 0, 2137, 0, - 0, 0, 309, 229, 514, 634, 516, 515, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 312, 0, 0, - 1260, 1261, 1262, 1259, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 299, - 441, 460, 310, 429, 473, 315, 437, 452, 305, 400, - 426, 0, 0, 301, 458, 436, 382, 359, 360, 300, - 0, 420, 334, 350, 331, 398, 0, 457, 485, 330, - 476, 0, 468, 303, 0, 467, 397, 454, 459, 383, - 376, 0, 302, 456, 381, 375, 363, 340, 501, 364, - 365, 354, 409, 373, 410, 355, 387, 386, 388, 0, - 0, 0, 0, 0, 496, 497, 0, 0, 645, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 627, 0, 0, 631, 0, 470, 0, 0, 0, 0, - 0, 0, 440, 0, 0, 366, 0, 0, 0, 486, - 0, 423, 403, 660, 0, 0, 421, 371, 455, 411, - 461, 442, 469, 417, 412, 294, 443, 333, 384, 306, - 308, 328, 335, 337, 341, 342, 393, 394, 406, 428, - 445, 446, 447, 332, 316, 422, 317, 352, 318, 295, - 324, 322, 325, 430, 326, 297, 407, 451, 0, 347, - 418, 379, 298, 378, 408, 450, 449, 307, 477, 483, - 484, 573, 0, 489, 661, 662, 663, 498, 0, 413, - 0, 503, 504, 505, 507, 508, 509, 510, 574, 591, - 558, 528, 491, 582, 525, 529, 530, 357, 594, 0, - 0, 0, 482, 367, 368, 0, 339, 338, 380, 416, - 345, 291, 292, 656, 329, 399, 596, 629, 630, 521, - 0, 583, 522, 531, 321, 555, 567, 566, 395, 481, - 0, 578, 581, 511, 655, 0, 575, 590, 659, 589, - 652, 405, 0, 427, 587, 534, 0, 579, 553, 0, - 580, 549, 584, 0, 523, 0, 435, 463, 475, 492, - 495, 524, 609, 610, 611, 296, 494, 613, 614, 615, - 616, 617, 618, 619, 612, 466, 556, 533, 559, 474, - 536, 535, 0, 0, 570, 490, 571, 572, 389, 390, - 391, 392, 349, 597, 314, 493, 415, 0, 557, 0, - 0, 0, 0, 0, 0, 0, 0, 562, 563, 560, - 664, 0, 620, 621, 0, 0, 487, 488, 344, 351, - 506, 353, 313, 404, 346, 472, 361, 0, 499, 564, - 500, 623, 626, 624, 625, 396, 356, 358, 431, 362, - 372, 419, 471, 402, 424, 311, 462, 433, 377, 550, - 577, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 605, 604, 603, - 602, 601, 600, 599, 598, 0, 0, 547, 448, 323, - 285, 319, 320, 327, 653, 650, 453, 654, 0, 293, - 527, 370, 0, 414, 343, 592, 593, 0, 644, 241, - 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, - 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, - 263, 264, 265, 595, 256, 257, 266, 267, 268, 269, - 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, - 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, - 282, 283, 284, 0, 0, 0, 478, 479, 480, 502, - 0, 464, 526, 651, 0, 0, 0, 0, 0, 0, - 0, 576, 588, 622, 0, 632, 633, 635, 637, 636, - 639, 438, 439, 646, 0, 641, 642, 643, 640, 374, - 425, 444, 432, 206, 657, 517, 518, 658, 628, 0, - 0, 0, 0, 401, 0, 0, 532, 565, 554, 638, - 520, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 336, 0, 0, 369, 569, 551, 561, 552, 537, - 538, 539, 546, 348, 540, 541, 542, 512, 543, 513, - 544, 545, 140, 568, 519, 434, 385, 586, 585, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 202, 2186, 0, 228, - 0, 0, 0, 0, 0, 0, 309, 229, 514, 634, - 516, 515, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 312, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 299, 441, 460, 310, 429, 473, 315, - 437, 452, 305, 400, 426, 0, 0, 301, 458, 436, - 382, 359, 360, 300, 0, 420, 334, 350, 331, 398, - 0, 457, 485, 330, 476, 0, 468, 303, 0, 467, - 397, 454, 459, 383, 376, 0, 302, 456, 381, 375, - 363, 340, 501, 364, 365, 354, 409, 373, 410, 355, - 387, 386, 388, 0, 0, 0, 0, 0, 496, 497, - 0, 0, 645, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 627, 0, 0, 631, 0, 470, - 0, 0, 0, 0, 0, 0, 440, 0, 0, 366, - 0, 0, 0, 486, 0, 423, 403, 660, 0, 0, - 421, 371, 455, 411, 461, 442, 469, 417, 412, 294, - 443, 333, 384, 306, 308, 328, 335, 337, 341, 342, - 393, 394, 406, 428, 445, 446, 447, 332, 316, 422, - 317, 352, 318, 295, 324, 322, 325, 430, 326, 297, - 407, 451, 0, 347, 418, 379, 298, 378, 408, 450, - 449, 307, 477, 483, 484, 573, 0, 489, 661, 662, - 663, 498, 0, 413, 0, 503, 504, 505, 507, 508, - 509, 510, 574, 591, 558, 528, 491, 582, 525, 529, - 530, 357, 594, 0, 0, 0, 482, 367, 368, 0, - 339, 338, 380, 416, 345, 291, 292, 656, 329, 399, - 596, 629, 630, 521, 0, 583, 522, 531, 321, 555, - 567, 566, 395, 481, 0, 578, 581, 511, 655, 0, - 575, 590, 659, 589, 652, 405, 0, 427, 587, 534, - 0, 579, 553, 0, 580, 549, 584, 0, 523, 0, - 435, 463, 475, 492, 495, 524, 609, 610, 611, 296, - 494, 613, 614, 615, 616, 617, 618, 619, 612, 466, - 556, 533, 559, 474, 536, 535, 0, 0, 570, 490, - 571, 572, 389, 390, 391, 392, 349, 597, 314, 493, - 415, 0, 557, 0, 0, 0, 0, 0, 0, 0, - 0, 562, 563, 560, 664, 0, 620, 621, 0, 0, - 487, 488, 344, 351, 506, 353, 313, 404, 346, 472, - 361, 0, 499, 564, 500, 623, 626, 624, 625, 396, - 356, 358, 431, 362, 372, 419, 471, 402, 424, 311, - 462, 433, 377, 550, 577, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, + 2524, 0, 0, 0, 310, 229, 515, 635, 517, 516, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 313, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 300, 442, 461, 311, 430, 474, 316, 438, 453, + 306, 401, 427, 0, 0, 302, 459, 437, 383, 360, + 361, 301, 0, 421, 335, 351, 332, 399, 0, 458, + 486, 331, 477, 0, 469, 304, 0, 468, 398, 455, + 460, 384, 377, 0, 303, 457, 382, 376, 364, 341, + 502, 365, 366, 355, 410, 374, 411, 356, 388, 387, + 389, 0, 0, 0, 0, 0, 497, 498, 0, 0, + 646, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 628, 0, 0, 632, 0, 471, 0, 0, + 0, 0, 0, 0, 441, 0, 0, 367, 0, 0, + 0, 487, 0, 424, 404, 661, 0, 0, 422, 372, + 456, 412, 462, 443, 470, 418, 413, 294, 444, 334, + 385, 307, 309, 329, 336, 338, 342, 343, 394, 395, + 407, 429, 446, 447, 448, 333, 317, 423, 318, 353, + 319, 295, 325, 323, 326, 431, 327, 297, 408, 452, + 0, 348, 419, 380, 298, 379, 409, 451, 450, 308, + 478, 484, 485, 574, 0, 490, 662, 663, 664, 499, + 0, 414, 0, 504, 505, 506, 508, 509, 510, 511, + 575, 592, 559, 529, 492, 583, 526, 530, 531, 358, + 595, 0, 0, 0, 483, 368, 369, 0, 340, 339, + 381, 417, 299, 346, 291, 292, 657, 330, 400, 597, + 630, 631, 522, 0, 584, 523, 532, 322, 556, 568, + 567, 396, 482, 0, 579, 582, 512, 656, 0, 576, + 591, 660, 590, 653, 406, 0, 428, 588, 535, 0, + 580, 554, 0, 581, 550, 585, 0, 524, 0, 436, + 464, 476, 493, 496, 525, 610, 611, 612, 296, 495, + 614, 615, 616, 617, 618, 619, 620, 613, 467, 557, + 534, 560, 475, 537, 536, 0, 0, 571, 491, 572, + 573, 390, 391, 392, 393, 350, 598, 315, 494, 416, + 0, 558, 0, 0, 0, 0, 0, 0, 0, 0, + 563, 564, 561, 665, 0, 621, 622, 0, 0, 488, + 489, 345, 352, 507, 354, 314, 405, 347, 473, 362, + 0, 500, 565, 501, 624, 627, 625, 626, 397, 357, + 359, 432, 363, 373, 420, 472, 403, 425, 312, 463, + 434, 378, 551, 578, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 606, 605, 604, 603, 602, 601, 600, 599, 0, 0, + 548, 449, 324, 285, 320, 321, 328, 654, 651, 454, + 655, 0, 293, 528, 371, 0, 415, 344, 593, 594, + 0, 645, 241, 242, 243, 244, 245, 246, 247, 248, + 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, + 260, 261, 262, 263, 264, 265, 596, 256, 257, 266, + 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, + 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, + 0, 0, 281, 282, 283, 284, 0, 0, 0, 479, + 480, 481, 503, 0, 465, 527, 652, 0, 0, 0, + 0, 0, 0, 0, 577, 589, 623, 0, 633, 634, + 636, 638, 637, 640, 439, 440, 647, 0, 642, 643, + 644, 641, 375, 426, 445, 433, 0, 658, 518, 519, + 659, 629, 402, 0, 0, 533, 566, 555, 639, 521, + 0, 0, 0, 0, 0, 2137, 0, 0, 0, 0, + 337, 0, 0, 370, 570, 552, 562, 553, 538, 539, + 540, 547, 349, 541, 542, 543, 513, 544, 514, 545, + 546, 0, 569, 520, 435, 386, 587, 586, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 228, 0, + 0, 2138, 0, 0, 0, 310, 229, 515, 635, 517, + 516, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 313, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 300, 442, 461, 311, 430, 474, 316, 438, + 453, 306, 401, 427, 0, 0, 302, 459, 437, 383, + 360, 361, 301, 0, 421, 335, 351, 332, 399, 0, + 458, 486, 331, 477, 0, 469, 304, 0, 468, 398, + 455, 460, 384, 377, 0, 303, 457, 382, 376, 364, + 341, 502, 365, 366, 355, 410, 374, 411, 356, 388, + 387, 389, 0, 0, 0, 0, 0, 497, 498, 0, + 0, 646, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 628, 0, 0, 632, 0, 471, 0, + 0, 0, 0, 0, 0, 441, 0, 0, 367, 0, + 0, 0, 487, 0, 424, 404, 661, 0, 0, 422, + 372, 456, 412, 462, 443, 470, 418, 413, 294, 444, + 334, 385, 307, 309, 329, 336, 338, 342, 343, 394, + 395, 407, 429, 446, 447, 448, 333, 317, 423, 318, + 353, 319, 295, 325, 323, 326, 431, 327, 297, 408, + 452, 0, 348, 419, 380, 298, 379, 409, 451, 450, + 308, 478, 484, 485, 574, 0, 490, 662, 663, 664, + 499, 0, 414, 0, 504, 505, 506, 508, 509, 510, + 511, 575, 592, 559, 529, 492, 583, 526, 530, 531, + 358, 595, 0, 0, 0, 483, 368, 369, 0, 340, + 339, 381, 417, 299, 346, 291, 292, 657, 330, 400, + 597, 630, 631, 522, 0, 584, 523, 532, 322, 556, + 568, 567, 396, 482, 0, 579, 582, 512, 656, 0, + 576, 591, 660, 590, 653, 406, 0, 428, 588, 535, + 0, 580, 554, 0, 581, 550, 585, 0, 524, 0, + 436, 464, 476, 493, 496, 525, 610, 611, 612, 296, + 495, 614, 615, 616, 617, 618, 619, 620, 613, 467, + 557, 534, 560, 475, 537, 536, 0, 0, 571, 491, + 572, 573, 390, 391, 392, 393, 350, 598, 315, 494, + 416, 0, 558, 0, 0, 0, 0, 0, 0, 0, + 0, 563, 564, 561, 665, 0, 621, 622, 0, 0, + 488, 489, 345, 352, 507, 354, 314, 405, 347, 473, + 362, 0, 500, 565, 501, 624, 627, 625, 626, 397, + 357, 359, 432, 363, 373, 420, 472, 403, 425, 312, + 463, 434, 378, 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 605, 604, 603, 602, 601, 600, 599, 598, 0, - 0, 547, 448, 323, 285, 319, 320, 327, 653, 650, - 453, 654, 0, 293, 527, 370, 169, 414, 343, 592, - 593, 0, 644, 241, 242, 243, 244, 245, 246, 247, + 0, 606, 605, 604, 603, 602, 601, 600, 599, 0, + 0, 548, 449, 324, 285, 320, 321, 328, 654, 651, + 454, 655, 0, 293, 528, 371, 0, 415, 344, 593, + 594, 0, 645, 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, - 259, 260, 261, 262, 263, 264, 265, 595, 256, 257, + 259, 260, 261, 262, 263, 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, 282, 283, 284, 0, 0, 0, - 478, 479, 480, 502, 0, 464, 526, 651, 0, 0, - 0, 0, 0, 0, 0, 576, 588, 622, 0, 632, - 633, 635, 637, 636, 639, 438, 439, 646, 0, 641, - 642, 643, 640, 374, 425, 444, 432, 206, 657, 517, - 518, 658, 628, 0, 0, 0, 0, 401, 0, 0, - 532, 565, 554, 638, 520, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 336, 0, 0, 369, 569, - 551, 561, 552, 537, 538, 539, 546, 348, 540, 541, - 542, 512, 543, 513, 544, 545, 140, 568, 519, 434, - 385, 586, 585, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 202, 2171, 0, 228, 0, 0, 0, 0, 0, 0, - 309, 229, 514, 634, 516, 515, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 312, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 299, 441, 460, - 310, 429, 473, 315, 437, 452, 305, 400, 426, 0, - 0, 301, 458, 436, 382, 359, 360, 300, 0, 420, - 334, 350, 331, 398, 0, 457, 485, 330, 476, 0, - 468, 303, 0, 467, 397, 454, 459, 383, 376, 0, - 302, 456, 381, 375, 363, 340, 501, 364, 365, 354, - 409, 373, 410, 355, 387, 386, 388, 0, 0, 0, - 0, 0, 496, 497, 0, 0, 645, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 627, 0, - 0, 631, 0, 470, 0, 0, 0, 0, 0, 0, - 440, 0, 0, 366, 0, 0, 0, 486, 0, 423, - 403, 660, 0, 0, 421, 371, 455, 411, 461, 442, - 469, 417, 412, 294, 443, 333, 384, 306, 308, 328, - 335, 337, 341, 342, 393, 394, 406, 428, 445, 446, - 447, 332, 316, 422, 317, 352, 318, 295, 324, 322, - 325, 430, 326, 297, 407, 451, 0, 347, 418, 379, - 298, 378, 408, 450, 449, 307, 477, 483, 484, 573, - 0, 489, 661, 662, 663, 498, 0, 413, 0, 503, - 504, 505, 507, 508, 509, 510, 574, 591, 558, 528, - 491, 582, 525, 529, 530, 357, 594, 0, 0, 0, - 482, 367, 368, 0, 339, 338, 380, 416, 345, 291, - 292, 656, 329, 399, 596, 629, 630, 521, 0, 583, - 522, 531, 321, 555, 567, 566, 395, 481, 0, 578, - 581, 511, 655, 0, 575, 590, 659, 589, 652, 405, - 0, 427, 587, 534, 0, 579, 553, 0, 580, 549, - 584, 0, 523, 0, 435, 463, 475, 492, 495, 524, - 609, 610, 611, 296, 494, 613, 614, 615, 616, 617, - 618, 619, 612, 466, 556, 533, 559, 474, 536, 535, - 0, 0, 570, 490, 571, 572, 389, 390, 391, 392, - 349, 597, 314, 493, 415, 0, 557, 0, 0, 0, - 0, 0, 0, 0, 0, 562, 563, 560, 664, 0, - 620, 621, 0, 0, 487, 488, 344, 351, 506, 353, - 313, 404, 346, 472, 361, 0, 499, 564, 500, 623, - 626, 624, 625, 396, 356, 358, 431, 362, 372, 419, - 471, 402, 424, 311, 462, 433, 377, 550, 577, 0, + 479, 480, 481, 503, 0, 465, 527, 652, 0, 0, + 0, 0, 0, 0, 0, 577, 589, 623, 0, 633, + 634, 636, 638, 637, 640, 439, 440, 647, 0, 642, + 643, 644, 641, 375, 426, 445, 433, 0, 658, 518, + 519, 659, 629, 402, 0, 0, 533, 566, 555, 639, + 521, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 337, 0, 0, 370, 570, 552, 562, 553, 538, + 539, 540, 547, 349, 541, 542, 543, 513, 544, 514, + 545, 546, 0, 569, 520, 435, 386, 587, 586, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 228, + 0, 0, 3200, 3202, 0, 0, 310, 229, 515, 635, + 517, 516, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 313, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 300, 442, 461, 311, 430, 474, 316, + 438, 453, 306, 401, 427, 0, 0, 302, 459, 437, + 383, 360, 361, 301, 0, 421, 335, 351, 332, 399, + 0, 458, 486, 331, 477, 0, 469, 304, 0, 468, + 398, 455, 460, 384, 377, 0, 303, 457, 382, 376, + 364, 341, 502, 365, 366, 355, 410, 374, 411, 356, + 388, 387, 389, 0, 0, 0, 0, 0, 497, 498, + 0, 0, 646, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 628, 0, 0, 632, 0, 471, + 0, 0, 0, 0, 0, 0, 441, 0, 0, 367, + 0, 0, 0, 487, 0, 424, 404, 661, 0, 0, + 422, 372, 456, 412, 462, 443, 470, 418, 413, 294, + 444, 334, 385, 307, 309, 329, 336, 338, 342, 343, + 394, 395, 407, 429, 446, 447, 448, 333, 317, 423, + 318, 353, 319, 295, 325, 323, 326, 431, 327, 297, + 408, 452, 0, 348, 419, 380, 298, 379, 409, 451, + 450, 308, 478, 484, 485, 574, 0, 490, 662, 663, + 664, 499, 0, 414, 0, 504, 505, 506, 508, 509, + 510, 511, 575, 592, 559, 529, 492, 583, 526, 530, + 531, 358, 595, 0, 0, 0, 483, 368, 369, 0, + 340, 339, 381, 417, 299, 346, 291, 292, 657, 330, + 400, 597, 630, 631, 522, 0, 584, 523, 532, 322, + 556, 568, 567, 396, 482, 0, 579, 582, 512, 656, + 0, 576, 591, 660, 590, 653, 406, 0, 428, 588, + 535, 0, 580, 554, 0, 581, 550, 585, 0, 524, + 0, 436, 464, 476, 493, 496, 525, 610, 611, 612, + 296, 495, 614, 615, 616, 617, 618, 619, 620, 613, + 467, 557, 534, 560, 475, 537, 536, 0, 0, 571, + 491, 572, 573, 390, 391, 392, 393, 350, 598, 315, + 494, 416, 0, 558, 0, 0, 0, 0, 0, 0, + 0, 0, 563, 564, 561, 665, 0, 621, 622, 0, + 0, 488, 489, 345, 352, 507, 354, 314, 405, 347, + 473, 362, 0, 500, 565, 501, 624, 627, 625, 626, + 397, 357, 359, 432, 363, 373, 420, 472, 403, 425, + 312, 463, 434, 378, 551, 578, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 606, 605, 604, 603, 602, 601, 600, 599, + 0, 0, 548, 449, 324, 285, 320, 321, 328, 654, + 651, 454, 655, 0, 293, 528, 371, 0, 415, 344, + 593, 594, 0, 645, 241, 242, 243, 244, 245, 246, + 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, + 258, 259, 260, 261, 262, 263, 264, 265, 596, 256, + 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, + 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, + 289, 290, 0, 0, 281, 282, 283, 284, 0, 0, + 0, 479, 480, 481, 503, 0, 465, 527, 652, 0, + 0, 0, 0, 0, 0, 0, 577, 589, 623, 0, + 633, 634, 636, 638, 637, 640, 439, 440, 647, 0, + 642, 643, 644, 641, 375, 426, 445, 433, 0, 658, + 518, 519, 659, 629, 402, 0, 0, 533, 566, 555, + 639, 521, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 337, 2545, 0, 370, 570, 552, 562, 553, + 538, 539, 540, 547, 349, 541, 542, 543, 513, 544, + 514, 545, 546, 0, 569, 520, 435, 386, 587, 586, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 228, 0, 0, 1555, 0, 0, 0, 310, 229, 515, + 635, 517, 516, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 313, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 300, 442, 461, 311, 430, 474, + 316, 438, 453, 306, 401, 427, 0, 0, 302, 459, + 437, 383, 360, 361, 301, 0, 421, 335, 351, 332, + 399, 0, 458, 486, 331, 477, 0, 469, 304, 0, + 468, 398, 455, 460, 384, 377, 0, 303, 457, 382, + 376, 364, 341, 502, 365, 366, 355, 410, 374, 411, + 356, 388, 387, 389, 0, 0, 0, 0, 0, 497, + 498, 0, 0, 646, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 628, 0, 0, 632, 0, + 471, 0, 0, 0, 0, 0, 0, 441, 0, 0, + 367, 0, 0, 0, 487, 0, 424, 404, 661, 0, + 0, 422, 372, 456, 412, 462, 443, 470, 418, 413, + 294, 444, 334, 385, 307, 309, 329, 336, 338, 342, + 343, 394, 395, 407, 429, 446, 447, 448, 333, 317, + 423, 318, 353, 319, 295, 325, 323, 326, 431, 327, + 297, 408, 452, 0, 348, 419, 380, 298, 379, 409, + 451, 450, 308, 478, 484, 485, 574, 0, 490, 662, + 663, 664, 499, 0, 414, 0, 504, 505, 506, 508, + 509, 510, 511, 575, 592, 559, 529, 492, 583, 526, + 530, 531, 358, 595, 0, 0, 0, 483, 368, 369, + 0, 340, 339, 381, 417, 299, 346, 291, 292, 657, + 330, 400, 597, 630, 631, 522, 0, 584, 523, 532, + 322, 556, 568, 567, 396, 482, 0, 579, 582, 512, + 656, 0, 576, 591, 660, 590, 653, 406, 0, 428, + 588, 535, 0, 580, 554, 0, 581, 550, 585, 0, + 524, 0, 436, 464, 476, 493, 496, 525, 610, 611, + 612, 296, 495, 614, 615, 616, 617, 618, 619, 620, + 613, 467, 557, 534, 560, 475, 537, 536, 0, 0, + 571, 491, 572, 573, 390, 391, 392, 393, 350, 598, + 315, 494, 416, 0, 558, 0, 0, 0, 0, 0, + 0, 0, 0, 563, 564, 561, 665, 0, 621, 622, + 0, 0, 488, 489, 345, 352, 507, 354, 314, 405, + 347, 473, 362, 0, 500, 565, 501, 624, 627, 625, + 626, 397, 357, 359, 432, 363, 373, 420, 472, 403, + 425, 312, 463, 434, 378, 551, 578, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 606, 605, 604, 603, 602, 601, 600, + 599, 0, 0, 548, 449, 324, 285, 320, 321, 328, + 654, 651, 454, 655, 0, 293, 528, 371, 0, 415, + 344, 593, 594, 0, 645, 241, 242, 243, 244, 245, + 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, + 255, 258, 259, 260, 261, 262, 263, 264, 265, 596, + 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, + 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, + 288, 289, 290, 0, 0, 281, 282, 283, 284, 0, + 0, 0, 479, 480, 481, 503, 0, 465, 527, 652, + 0, 0, 0, 0, 0, 0, 0, 577, 589, 623, + 0, 633, 634, 636, 638, 637, 640, 439, 440, 647, + 0, 642, 643, 644, 641, 375, 426, 445, 433, 0, + 658, 518, 519, 659, 629, 402, 0, 0, 533, 566, + 555, 639, 521, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 672, 337, 0, 0, 370, 570, 552, 562, + 553, 538, 539, 540, 547, 349, 541, 542, 543, 513, + 544, 514, 545, 546, 0, 569, 520, 435, 386, 587, + 586, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 228, 0, 0, 0, 0, 0, 0, 310, 229, + 515, 635, 517, 516, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 313, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 300, 442, 461, 311, 430, + 474, 316, 438, 453, 306, 401, 427, 0, 0, 302, + 459, 437, 383, 360, 361, 301, 0, 421, 335, 351, + 332, 399, 0, 458, 486, 331, 477, 0, 469, 304, + 0, 468, 398, 455, 460, 384, 377, 0, 303, 457, + 382, 376, 364, 341, 502, 365, 366, 355, 410, 374, + 411, 356, 388, 387, 389, 0, 0, 0, 0, 0, + 497, 498, 0, 0, 646, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 628, 0, 0, 632, + 0, 471, 0, 671, 0, 0, 0, 0, 441, 0, + 0, 367, 0, 0, 0, 487, 0, 424, 404, 661, + 0, 0, 422, 372, 456, 412, 462, 443, 470, 418, + 413, 294, 444, 334, 385, 307, 309, 329, 336, 338, + 342, 343, 394, 395, 407, 429, 446, 447, 448, 333, + 317, 423, 318, 353, 319, 295, 325, 323, 326, 431, + 327, 297, 408, 452, 0, 348, 419, 380, 298, 379, + 409, 451, 450, 308, 478, 484, 485, 574, 0, 490, + 662, 663, 664, 499, 0, 414, 0, 504, 505, 506, + 508, 509, 510, 511, 575, 592, 559, 529, 492, 583, + 526, 530, 531, 358, 595, 0, 0, 0, 483, 368, + 369, 0, 340, 339, 381, 417, 299, 346, 291, 292, + 657, 330, 400, 597, 630, 631, 522, 0, 584, 523, + 532, 322, 556, 568, 567, 396, 482, 0, 579, 582, + 512, 656, 0, 576, 591, 660, 590, 653, 406, 0, + 428, 588, 535, 0, 580, 554, 0, 581, 550, 585, + 0, 524, 0, 436, 464, 476, 493, 496, 525, 610, + 611, 612, 296, 495, 614, 615, 616, 617, 618, 619, + 620, 613, 467, 557, 534, 560, 475, 537, 536, 0, + 0, 571, 491, 572, 573, 390, 391, 392, 393, 350, + 598, 315, 494, 416, 0, 558, 0, 0, 0, 0, + 0, 0, 0, 0, 563, 564, 561, 665, 0, 621, + 622, 0, 0, 488, 489, 345, 352, 507, 354, 314, + 405, 347, 473, 362, 0, 500, 565, 501, 624, 627, + 625, 626, 397, 357, 359, 432, 363, 373, 420, 472, + 403, 425, 312, 463, 434, 378, 551, 578, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 606, 605, 604, 603, 602, 601, + 600, 599, 0, 0, 548, 449, 324, 285, 320, 321, + 328, 654, 651, 454, 655, 0, 293, 528, 371, 0, + 415, 344, 593, 594, 0, 645, 241, 242, 243, 244, + 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, + 254, 255, 258, 259, 260, 261, 262, 263, 264, 265, + 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, + 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, + 287, 288, 289, 290, 0, 0, 281, 282, 283, 284, + 0, 0, 0, 479, 480, 481, 503, 0, 465, 527, + 652, 0, 0, 0, 0, 0, 0, 0, 577, 589, + 623, 0, 633, 634, 636, 638, 637, 640, 439, 440, + 647, 0, 642, 643, 644, 641, 375, 426, 445, 433, + 0, 658, 518, 519, 659, 629, 402, 0, 0, 533, + 566, 555, 639, 521, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 337, 0, 0, 370, 570, 552, + 562, 553, 538, 539, 540, 547, 349, 541, 542, 543, + 513, 544, 514, 545, 546, 0, 569, 520, 435, 386, + 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 228, 855, 0, 0, 0, 0, 0, 310, + 229, 515, 635, 517, 516, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 313, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 300, 442, 461, 311, + 430, 474, 316, 438, 453, 306, 401, 427, 0, 0, + 302, 459, 437, 383, 360, 361, 301, 0, 421, 335, + 351, 332, 399, 0, 458, 486, 331, 477, 0, 469, + 304, 0, 468, 398, 455, 460, 384, 377, 0, 303, + 457, 382, 376, 364, 341, 502, 365, 366, 355, 410, + 374, 411, 356, 388, 387, 389, 0, 0, 0, 0, + 0, 497, 498, 0, 0, 646, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 628, 0, 0, + 632, 0, 471, 0, 0, 0, 0, 0, 0, 441, + 0, 0, 367, 0, 0, 0, 487, 0, 424, 404, + 661, 0, 0, 422, 372, 456, 412, 462, 443, 470, + 418, 413, 294, 444, 334, 385, 307, 309, 329, 336, + 338, 342, 343, 394, 395, 407, 429, 446, 447, 448, + 333, 317, 423, 318, 353, 319, 295, 325, 323, 326, + 431, 327, 297, 408, 452, 0, 348, 419, 380, 298, + 379, 409, 451, 450, 308, 478, 484, 485, 574, 0, + 490, 662, 663, 664, 499, 0, 414, 0, 504, 505, + 506, 508, 509, 510, 511, 575, 592, 559, 529, 492, + 583, 526, 530, 531, 358, 595, 0, 0, 0, 483, + 368, 369, 0, 340, 339, 381, 417, 299, 346, 291, + 292, 657, 330, 400, 597, 630, 631, 522, 0, 584, + 523, 532, 322, 556, 568, 567, 396, 482, 0, 579, + 582, 512, 656, 0, 576, 591, 660, 590, 653, 406, + 0, 428, 588, 535, 0, 580, 554, 0, 581, 550, + 585, 0, 524, 0, 436, 464, 476, 493, 496, 525, + 610, 611, 612, 296, 495, 614, 615, 616, 617, 618, + 619, 620, 613, 467, 557, 534, 560, 475, 537, 536, + 0, 0, 571, 491, 572, 573, 390, 391, 392, 393, + 350, 598, 315, 494, 416, 0, 558, 0, 0, 0, + 0, 0, 0, 0, 0, 563, 564, 561, 665, 0, + 621, 622, 0, 0, 488, 489, 345, 352, 507, 354, + 314, 405, 347, 473, 362, 0, 500, 565, 501, 624, + 627, 625, 626, 397, 357, 359, 432, 363, 373, 420, + 472, 403, 425, 312, 463, 434, 378, 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 605, 604, 603, 602, 601, - 600, 599, 598, 0, 0, 547, 448, 323, 285, 319, - 320, 327, 653, 650, 453, 654, 0, 293, 527, 370, - 169, 414, 343, 592, 593, 0, 644, 241, 242, 243, + 0, 0, 0, 0, 0, 606, 605, 604, 603, 602, + 601, 600, 599, 0, 0, 548, 449, 324, 285, 320, + 321, 328, 654, 651, 454, 655, 0, 293, 528, 371, + 0, 415, 344, 593, 594, 0, 645, 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, 263, 264, - 265, 595, 256, 257, 266, 267, 268, 269, 270, 271, + 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, 282, 283, - 284, 0, 0, 0, 478, 479, 480, 502, 0, 464, - 526, 651, 0, 0, 0, 0, 0, 0, 0, 576, - 588, 622, 0, 632, 633, 635, 637, 636, 639, 438, - 439, 646, 0, 641, 642, 643, 640, 374, 425, 444, - 432, 0, 657, 517, 518, 658, 628, 401, 0, 0, - 532, 565, 554, 638, 520, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 336, 1050, 0, 369, 569, - 551, 561, 552, 537, 538, 539, 546, 348, 540, 541, - 542, 512, 543, 513, 544, 545, 0, 568, 519, 434, - 385, 586, 585, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 228, 1057, 1058, 0, 0, 0, 0, - 309, 229, 514, 634, 516, 515, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1061, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 299, 441, 1044, - 310, 429, 473, 315, 437, 452, 305, 400, 426, 0, - 0, 301, 458, 436, 382, 359, 360, 300, 0, 420, - 334, 350, 331, 398, 0, 457, 485, 330, 476, 1031, - 468, 303, 1030, 467, 397, 454, 459, 383, 376, 0, - 302, 456, 381, 375, 363, 340, 501, 364, 365, 354, - 409, 373, 410, 355, 387, 386, 388, 0, 0, 0, - 0, 0, 496, 497, 0, 0, 645, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 627, 0, - 0, 631, 0, 470, 0, 0, 0, 0, 0, 0, - 440, 0, 0, 366, 0, 0, 0, 486, 0, 423, - 403, 660, 0, 0, 421, 371, 455, 411, 461, 442, - 469, 1048, 412, 294, 443, 333, 384, 306, 308, 328, - 335, 337, 341, 342, 393, 394, 406, 428, 445, 446, - 447, 332, 316, 422, 317, 352, 318, 295, 324, 322, - 325, 430, 326, 297, 407, 451, 0, 347, 418, 379, - 298, 378, 408, 450, 449, 307, 477, 483, 484, 573, - 0, 489, 661, 662, 663, 498, 0, 413, 0, 503, - 504, 505, 507, 508, 509, 510, 574, 591, 558, 528, - 491, 582, 525, 529, 530, 357, 594, 0, 0, 0, - 482, 367, 368, 0, 339, 338, 380, 416, 345, 291, - 292, 656, 329, 399, 596, 629, 630, 521, 0, 583, - 522, 531, 321, 555, 567, 566, 395, 481, 0, 578, - 581, 511, 655, 0, 575, 590, 659, 589, 652, 405, - 0, 427, 587, 534, 0, 579, 553, 0, 580, 549, - 584, 0, 523, 0, 435, 463, 475, 492, 495, 524, - 609, 610, 611, 296, 494, 613, 614, 615, 616, 617, - 618, 1049, 612, 466, 556, 533, 559, 474, 536, 535, - 0, 0, 570, 1052, 571, 572, 389, 390, 391, 392, - 349, 597, 1047, 493, 415, 0, 557, 0, 0, 0, - 0, 0, 0, 0, 0, 562, 563, 560, 664, 0, - 620, 621, 0, 0, 487, 488, 344, 351, 506, 353, - 313, 404, 346, 472, 361, 0, 499, 564, 500, 623, - 626, 624, 625, 1059, 1045, 1055, 1046, 362, 372, 419, - 471, 402, 424, 311, 462, 433, 1056, 550, 577, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 280, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 605, 604, 603, 602, 601, - 600, 599, 598, 0, 0, 547, 448, 323, 285, 319, - 320, 327, 653, 650, 453, 654, 0, 293, 527, 370, - 0, 414, 343, 592, 593, 0, 644, 241, 242, 243, - 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, - 253, 254, 255, 258, 259, 260, 261, 262, 263, 264, - 265, 595, 256, 257, 266, 267, 268, 269, 270, 271, - 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, - 0, 287, 288, 289, 290, 0, 0, 281, 282, 283, - 284, 0, 0, 0, 478, 479, 480, 502, 0, 464, - 526, 651, 0, 0, 0, 0, 0, 0, 0, 576, - 588, 622, 0, 632, 633, 635, 637, 636, 639, 438, - 439, 646, 0, 641, 642, 643, 640, 1043, 425, 444, - 432, 206, 657, 517, 518, 658, 628, 0, 0, 0, - 0, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 140, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 2068, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 169, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 1057, 1058, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 1061, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 1031, 468, 303, 1030, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 1059, 2089, 1055, - 2090, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 1056, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 2980, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 2983, 0, 0, - 0, 2982, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 1556, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 1554, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1552, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 1550, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 1554, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1552, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 4086, 0, 228, 854, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 1554, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1552, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 1554, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1765, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 2521, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 2523, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 2136, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 2137, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 3199, 3201, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 2544, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 1554, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 671, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 670, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 854, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 4063, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 3818, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 3954, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1779, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 3833, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 3740, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 3232, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 3251, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 2068, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 3452, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 3360, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 3088, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 1554, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 2523, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 2898, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 2206, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 2642, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 2604, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 2602, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 2370, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 1919, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 2050, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 1554, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 1955, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 1583, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 671, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 681, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 979, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, + 284, 0, 0, 0, 479, 480, 481, 503, 0, 465, + 527, 652, 0, 0, 0, 0, 0, 0, 0, 577, + 589, 623, 0, 633, 634, 636, 638, 637, 640, 439, + 440, 647, 0, 642, 643, 644, 641, 375, 426, 445, + 433, 0, 658, 518, 519, 659, 629, 402, 0, 0, + 533, 566, 555, 639, 521, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 337, 0, 0, 370, 570, + 552, 562, 553, 538, 539, 540, 547, 349, 541, 542, + 543, 513, 544, 514, 545, 546, 0, 569, 520, 435, + 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 4065, 0, 0, 228, 0, 0, 0, 0, 0, 0, + 310, 229, 515, 635, 517, 516, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 313, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 300, 442, 461, + 311, 430, 474, 316, 438, 453, 306, 401, 427, 0, + 0, 302, 459, 437, 383, 360, 361, 301, 0, 421, + 335, 351, 332, 399, 0, 458, 486, 331, 477, 0, + 469, 304, 0, 468, 398, 455, 460, 384, 377, 0, + 303, 457, 382, 376, 364, 341, 502, 365, 366, 355, + 410, 374, 411, 356, 388, 387, 389, 0, 0, 0, + 0, 0, 497, 498, 0, 0, 646, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 628, 0, + 0, 632, 0, 471, 0, 0, 0, 0, 0, 0, + 441, 0, 0, 367, 0, 0, 0, 487, 0, 424, + 404, 661, 0, 0, 422, 372, 456, 412, 462, 443, + 470, 418, 413, 294, 444, 334, 385, 307, 309, 329, + 336, 338, 342, 343, 394, 395, 407, 429, 446, 447, + 448, 333, 317, 423, 318, 353, 319, 295, 325, 323, + 326, 431, 327, 297, 408, 452, 0, 348, 419, 380, + 298, 379, 409, 451, 450, 308, 478, 484, 485, 574, + 0, 490, 662, 663, 664, 499, 0, 414, 0, 504, + 505, 506, 508, 509, 510, 511, 575, 592, 559, 529, + 492, 583, 526, 530, 531, 358, 595, 0, 0, 0, + 483, 368, 369, 0, 340, 339, 381, 417, 299, 346, + 291, 292, 657, 330, 400, 597, 630, 631, 522, 0, + 584, 523, 532, 322, 556, 568, 567, 396, 482, 0, + 579, 582, 512, 656, 0, 576, 591, 660, 590, 653, + 406, 0, 428, 588, 535, 0, 580, 554, 0, 581, + 550, 585, 0, 524, 0, 436, 464, 476, 493, 496, + 525, 610, 611, 612, 296, 495, 614, 615, 616, 617, + 618, 619, 620, 613, 467, 557, 534, 560, 475, 537, + 536, 0, 0, 571, 491, 572, 573, 390, 391, 392, + 393, 350, 598, 315, 494, 416, 0, 558, 0, 0, + 0, 0, 0, 0, 0, 0, 563, 564, 561, 665, + 0, 621, 622, 0, 0, 488, 489, 345, 352, 507, + 354, 314, 405, 347, 473, 362, 0, 500, 565, 501, + 624, 627, 625, 626, 397, 357, 359, 432, 363, 373, + 420, 472, 403, 425, 312, 463, 434, 378, 551, 578, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 606, 605, 604, 603, + 602, 601, 600, 599, 0, 0, 548, 449, 324, 285, + 320, 321, 328, 654, 651, 454, 655, 0, 293, 528, + 371, 0, 415, 344, 593, 594, 0, 645, 241, 242, + 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, + 252, 253, 254, 255, 258, 259, 260, 261, 262, 263, + 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, + 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, + 0, 0, 287, 288, 289, 290, 0, 0, 281, 282, + 283, 284, 0, 0, 0, 479, 480, 481, 503, 0, + 465, 527, 652, 0, 0, 0, 0, 0, 0, 0, + 577, 589, 623, 0, 633, 634, 636, 638, 637, 640, + 439, 440, 647, 0, 642, 643, 644, 641, 375, 426, + 445, 433, 0, 658, 518, 519, 659, 629, 402, 0, + 0, 533, 566, 555, 639, 521, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 337, 0, 0, 370, + 570, 552, 562, 553, 538, 539, 540, 547, 349, 541, + 542, 543, 513, 544, 514, 545, 546, 0, 569, 520, + 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 228, 0, 0, 3819, 0, 0, + 0, 310, 229, 515, 635, 517, 516, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 313, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 300, 442, + 461, 311, 430, 474, 316, 438, 453, 306, 401, 427, + 0, 0, 302, 459, 437, 383, 360, 361, 301, 0, + 421, 335, 351, 332, 399, 0, 458, 486, 331, 477, + 0, 469, 304, 0, 468, 398, 455, 460, 384, 377, + 0, 303, 457, 382, 376, 364, 341, 502, 365, 366, + 355, 410, 374, 411, 356, 388, 387, 389, 0, 0, + 0, 0, 0, 497, 498, 0, 0, 646, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 628, + 0, 0, 632, 0, 471, 0, 0, 0, 0, 0, + 0, 441, 0, 0, 367, 0, 0, 0, 487, 0, + 424, 404, 661, 0, 0, 422, 372, 456, 412, 462, + 443, 470, 418, 413, 294, 444, 334, 385, 307, 309, + 329, 336, 338, 342, 343, 394, 395, 407, 429, 446, + 447, 448, 333, 317, 423, 318, 353, 319, 295, 325, + 323, 326, 431, 327, 297, 408, 452, 0, 348, 419, + 380, 298, 379, 409, 451, 450, 308, 478, 484, 485, + 574, 0, 490, 662, 663, 664, 499, 0, 414, 0, + 504, 505, 506, 508, 509, 510, 511, 575, 592, 559, + 529, 492, 583, 526, 530, 531, 358, 595, 0, 0, + 0, 483, 368, 369, 0, 340, 339, 381, 417, 299, + 346, 291, 292, 657, 330, 400, 597, 630, 631, 522, + 0, 584, 523, 532, 322, 556, 568, 567, 396, 482, + 0, 579, 582, 512, 656, 0, 576, 591, 660, 590, + 653, 406, 0, 428, 588, 535, 0, 580, 554, 0, + 581, 550, 585, 0, 524, 0, 436, 464, 476, 493, + 496, 525, 610, 611, 612, 296, 495, 614, 615, 616, + 617, 618, 619, 620, 613, 467, 557, 534, 560, 475, + 537, 536, 0, 0, 571, 491, 572, 573, 390, 391, + 392, 393, 350, 598, 315, 494, 416, 0, 558, 0, + 0, 0, 0, 0, 0, 0, 0, 563, 564, 561, + 665, 0, 621, 622, 0, 0, 488, 489, 345, 352, + 507, 354, 314, 405, 347, 473, 362, 0, 500, 565, + 501, 624, 627, 625, 626, 397, 357, 359, 432, 363, + 373, 420, 472, 403, 425, 312, 463, 434, 378, 551, + 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 606, 605, 604, + 603, 602, 601, 600, 599, 0, 0, 548, 449, 324, + 285, 320, 321, 328, 654, 651, 454, 655, 0, 293, + 528, 371, 0, 415, 344, 593, 594, 0, 645, 241, + 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, + 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, + 263, 264, 265, 596, 256, 257, 266, 267, 268, 269, + 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, + 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, + 282, 283, 284, 0, 0, 0, 479, 480, 481, 503, + 0, 465, 527, 652, 0, 0, 0, 0, 0, 0, + 0, 577, 589, 623, 0, 633, 634, 636, 638, 637, + 640, 439, 440, 647, 0, 642, 643, 644, 641, 375, + 426, 445, 433, 0, 658, 518, 519, 659, 629, 402, + 0, 0, 533, 566, 555, 639, 521, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 337, 0, 0, + 370, 570, 552, 562, 553, 538, 539, 540, 547, 349, + 541, 542, 543, 513, 544, 514, 545, 546, 0, 569, + 520, 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 3177, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 228, 0, 0, 0, 0, + 0, 0, 310, 229, 515, 635, 517, 516, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 313, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 300, + 442, 461, 311, 430, 474, 316, 438, 453, 306, 401, + 427, 0, 0, 302, 459, 437, 383, 360, 361, 301, + 0, 421, 335, 351, 332, 399, 0, 458, 486, 331, + 477, 0, 469, 304, 0, 468, 398, 455, 460, 384, + 377, 0, 303, 457, 382, 376, 364, 341, 502, 365, + 366, 355, 410, 374, 411, 356, 388, 387, 389, 0, + 0, 0, 0, 0, 497, 498, 0, 0, 646, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 628, 0, 0, 632, 0, 471, 0, 0, 0, 3955, + 0, 0, 441, 0, 0, 367, 0, 0, 0, 487, + 0, 424, 404, 661, 0, 0, 422, 372, 456, 412, + 462, 443, 470, 418, 413, 294, 444, 334, 385, 307, + 309, 329, 336, 338, 342, 343, 394, 395, 407, 429, + 446, 447, 448, 333, 317, 423, 318, 353, 319, 295, + 325, 323, 326, 431, 327, 297, 408, 452, 0, 348, + 419, 380, 298, 379, 409, 451, 450, 308, 478, 484, + 485, 574, 0, 490, 662, 663, 664, 499, 0, 414, + 0, 504, 505, 506, 508, 509, 510, 511, 575, 592, + 559, 529, 492, 583, 526, 530, 531, 358, 595, 0, + 0, 0, 483, 368, 369, 0, 340, 339, 381, 417, + 299, 346, 291, 292, 657, 330, 400, 597, 630, 631, + 522, 0, 584, 523, 532, 322, 556, 568, 567, 396, + 482, 0, 579, 582, 512, 656, 0, 576, 591, 660, + 590, 653, 406, 0, 428, 588, 535, 0, 580, 554, + 0, 581, 550, 585, 0, 524, 0, 436, 464, 476, + 493, 496, 525, 610, 611, 612, 296, 495, 614, 615, + 616, 617, 618, 619, 620, 613, 467, 557, 534, 560, + 475, 537, 536, 0, 0, 571, 491, 572, 573, 390, + 391, 392, 393, 350, 598, 315, 494, 416, 0, 558, + 0, 0, 0, 0, 0, 0, 0, 0, 563, 564, + 561, 665, 0, 621, 622, 0, 0, 488, 489, 345, + 352, 507, 354, 314, 405, 347, 473, 362, 0, 500, + 565, 501, 624, 627, 625, 626, 397, 357, 359, 432, + 363, 373, 420, 472, 403, 425, 312, 463, 434, 378, + 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 606, 605, + 604, 603, 602, 601, 600, 599, 0, 0, 548, 449, + 324, 285, 320, 321, 328, 654, 651, 454, 655, 0, + 293, 528, 371, 0, 415, 344, 593, 594, 0, 645, + 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, + 250, 251, 252, 253, 254, 255, 258, 259, 260, 261, + 262, 263, 264, 265, 596, 256, 257, 266, 267, 268, + 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, + 279, 0, 0, 0, 287, 288, 289, 290, 0, 0, + 281, 282, 283, 284, 0, 0, 0, 479, 480, 481, + 503, 0, 465, 527, 652, 0, 0, 0, 0, 0, + 0, 0, 577, 589, 623, 0, 633, 634, 636, 638, + 637, 640, 439, 440, 647, 0, 642, 643, 644, 641, + 375, 426, 445, 433, 0, 658, 518, 519, 659, 629, + 402, 0, 0, 533, 566, 555, 639, 521, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 337, 0, + 0, 370, 570, 552, 562, 553, 538, 539, 540, 547, + 349, 541, 542, 543, 513, 544, 514, 545, 546, 0, + 569, 520, 435, 386, 587, 586, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 1780, 0, 0, 228, 0, 0, 0, + 0, 0, 0, 310, 229, 515, 635, 517, 516, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 313, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 300, 442, 461, 311, 430, 474, 316, 438, 453, 306, + 401, 427, 0, 0, 302, 459, 437, 383, 360, 361, + 301, 0, 421, 335, 351, 332, 399, 0, 458, 486, + 331, 477, 0, 469, 304, 0, 468, 398, 455, 460, + 384, 377, 0, 303, 457, 382, 376, 364, 341, 502, + 365, 366, 355, 410, 374, 411, 356, 388, 387, 389, + 0, 0, 0, 0, 0, 497, 498, 0, 0, 646, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 628, 0, 0, 632, 0, 471, 0, 0, 0, + 0, 0, 0, 441, 0, 0, 367, 0, 0, 0, + 487, 0, 424, 404, 661, 0, 0, 422, 372, 456, + 412, 462, 443, 470, 418, 413, 294, 444, 334, 385, + 307, 309, 329, 336, 338, 342, 343, 394, 395, 407, + 429, 446, 447, 448, 333, 317, 423, 318, 353, 319, + 295, 325, 323, 326, 431, 327, 297, 408, 452, 0, + 348, 419, 380, 298, 379, 409, 451, 450, 308, 478, + 484, 485, 574, 0, 490, 662, 663, 664, 499, 0, + 414, 0, 504, 505, 506, 508, 509, 510, 511, 575, + 592, 559, 529, 492, 583, 526, 530, 531, 358, 595, + 0, 0, 0, 483, 368, 369, 0, 340, 339, 381, + 417, 299, 346, 291, 292, 657, 330, 400, 597, 630, + 631, 522, 0, 584, 523, 532, 322, 556, 568, 567, + 396, 482, 0, 579, 582, 512, 656, 0, 576, 591, + 660, 590, 653, 406, 0, 428, 588, 535, 0, 580, + 554, 0, 581, 550, 585, 0, 524, 0, 436, 464, + 476, 493, 496, 525, 610, 611, 612, 296, 495, 614, + 615, 616, 617, 618, 619, 620, 613, 467, 557, 534, + 560, 475, 537, 536, 0, 0, 571, 491, 572, 573, + 390, 391, 392, 393, 350, 598, 315, 494, 416, 0, + 558, 0, 0, 0, 0, 0, 0, 0, 0, 563, + 564, 561, 665, 0, 621, 622, 0, 0, 488, 489, + 345, 352, 507, 354, 314, 405, 347, 473, 362, 0, + 500, 565, 501, 624, 627, 625, 626, 397, 357, 359, + 432, 363, 373, 420, 472, 403, 425, 312, 463, 434, + 378, 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 606, + 605, 604, 603, 602, 601, 600, 599, 0, 0, 548, + 449, 324, 285, 320, 321, 328, 654, 651, 454, 655, + 0, 293, 528, 371, 0, 415, 344, 593, 594, 0, + 645, 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, + 261, 262, 263, 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, + 0, 281, 282, 283, 284, 0, 0, 0, 479, 480, + 481, 503, 0, 465, 527, 652, 0, 0, 0, 0, + 0, 0, 0, 577, 589, 623, 0, 633, 634, 636, + 638, 637, 640, 439, 440, 647, 0, 642, 643, 644, + 641, 375, 426, 445, 433, 0, 658, 518, 519, 659, + 629, 402, 0, 0, 533, 566, 555, 639, 521, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 337, + 0, 0, 370, 570, 552, 562, 553, 538, 539, 540, + 547, 349, 541, 542, 543, 513, 544, 514, 545, 546, + 0, 569, 520, 435, 386, 587, 586, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 3834, 0, 228, 0, 0, + 0, 0, 0, 0, 310, 229, 515, 635, 517, 516, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 313, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 300, 442, 461, 311, 430, 474, 316, 438, 453, + 306, 401, 427, 0, 0, 302, 459, 437, 383, 360, + 361, 301, 0, 421, 335, 351, 332, 399, 0, 458, + 486, 331, 477, 0, 469, 304, 0, 468, 398, 455, + 460, 384, 377, 0, 303, 457, 382, 376, 364, 341, + 502, 365, 366, 355, 410, 374, 411, 356, 388, 387, + 389, 0, 0, 0, 0, 0, 497, 498, 0, 0, + 646, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 628, 0, 0, 632, 0, 471, 0, 0, + 0, 0, 0, 0, 441, 0, 0, 367, 0, 0, + 0, 487, 0, 424, 404, 661, 0, 0, 422, 372, + 456, 412, 462, 443, 470, 418, 413, 294, 444, 334, + 385, 307, 309, 329, 336, 338, 342, 343, 394, 395, + 407, 429, 446, 447, 448, 333, 317, 423, 318, 353, + 319, 295, 325, 323, 326, 431, 327, 297, 408, 452, + 0, 348, 419, 380, 298, 379, 409, 451, 450, 308, + 478, 484, 485, 574, 0, 490, 662, 663, 664, 499, + 0, 414, 0, 504, 505, 506, 508, 509, 510, 511, + 575, 592, 559, 529, 492, 583, 526, 530, 531, 358, + 595, 0, 0, 0, 483, 368, 369, 0, 340, 339, + 381, 417, 299, 346, 291, 292, 657, 330, 400, 597, + 630, 631, 522, 0, 584, 523, 532, 322, 556, 568, + 567, 396, 482, 0, 579, 582, 512, 656, 0, 576, + 591, 660, 590, 653, 406, 0, 428, 588, 535, 0, + 580, 554, 0, 581, 550, 585, 0, 524, 0, 436, + 464, 476, 493, 496, 525, 610, 611, 612, 296, 495, + 614, 615, 616, 617, 618, 619, 620, 613, 467, 557, + 534, 560, 475, 537, 536, 0, 0, 571, 491, 572, + 573, 390, 391, 392, 393, 350, 598, 315, 494, 416, + 0, 558, 0, 0, 0, 0, 0, 0, 0, 0, + 563, 564, 561, 665, 0, 621, 622, 0, 0, 488, + 489, 345, 352, 507, 354, 314, 405, 347, 473, 362, + 0, 500, 565, 501, 624, 627, 625, 626, 397, 357, + 359, 432, 363, 373, 420, 472, 403, 425, 312, 463, + 434, 378, 551, 578, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 606, 605, 604, 603, 602, 601, 600, 599, 0, 0, + 548, 449, 324, 285, 320, 321, 328, 654, 651, 454, + 655, 0, 293, 528, 371, 0, 415, 344, 593, 594, + 0, 645, 241, 242, 243, 244, 245, 246, 247, 248, + 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, + 260, 261, 262, 263, 264, 265, 596, 256, 257, 266, + 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, + 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, + 0, 0, 281, 282, 283, 284, 0, 0, 0, 479, + 480, 481, 503, 0, 465, 527, 652, 0, 0, 0, + 0, 0, 0, 0, 577, 589, 623, 0, 633, 634, + 636, 638, 637, 640, 439, 440, 647, 0, 642, 643, + 644, 641, 375, 426, 445, 433, 0, 658, 518, 519, + 659, 629, 402, 0, 0, 533, 566, 555, 639, 521, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 337, 0, 0, 370, 570, 552, 562, 553, 538, 539, + 540, 547, 349, 541, 542, 543, 513, 544, 514, 545, + 546, 0, 569, 520, 435, 386, 587, 586, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 228, 0, + 0, 0, 0, 0, 0, 310, 229, 515, 635, 517, + 516, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 313, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 300, 442, 461, 311, 430, 474, 316, 438, + 453, 306, 401, 427, 0, 0, 302, 459, 437, 383, + 360, 361, 301, 0, 421, 335, 351, 332, 399, 0, + 458, 486, 331, 477, 0, 469, 304, 0, 468, 398, + 455, 460, 384, 377, 0, 303, 457, 382, 376, 364, + 341, 502, 365, 366, 355, 410, 374, 411, 356, 388, + 387, 389, 0, 0, 0, 0, 0, 497, 498, 0, + 0, 646, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 628, 0, 0, 632, 0, 471, 0, + 0, 0, 3741, 0, 0, 441, 0, 0, 367, 0, + 0, 0, 487, 0, 424, 404, 661, 0, 0, 422, + 372, 456, 412, 462, 443, 470, 418, 413, 294, 444, + 334, 385, 307, 309, 329, 336, 338, 342, 343, 394, + 395, 407, 429, 446, 447, 448, 333, 317, 423, 318, + 353, 319, 295, 325, 323, 326, 431, 327, 297, 408, + 452, 0, 348, 419, 380, 298, 379, 409, 451, 450, + 308, 478, 484, 485, 574, 0, 490, 662, 663, 664, + 499, 0, 414, 0, 504, 505, 506, 508, 509, 510, + 511, 575, 592, 559, 529, 492, 583, 526, 530, 531, + 358, 595, 0, 0, 0, 483, 368, 369, 0, 340, + 339, 381, 417, 299, 346, 291, 292, 657, 330, 400, + 597, 630, 631, 522, 0, 584, 523, 532, 322, 556, + 568, 567, 396, 482, 0, 579, 582, 512, 656, 0, + 576, 591, 660, 590, 653, 406, 0, 428, 588, 535, + 0, 580, 554, 0, 581, 550, 585, 0, 524, 0, + 436, 464, 476, 493, 496, 525, 610, 611, 612, 296, + 495, 614, 615, 616, 617, 618, 619, 620, 613, 467, + 557, 534, 560, 475, 537, 536, 0, 0, 571, 491, + 572, 573, 390, 391, 392, 393, 350, 598, 315, 494, + 416, 0, 558, 0, 0, 0, 0, 0, 0, 0, + 0, 563, 564, 561, 665, 0, 621, 622, 0, 0, + 488, 489, 345, 352, 507, 354, 314, 405, 347, 473, + 362, 0, 500, 565, 501, 624, 627, 625, 626, 397, + 357, 359, 432, 363, 373, 420, 472, 403, 425, 312, + 463, 434, 378, 551, 578, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 1905, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, + 0, 606, 605, 604, 603, 602, 601, 600, 599, 0, + 0, 548, 449, 324, 285, 320, 321, 328, 654, 651, + 454, 655, 0, 293, 528, 371, 0, 415, 344, 593, + 594, 0, 645, 241, 242, 243, 244, 245, 246, 247, + 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, + 259, 260, 261, 262, 263, 264, 265, 596, 256, 257, + 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, + 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, + 290, 0, 0, 281, 282, 283, 284, 0, 0, 0, + 479, 480, 481, 503, 0, 465, 527, 652, 0, 0, + 0, 0, 0, 0, 0, 577, 589, 623, 0, 633, + 634, 636, 638, 637, 640, 439, 440, 647, 0, 642, + 643, 644, 641, 375, 426, 445, 433, 0, 658, 518, + 519, 659, 629, 402, 0, 0, 533, 566, 555, 639, + 521, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 337, 0, 0, 370, 570, 552, 562, 553, 538, + 539, 540, 547, 349, 541, 542, 543, 513, 544, 514, + 545, 546, 0, 569, 520, 435, 386, 587, 586, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 228, + 0, 0, 3233, 0, 0, 0, 310, 229, 515, 635, + 517, 516, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 313, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 300, 442, 461, 311, 430, 474, 316, + 438, 453, 306, 401, 427, 0, 0, 302, 459, 437, + 383, 360, 361, 301, 0, 421, 335, 351, 332, 399, + 0, 458, 486, 331, 477, 0, 469, 304, 0, 468, + 398, 455, 460, 384, 377, 0, 303, 457, 382, 376, + 364, 341, 502, 365, 366, 355, 410, 374, 411, 356, + 388, 387, 389, 0, 0, 0, 0, 0, 497, 498, + 0, 0, 646, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 628, 0, 0, 632, 0, 471, + 0, 0, 0, 0, 0, 0, 441, 0, 0, 367, + 0, 0, 0, 487, 0, 424, 404, 661, 0, 0, + 422, 372, 456, 412, 462, 443, 470, 418, 413, 294, + 444, 334, 385, 307, 309, 329, 336, 338, 342, 343, + 394, 395, 407, 429, 446, 447, 448, 333, 317, 423, + 318, 353, 319, 295, 325, 323, 326, 431, 327, 297, + 408, 452, 0, 348, 419, 380, 298, 379, 409, 451, + 450, 308, 478, 484, 485, 574, 0, 490, 662, 663, + 664, 499, 0, 414, 0, 504, 505, 506, 508, 509, + 510, 511, 575, 592, 559, 529, 492, 583, 526, 530, + 531, 358, 595, 0, 0, 0, 483, 368, 369, 0, + 340, 339, 381, 417, 299, 346, 291, 292, 657, 330, + 400, 597, 630, 631, 522, 0, 584, 523, 532, 322, + 556, 568, 567, 396, 482, 0, 579, 582, 512, 656, + 0, 576, 591, 660, 590, 653, 406, 0, 428, 588, + 535, 0, 580, 554, 0, 581, 550, 585, 0, 524, + 0, 436, 464, 476, 493, 496, 525, 610, 611, 612, + 296, 495, 614, 615, 616, 617, 618, 619, 620, 613, + 467, 557, 534, 560, 475, 537, 536, 0, 0, 571, + 491, 572, 573, 390, 391, 392, 393, 350, 598, 315, + 494, 416, 0, 558, 0, 0, 0, 0, 0, 0, + 0, 0, 563, 564, 561, 665, 0, 621, 622, 0, + 0, 488, 489, 345, 352, 507, 354, 314, 405, 347, + 473, 362, 0, 500, 565, 501, 624, 627, 625, 626, + 397, 357, 359, 432, 363, 373, 420, 472, 403, 425, + 312, 463, 434, 378, 551, 578, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 606, 605, 604, 603, 602, 601, 600, 599, + 0, 0, 548, 449, 324, 285, 320, 321, 328, 654, + 651, 454, 655, 0, 293, 528, 371, 0, 415, 344, + 593, 594, 0, 645, 241, 242, 243, 244, 245, 246, + 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, + 258, 259, 260, 261, 262, 263, 264, 265, 596, 256, + 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, + 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, + 289, 290, 0, 0, 281, 282, 283, 284, 0, 0, + 0, 479, 480, 481, 503, 0, 465, 527, 652, 0, + 0, 0, 0, 0, 0, 0, 577, 589, 623, 0, + 633, 634, 636, 638, 637, 640, 439, 440, 647, 0, + 642, 643, 644, 641, 375, 426, 445, 433, 0, 658, + 518, 519, 659, 629, 402, 0, 0, 533, 566, 555, + 639, 521, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 337, 0, 0, 370, 570, 552, 562, 553, + 538, 539, 540, 547, 349, 541, 542, 543, 513, 544, + 514, 545, 546, 0, 569, 520, 435, 386, 587, 586, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 228, 0, 0, 0, 0, 0, 0, 310, 229, 515, + 635, 517, 516, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 313, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 3252, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 300, 442, 461, 311, 430, 474, + 316, 438, 453, 306, 401, 427, 0, 0, 302, 459, + 437, 383, 360, 361, 301, 0, 421, 335, 351, 332, + 399, 0, 458, 486, 331, 477, 0, 469, 304, 0, + 468, 398, 455, 460, 384, 377, 0, 303, 457, 382, + 376, 364, 341, 502, 365, 366, 355, 410, 374, 411, + 356, 388, 387, 389, 0, 0, 0, 0, 0, 497, + 498, 0, 0, 646, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 628, 0, 0, 632, 0, + 471, 0, 0, 0, 0, 0, 0, 441, 0, 0, + 367, 0, 0, 0, 487, 0, 424, 404, 661, 0, + 0, 422, 372, 456, 412, 462, 443, 470, 418, 413, + 294, 444, 334, 385, 307, 309, 329, 336, 338, 342, + 343, 394, 395, 407, 429, 446, 447, 448, 333, 317, + 423, 318, 353, 319, 295, 325, 323, 326, 431, 327, + 297, 408, 452, 0, 348, 419, 380, 298, 379, 409, + 451, 450, 308, 478, 484, 485, 574, 0, 490, 662, + 663, 664, 499, 0, 414, 0, 504, 505, 506, 508, + 509, 510, 511, 575, 592, 559, 529, 492, 583, 526, + 530, 531, 358, 595, 0, 0, 0, 483, 368, 369, + 0, 340, 339, 381, 417, 299, 346, 291, 292, 657, + 330, 400, 597, 630, 631, 522, 0, 584, 523, 532, + 322, 556, 568, 567, 396, 482, 0, 579, 582, 512, + 656, 0, 576, 591, 660, 590, 653, 406, 0, 428, + 588, 535, 0, 580, 554, 0, 581, 550, 585, 0, + 524, 0, 436, 464, 476, 493, 496, 525, 610, 611, + 612, 296, 495, 614, 615, 616, 617, 618, 619, 620, + 613, 467, 557, 534, 560, 475, 537, 536, 0, 0, + 571, 491, 572, 573, 390, 391, 392, 393, 350, 598, + 315, 494, 416, 0, 558, 0, 0, 0, 0, 0, + 0, 0, 0, 563, 564, 561, 665, 0, 621, 622, + 0, 0, 488, 489, 345, 352, 507, 354, 314, 405, + 347, 473, 362, 0, 500, 565, 501, 624, 627, 625, + 626, 397, 357, 359, 432, 363, 373, 420, 472, 403, + 425, 312, 463, 434, 378, 551, 578, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 606, 605, 604, 603, 602, 601, 600, + 599, 0, 0, 548, 449, 324, 285, 320, 321, 328, + 654, 651, 454, 655, 0, 293, 528, 371, 0, 415, + 344, 593, 594, 0, 645, 241, 242, 243, 244, 245, + 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, + 255, 258, 259, 260, 261, 262, 263, 264, 265, 596, + 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, + 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, + 288, 289, 290, 0, 0, 281, 282, 283, 284, 0, + 0, 0, 479, 480, 481, 503, 0, 465, 527, 652, + 0, 0, 0, 0, 0, 0, 0, 577, 589, 623, + 0, 633, 634, 636, 638, 637, 640, 439, 440, 647, + 0, 642, 643, 644, 641, 375, 426, 445, 433, 0, + 658, 518, 519, 659, 629, 402, 0, 0, 533, 566, + 555, 639, 521, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 337, 0, 0, 370, 570, 552, 562, + 553, 538, 539, 540, 547, 349, 541, 542, 543, 513, + 544, 514, 545, 546, 0, 569, 520, 435, 386, 587, + 586, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 2069, 0, + 0, 228, 0, 0, 0, 0, 0, 0, 310, 229, + 515, 635, 517, 516, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 313, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 300, 442, 461, 311, 430, + 474, 316, 438, 453, 306, 401, 427, 0, 0, 302, + 459, 437, 383, 360, 361, 301, 0, 421, 335, 351, + 332, 399, 0, 458, 486, 331, 477, 0, 469, 304, + 0, 468, 398, 455, 460, 384, 377, 0, 303, 457, + 382, 376, 364, 341, 502, 365, 366, 355, 410, 374, + 411, 356, 388, 387, 389, 0, 0, 0, 0, 0, + 497, 498, 0, 0, 646, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 628, 0, 0, 632, + 0, 471, 0, 0, 0, 0, 0, 0, 441, 0, + 0, 367, 0, 0, 0, 487, 0, 424, 404, 661, + 0, 0, 422, 372, 456, 412, 462, 443, 470, 418, + 413, 294, 444, 334, 385, 307, 309, 329, 336, 338, + 342, 343, 394, 395, 407, 429, 446, 447, 448, 333, + 317, 423, 318, 353, 319, 295, 325, 323, 326, 431, + 327, 297, 408, 452, 0, 348, 419, 380, 298, 379, + 409, 451, 450, 308, 478, 484, 485, 574, 0, 490, + 662, 663, 664, 499, 0, 414, 0, 504, 505, 506, + 508, 509, 510, 511, 575, 592, 559, 529, 492, 583, + 526, 530, 531, 358, 595, 0, 0, 0, 483, 368, + 369, 0, 340, 339, 381, 417, 299, 346, 291, 292, + 657, 330, 400, 597, 630, 631, 522, 0, 584, 523, + 532, 322, 556, 568, 567, 396, 482, 0, 579, 582, + 512, 656, 0, 576, 591, 660, 590, 653, 406, 0, + 428, 588, 535, 0, 580, 554, 0, 581, 550, 585, + 0, 524, 0, 436, 464, 476, 493, 496, 525, 610, + 611, 612, 296, 495, 614, 615, 616, 617, 618, 619, + 620, 613, 467, 557, 534, 560, 475, 537, 536, 0, + 0, 571, 491, 572, 573, 390, 391, 392, 393, 350, + 598, 315, 494, 416, 0, 558, 0, 0, 0, 0, + 0, 0, 0, 0, 563, 564, 561, 665, 0, 621, + 622, 0, 0, 488, 489, 345, 352, 507, 354, 314, + 405, 347, 473, 362, 0, 500, 565, 501, 624, 627, + 625, 626, 397, 357, 359, 432, 363, 373, 420, 472, + 403, 425, 312, 463, 434, 378, 551, 578, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 606, 605, 604, 603, 602, 601, + 600, 599, 0, 0, 548, 449, 324, 285, 320, 321, + 328, 654, 651, 454, 655, 0, 293, 528, 371, 0, + 415, 344, 593, 594, 0, 645, 241, 242, 243, 244, + 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, + 254, 255, 258, 259, 260, 261, 262, 263, 264, 265, + 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, + 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, + 287, 288, 289, 290, 0, 0, 281, 282, 283, 284, + 0, 0, 0, 479, 480, 481, 503, 0, 465, 527, + 652, 0, 0, 0, 0, 0, 0, 0, 577, 589, + 623, 0, 633, 634, 636, 638, 637, 640, 439, 440, + 647, 0, 642, 643, 644, 641, 375, 426, 445, 433, + 0, 658, 518, 519, 659, 629, 402, 0, 0, 533, + 566, 555, 639, 521, 0, 0, 3453, 0, 0, 0, + 0, 0, 0, 0, 337, 0, 0, 370, 570, 552, + 562, 553, 538, 539, 540, 547, 349, 541, 542, 543, + 513, 544, 514, 545, 546, 0, 569, 520, 435, 386, + 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 228, 0, 0, 0, 0, 0, 0, 310, + 229, 515, 635, 517, 516, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 313, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 300, 442, 461, 311, + 430, 474, 316, 438, 453, 306, 401, 427, 0, 0, + 302, 459, 437, 383, 360, 361, 301, 0, 421, 335, + 351, 332, 399, 0, 458, 486, 331, 477, 0, 469, + 304, 0, 468, 398, 455, 460, 384, 377, 0, 303, + 457, 382, 376, 364, 341, 502, 365, 366, 355, 410, + 374, 411, 356, 388, 387, 389, 0, 0, 0, 0, + 0, 497, 498, 0, 0, 646, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 628, 0, 0, + 632, 0, 471, 0, 0, 0, 0, 0, 0, 441, + 0, 0, 367, 0, 0, 0, 487, 0, 424, 404, + 661, 0, 0, 422, 372, 456, 412, 462, 443, 470, + 418, 413, 294, 444, 334, 385, 307, 309, 329, 336, + 338, 342, 343, 394, 395, 407, 429, 446, 447, 448, + 333, 317, 423, 318, 353, 319, 295, 325, 323, 326, + 431, 327, 297, 408, 452, 0, 348, 419, 380, 298, + 379, 409, 451, 450, 308, 478, 484, 485, 574, 0, + 490, 662, 663, 664, 499, 0, 414, 0, 504, 505, + 506, 508, 509, 510, 511, 575, 592, 559, 529, 492, + 583, 526, 530, 531, 358, 595, 0, 0, 0, 483, + 368, 369, 0, 340, 339, 381, 417, 299, 346, 291, + 292, 657, 330, 400, 597, 630, 631, 522, 0, 584, + 523, 532, 322, 556, 568, 567, 396, 482, 0, 579, + 582, 512, 656, 0, 576, 591, 660, 590, 653, 406, + 0, 428, 588, 535, 0, 580, 554, 0, 581, 550, + 585, 0, 524, 0, 436, 464, 476, 493, 496, 525, + 610, 611, 612, 296, 495, 614, 615, 616, 617, 618, + 619, 620, 613, 467, 557, 534, 560, 475, 537, 536, + 0, 0, 571, 491, 572, 573, 390, 391, 392, 393, + 350, 598, 315, 494, 416, 0, 558, 0, 0, 0, + 0, 0, 0, 0, 0, 563, 564, 561, 665, 0, + 621, 622, 0, 0, 488, 489, 345, 352, 507, 354, + 314, 405, 347, 473, 362, 0, 500, 565, 501, 624, + 627, 625, 626, 397, 357, 359, 432, 363, 373, 420, + 472, 403, 425, 312, 463, 434, 378, 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 1533, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, + 280, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 606, 605, 604, 603, 602, + 601, 600, 599, 0, 0, 548, 449, 324, 285, 320, + 321, 328, 654, 651, 454, 655, 0, 293, 528, 371, + 0, 415, 344, 593, 594, 0, 645, 241, 242, 243, + 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, + 253, 254, 255, 258, 259, 260, 261, 262, 263, 264, + 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, + 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, + 0, 287, 288, 289, 290, 0, 0, 281, 282, 283, + 284, 0, 0, 0, 479, 480, 481, 503, 0, 465, + 527, 652, 0, 0, 0, 0, 0, 0, 0, 577, + 589, 623, 0, 633, 634, 636, 638, 637, 640, 439, + 440, 647, 0, 642, 643, 644, 641, 375, 426, 445, + 433, 0, 658, 518, 519, 659, 629, 402, 0, 0, + 533, 566, 555, 639, 521, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 337, 0, 0, 370, 570, + 552, 562, 553, 538, 539, 540, 547, 349, 541, 542, + 543, 513, 544, 514, 545, 546, 0, 569, 520, 435, + 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 228, 0, 0, 0, 0, 0, 0, + 310, 229, 515, 635, 517, 516, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 313, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 3361, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 300, 442, 461, + 311, 430, 474, 316, 438, 453, 306, 401, 427, 0, + 0, 302, 459, 437, 383, 360, 361, 301, 0, 421, + 335, 351, 332, 399, 0, 458, 486, 331, 477, 0, + 469, 304, 0, 468, 398, 455, 460, 384, 377, 0, + 303, 457, 382, 376, 364, 341, 502, 365, 366, 355, + 410, 374, 411, 356, 388, 387, 389, 0, 0, 0, + 0, 0, 497, 498, 0, 0, 646, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 628, 0, + 0, 632, 0, 471, 0, 0, 0, 0, 0, 0, + 441, 0, 0, 367, 0, 0, 0, 487, 0, 424, + 404, 661, 0, 0, 422, 372, 456, 412, 462, 443, + 470, 418, 413, 294, 444, 334, 385, 307, 309, 329, + 336, 338, 342, 343, 394, 395, 407, 429, 446, 447, + 448, 333, 317, 423, 318, 353, 319, 295, 325, 323, + 326, 431, 327, 297, 408, 452, 0, 348, 419, 380, + 298, 379, 409, 451, 450, 308, 478, 484, 485, 574, + 0, 490, 662, 663, 664, 499, 0, 414, 0, 504, + 505, 506, 508, 509, 510, 511, 575, 592, 559, 529, + 492, 583, 526, 530, 531, 358, 595, 0, 0, 0, + 483, 368, 369, 0, 340, 339, 381, 417, 299, 346, + 291, 292, 657, 330, 400, 597, 630, 631, 522, 0, + 584, 523, 532, 322, 556, 568, 567, 396, 482, 0, + 579, 582, 512, 656, 0, 576, 591, 660, 590, 653, + 406, 0, 428, 588, 535, 0, 580, 554, 0, 581, + 550, 585, 0, 524, 0, 436, 464, 476, 493, 496, + 525, 610, 611, 612, 296, 495, 614, 615, 616, 617, + 618, 619, 620, 613, 467, 557, 534, 560, 475, 537, + 536, 0, 0, 571, 491, 572, 573, 390, 391, 392, + 393, 350, 598, 315, 494, 416, 0, 558, 0, 0, + 0, 0, 0, 0, 0, 0, 563, 564, 561, 665, + 0, 621, 622, 0, 0, 488, 489, 345, 352, 507, + 354, 314, 405, 347, 473, 362, 0, 500, 565, 501, + 624, 627, 625, 626, 397, 357, 359, 432, 363, 373, + 420, 472, 403, 425, 312, 463, 434, 378, 551, 578, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 606, 605, 604, 603, + 602, 601, 600, 599, 0, 0, 548, 449, 324, 285, + 320, 321, 328, 654, 651, 454, 655, 0, 293, 528, + 371, 0, 415, 344, 593, 594, 0, 645, 241, 242, + 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, + 252, 253, 254, 255, 258, 259, 260, 261, 262, 263, + 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, + 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, + 0, 0, 287, 288, 289, 290, 0, 0, 281, 282, + 283, 284, 0, 0, 0, 479, 480, 481, 503, 0, + 465, 527, 652, 0, 0, 0, 0, 0, 0, 0, + 577, 589, 623, 0, 633, 634, 636, 638, 637, 640, + 439, 440, 647, 0, 642, 643, 644, 641, 375, 426, + 445, 433, 0, 658, 518, 519, 659, 629, 402, 0, + 0, 533, 566, 555, 639, 521, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 337, 0, 0, 370, + 570, 552, 562, 553, 538, 539, 540, 547, 349, 541, + 542, 543, 513, 544, 514, 545, 546, 0, 569, 520, + 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 228, 0, 0, 0, 0, 0, + 0, 310, 229, 515, 635, 517, 516, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 313, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 3089, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 300, 442, + 461, 311, 430, 474, 316, 438, 453, 306, 401, 427, + 0, 0, 302, 459, 437, 383, 360, 361, 301, 0, + 421, 335, 351, 332, 399, 0, 458, 486, 331, 477, + 0, 469, 304, 0, 468, 398, 455, 460, 384, 377, + 0, 303, 457, 382, 376, 364, 341, 502, 365, 366, + 355, 410, 374, 411, 356, 388, 387, 389, 0, 0, + 0, 0, 0, 497, 498, 0, 0, 646, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 628, + 0, 0, 632, 0, 471, 0, 0, 0, 0, 0, + 0, 441, 0, 0, 367, 0, 0, 0, 487, 0, + 424, 404, 661, 0, 0, 422, 372, 456, 412, 462, + 443, 470, 418, 413, 294, 444, 334, 385, 307, 309, + 329, 336, 338, 342, 343, 394, 395, 407, 429, 446, + 447, 448, 333, 317, 423, 318, 353, 319, 295, 325, + 323, 326, 431, 327, 297, 408, 452, 0, 348, 419, + 380, 298, 379, 409, 451, 450, 308, 478, 484, 485, + 574, 0, 490, 662, 663, 664, 499, 0, 414, 0, + 504, 505, 506, 508, 509, 510, 511, 575, 592, 559, + 529, 492, 583, 526, 530, 531, 358, 595, 0, 0, + 0, 483, 368, 369, 0, 340, 339, 381, 417, 299, + 346, 291, 292, 657, 330, 400, 597, 630, 631, 522, + 0, 584, 523, 532, 322, 556, 568, 567, 396, 482, + 0, 579, 582, 512, 656, 0, 576, 591, 660, 590, + 653, 406, 0, 428, 588, 535, 0, 580, 554, 0, + 581, 550, 585, 0, 524, 0, 436, 464, 476, 493, + 496, 525, 610, 611, 612, 296, 495, 614, 615, 616, + 617, 618, 619, 620, 613, 467, 557, 534, 560, 475, + 537, 536, 0, 0, 571, 491, 572, 573, 390, 391, + 392, 393, 350, 598, 315, 494, 416, 0, 558, 0, + 0, 0, 0, 0, 0, 0, 0, 563, 564, 561, + 665, 0, 621, 622, 0, 0, 488, 489, 345, 352, + 507, 354, 314, 405, 347, 473, 362, 0, 500, 565, + 501, 624, 627, 625, 626, 397, 357, 359, 432, 363, + 373, 420, 472, 403, 425, 312, 463, 434, 378, 551, + 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 606, 605, 604, + 603, 602, 601, 600, 599, 0, 0, 548, 449, 324, + 285, 320, 321, 328, 654, 651, 454, 655, 0, 293, + 528, 371, 0, 415, 344, 593, 594, 0, 645, 241, + 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, + 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, + 263, 264, 265, 596, 256, 257, 266, 267, 268, 269, + 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, + 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, + 282, 283, 284, 0, 0, 0, 479, 480, 481, 503, + 0, 465, 527, 652, 0, 0, 0, 0, 0, 0, + 0, 577, 589, 623, 0, 633, 634, 636, 638, 637, + 640, 439, 440, 647, 0, 642, 643, 644, 641, 375, + 426, 445, 433, 0, 658, 518, 519, 659, 629, 402, + 0, 0, 533, 566, 555, 639, 521, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 337, 0, 0, + 370, 570, 552, 562, 553, 538, 539, 540, 547, 349, + 541, 542, 543, 513, 544, 514, 545, 546, 0, 569, + 520, 435, 386, 587, 586, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 228, 0, 0, 1555, 0, + 0, 0, 310, 229, 515, 635, 517, 516, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 313, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 300, + 442, 461, 311, 430, 474, 316, 438, 453, 306, 401, + 427, 0, 0, 302, 459, 437, 383, 360, 361, 301, + 0, 421, 335, 351, 332, 399, 0, 458, 486, 331, + 477, 0, 469, 304, 0, 468, 398, 455, 460, 384, + 377, 0, 303, 457, 382, 376, 364, 341, 502, 365, + 366, 355, 410, 374, 411, 356, 388, 387, 389, 0, + 0, 0, 0, 0, 497, 498, 0, 0, 646, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 628, 0, 0, 632, 0, 471, 0, 0, 0, 0, + 0, 0, 441, 0, 0, 367, 0, 0, 0, 487, + 0, 424, 404, 661, 0, 0, 422, 372, 456, 412, + 462, 443, 470, 418, 413, 294, 444, 334, 385, 307, + 309, 329, 336, 338, 342, 343, 394, 395, 407, 429, + 446, 447, 448, 333, 317, 423, 318, 353, 319, 295, + 325, 323, 326, 431, 327, 297, 408, 452, 0, 348, + 419, 380, 298, 379, 409, 451, 450, 308, 478, 484, + 485, 574, 0, 490, 662, 663, 664, 499, 0, 414, + 0, 504, 505, 506, 508, 509, 510, 511, 575, 592, + 559, 529, 492, 583, 526, 530, 531, 358, 595, 0, + 0, 0, 483, 368, 369, 0, 340, 339, 381, 417, + 299, 346, 291, 292, 657, 330, 400, 597, 630, 631, + 522, 0, 584, 523, 532, 322, 556, 568, 567, 396, + 482, 0, 579, 582, 512, 656, 0, 576, 591, 660, + 590, 653, 406, 0, 428, 588, 535, 0, 580, 554, + 0, 581, 550, 585, 0, 524, 0, 436, 464, 476, + 493, 496, 525, 610, 611, 612, 296, 495, 614, 615, + 616, 617, 618, 619, 620, 613, 467, 557, 534, 560, + 475, 537, 536, 0, 0, 571, 491, 572, 573, 390, + 391, 392, 393, 350, 598, 315, 494, 416, 0, 558, + 0, 0, 0, 0, 0, 0, 0, 0, 563, 564, + 561, 665, 0, 621, 622, 0, 0, 488, 489, 345, + 352, 507, 354, 314, 405, 347, 473, 362, 0, 500, + 565, 501, 624, 627, 625, 626, 397, 357, 359, 432, + 363, 373, 420, 472, 403, 425, 312, 463, 434, 378, + 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 606, 605, + 604, 603, 602, 601, 600, 599, 0, 0, 548, 449, + 324, 285, 320, 321, 328, 654, 651, 454, 655, 0, + 293, 528, 371, 0, 415, 344, 593, 594, 0, 645, + 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, + 250, 251, 252, 253, 254, 255, 258, 259, 260, 261, + 262, 263, 264, 265, 596, 256, 257, 266, 267, 268, + 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, + 279, 0, 0, 0, 287, 288, 289, 290, 0, 0, + 281, 282, 283, 284, 0, 0, 0, 479, 480, 481, + 503, 0, 465, 527, 652, 0, 0, 0, 0, 0, + 0, 0, 577, 589, 623, 0, 633, 634, 636, 638, + 637, 640, 439, 440, 647, 0, 642, 643, 644, 641, + 375, 426, 445, 433, 0, 658, 518, 519, 659, 629, + 402, 0, 0, 533, 566, 555, 639, 521, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 337, 0, + 0, 370, 570, 552, 562, 553, 538, 539, 540, 547, + 349, 541, 542, 543, 513, 544, 514, 545, 546, 0, + 569, 520, 435, 386, 587, 586, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 228, 0, 0, 2524, + 0, 0, 0, 310, 229, 515, 635, 517, 516, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 313, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 300, 442, 461, 311, 430, 474, 316, 438, 453, 306, + 401, 427, 0, 0, 302, 459, 437, 383, 360, 361, + 301, 0, 421, 335, 351, 332, 399, 0, 458, 486, + 331, 477, 0, 469, 304, 0, 468, 398, 455, 460, + 384, 377, 0, 303, 457, 382, 376, 364, 341, 502, + 365, 366, 355, 410, 374, 411, 356, 388, 387, 389, + 0, 0, 0, 0, 0, 497, 498, 0, 0, 646, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 628, 0, 0, 632, 0, 471, 0, 0, 0, + 0, 0, 0, 441, 0, 0, 367, 0, 0, 0, + 487, 0, 424, 404, 661, 0, 0, 422, 372, 456, + 412, 462, 443, 470, 418, 413, 294, 444, 334, 385, + 307, 309, 329, 336, 338, 342, 343, 394, 395, 407, + 429, 446, 447, 448, 333, 317, 423, 318, 353, 319, + 295, 325, 323, 326, 431, 327, 297, 408, 452, 0, + 348, 419, 380, 298, 379, 409, 451, 450, 308, 478, + 484, 485, 574, 0, 490, 662, 663, 664, 499, 0, + 414, 0, 504, 505, 506, 508, 509, 510, 511, 575, + 592, 559, 529, 492, 583, 526, 530, 531, 358, 595, + 0, 0, 0, 483, 368, 369, 0, 340, 339, 381, + 417, 299, 346, 291, 292, 657, 330, 400, 597, 630, + 631, 522, 0, 584, 523, 532, 322, 556, 568, 567, + 396, 482, 0, 579, 582, 512, 656, 0, 576, 591, + 660, 590, 653, 406, 0, 428, 588, 535, 0, 580, + 554, 0, 581, 550, 585, 0, 524, 0, 436, 464, + 476, 493, 496, 525, 610, 611, 612, 296, 495, 614, + 615, 616, 617, 618, 619, 620, 613, 467, 557, 534, + 560, 475, 537, 536, 0, 0, 571, 491, 572, 573, + 390, 391, 392, 393, 350, 598, 315, 494, 416, 0, + 558, 0, 0, 0, 0, 0, 0, 0, 0, 563, + 564, 561, 665, 0, 621, 622, 0, 0, 488, 489, + 345, 352, 507, 354, 314, 405, 347, 473, 362, 0, + 500, 565, 501, 624, 627, 625, 626, 397, 357, 359, + 432, 363, 373, 420, 472, 403, 425, 312, 463, 434, + 378, 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 606, + 605, 604, 603, 602, 601, 600, 599, 0, 0, 548, + 449, 324, 285, 320, 321, 328, 654, 651, 454, 655, + 0, 293, 528, 371, 0, 415, 344, 593, 594, 0, + 645, 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, + 261, 262, 263, 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, + 0, 281, 282, 283, 284, 0, 0, 0, 479, 480, + 481, 503, 0, 465, 527, 652, 0, 0, 0, 0, + 0, 0, 0, 577, 589, 623, 0, 633, 634, 636, + 638, 637, 640, 439, 440, 647, 0, 642, 643, 644, + 641, 375, 426, 445, 433, 0, 658, 518, 519, 659, + 629, 402, 0, 0, 533, 566, 555, 639, 521, 0, + 0, 2899, 0, 0, 0, 0, 0, 0, 0, 337, + 0, 0, 370, 570, 552, 562, 553, 538, 539, 540, + 547, 349, 541, 542, 543, 513, 544, 514, 545, 546, + 0, 569, 520, 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 1531, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, + 0, 0, 0, 0, 310, 229, 515, 635, 517, 516, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 313, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 300, 442, 461, 311, 430, 474, 316, 438, 453, + 306, 401, 427, 0, 0, 302, 459, 437, 383, 360, + 361, 301, 0, 421, 335, 351, 332, 399, 0, 458, + 486, 331, 477, 0, 469, 304, 0, 468, 398, 455, + 460, 384, 377, 0, 303, 457, 382, 376, 364, 341, + 502, 365, 366, 355, 410, 374, 411, 356, 388, 387, + 389, 0, 0, 0, 0, 0, 497, 498, 0, 0, + 646, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 628, 0, 0, 632, 0, 471, 0, 0, + 0, 0, 0, 0, 441, 0, 0, 367, 0, 0, + 0, 487, 0, 424, 404, 661, 0, 0, 422, 372, + 456, 412, 462, 443, 470, 418, 413, 294, 444, 334, + 385, 307, 309, 329, 336, 338, 342, 343, 394, 395, + 407, 429, 446, 447, 448, 333, 317, 423, 318, 353, + 319, 295, 325, 323, 326, 431, 327, 297, 408, 452, + 0, 348, 419, 380, 298, 379, 409, 451, 450, 308, + 478, 484, 485, 574, 0, 490, 662, 663, 664, 499, + 0, 414, 0, 504, 505, 506, 508, 509, 510, 511, + 575, 592, 559, 529, 492, 583, 526, 530, 531, 358, + 595, 0, 0, 0, 483, 368, 369, 0, 340, 339, + 381, 417, 299, 346, 291, 292, 657, 330, 400, 597, + 630, 631, 522, 0, 584, 523, 532, 322, 556, 568, + 567, 396, 482, 0, 579, 582, 512, 656, 0, 576, + 591, 660, 590, 653, 406, 0, 428, 588, 535, 0, + 580, 554, 0, 581, 550, 585, 0, 524, 0, 436, + 464, 476, 493, 496, 525, 610, 611, 612, 296, 495, + 614, 615, 616, 617, 618, 619, 620, 613, 467, 557, + 534, 560, 475, 537, 536, 0, 0, 571, 491, 572, + 573, 390, 391, 392, 393, 350, 598, 315, 494, 416, + 0, 558, 0, 0, 0, 0, 0, 0, 0, 0, + 563, 564, 561, 665, 0, 621, 622, 0, 0, 488, + 489, 345, 352, 507, 354, 314, 405, 347, 473, 362, + 0, 500, 565, 501, 624, 627, 625, 626, 397, 357, + 359, 432, 363, 373, 420, 472, 403, 425, 312, 463, + 434, 378, 551, 578, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 606, 605, 604, 603, 602, 601, 600, 599, 0, 0, + 548, 449, 324, 285, 320, 321, 328, 654, 651, 454, + 655, 0, 293, 528, 371, 0, 415, 344, 593, 594, + 0, 645, 241, 242, 243, 244, 245, 246, 247, 248, + 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, + 260, 261, 262, 263, 264, 265, 596, 256, 257, 266, + 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, + 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, + 0, 0, 281, 282, 283, 284, 0, 0, 0, 479, + 480, 481, 503, 0, 465, 527, 652, 0, 0, 0, + 0, 0, 0, 0, 577, 589, 623, 0, 633, 634, + 636, 638, 637, 640, 439, 440, 647, 0, 642, 643, + 644, 641, 375, 426, 445, 433, 0, 658, 518, 519, + 659, 629, 402, 0, 0, 533, 566, 555, 639, 521, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 337, 0, 0, 370, 570, 552, 562, 553, 538, 539, + 540, 547, 349, 541, 542, 543, 513, 544, 514, 545, + 546, 0, 569, 520, 435, 386, 587, 586, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 228, 0, + 0, 0, 0, 0, 0, 310, 229, 515, 635, 517, + 516, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 313, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 2207, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 300, 442, 461, 311, 430, 474, 316, 438, + 453, 306, 401, 427, 0, 0, 302, 459, 437, 383, + 360, 361, 301, 0, 421, 335, 351, 332, 399, 0, + 458, 486, 331, 477, 0, 469, 304, 0, 468, 398, + 455, 460, 384, 377, 0, 303, 457, 382, 376, 364, + 341, 502, 365, 366, 355, 410, 374, 411, 356, 388, + 387, 389, 0, 0, 0, 0, 0, 497, 498, 0, + 0, 646, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 628, 0, 0, 632, 0, 471, 0, + 0, 0, 0, 0, 0, 441, 0, 0, 367, 0, + 0, 0, 487, 0, 424, 404, 661, 0, 0, 422, + 372, 456, 412, 462, 443, 470, 418, 413, 294, 444, + 334, 385, 307, 309, 329, 336, 338, 342, 343, 394, + 395, 407, 429, 446, 447, 448, 333, 317, 423, 318, + 353, 319, 295, 325, 323, 326, 431, 327, 297, 408, + 452, 0, 348, 419, 380, 298, 379, 409, 451, 450, + 308, 478, 484, 485, 574, 0, 490, 662, 663, 664, + 499, 0, 414, 0, 504, 505, 506, 508, 509, 510, + 511, 575, 592, 559, 529, 492, 583, 526, 530, 531, + 358, 595, 0, 0, 0, 483, 368, 369, 0, 340, + 339, 381, 417, 299, 346, 291, 292, 657, 330, 400, + 597, 630, 631, 522, 0, 584, 523, 532, 322, 556, + 568, 567, 396, 482, 0, 579, 582, 512, 656, 0, + 576, 591, 660, 590, 653, 406, 0, 428, 588, 535, + 0, 580, 554, 0, 581, 550, 585, 0, 524, 0, + 436, 464, 476, 493, 496, 525, 610, 611, 612, 296, + 495, 614, 615, 616, 617, 618, 619, 620, 613, 467, + 557, 534, 560, 475, 537, 536, 0, 0, 571, 491, + 572, 573, 390, 391, 392, 393, 350, 598, 315, 494, + 416, 0, 558, 0, 0, 0, 0, 0, 0, 0, + 0, 563, 564, 561, 665, 0, 621, 622, 0, 0, + 488, 489, 345, 352, 507, 354, 314, 405, 347, 473, + 362, 0, 500, 565, 501, 624, 627, 625, 626, 397, + 357, 359, 432, 363, 373, 420, 472, 403, 425, 312, + 463, 434, 378, 551, 578, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 1410, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, + 0, 606, 605, 604, 603, 602, 601, 600, 599, 0, + 0, 548, 449, 324, 285, 320, 321, 328, 654, 651, + 454, 655, 0, 293, 528, 371, 0, 415, 344, 593, + 594, 0, 645, 241, 242, 243, 244, 245, 246, 247, + 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, + 259, 260, 261, 262, 263, 264, 265, 596, 256, 257, + 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, + 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, + 290, 0, 0, 281, 282, 283, 284, 0, 0, 0, + 479, 480, 481, 503, 0, 465, 527, 652, 0, 0, + 0, 0, 0, 0, 0, 577, 589, 623, 0, 633, + 634, 636, 638, 637, 640, 439, 440, 647, 0, 642, + 643, 644, 641, 375, 426, 445, 433, 0, 658, 518, + 519, 659, 629, 402, 0, 0, 533, 566, 555, 639, + 521, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 337, 0, 0, 370, 570, 552, 562, 553, 538, + 539, 540, 547, 349, 541, 542, 543, 513, 544, 514, + 545, 546, 0, 569, 520, 435, 386, 587, 586, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 228, + 0, 0, 2643, 0, 0, 0, 310, 229, 515, 635, + 517, 516, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 313, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 300, 442, 461, 311, 430, 474, 316, + 438, 453, 306, 401, 427, 0, 0, 302, 459, 437, + 383, 360, 361, 301, 0, 421, 335, 351, 332, 399, + 0, 458, 486, 331, 477, 0, 469, 304, 0, 468, + 398, 455, 460, 384, 377, 0, 303, 457, 382, 376, + 364, 341, 502, 365, 366, 355, 410, 374, 411, 356, + 388, 387, 389, 0, 0, 0, 0, 0, 497, 498, + 0, 0, 646, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 628, 0, 0, 632, 0, 471, + 0, 0, 0, 0, 0, 0, 441, 0, 0, 367, + 0, 0, 0, 487, 0, 424, 404, 661, 0, 0, + 422, 372, 456, 412, 462, 443, 470, 418, 413, 294, + 444, 334, 385, 307, 309, 329, 336, 338, 342, 343, + 394, 395, 407, 429, 446, 447, 448, 333, 317, 423, + 318, 353, 319, 295, 325, 323, 326, 431, 327, 297, + 408, 452, 0, 348, 419, 380, 298, 379, 409, 451, + 450, 308, 478, 484, 485, 574, 0, 490, 662, 663, + 664, 499, 0, 414, 0, 504, 505, 506, 508, 509, + 510, 511, 575, 592, 559, 529, 492, 583, 526, 530, + 531, 358, 595, 0, 0, 0, 483, 368, 369, 0, + 340, 339, 381, 417, 299, 346, 291, 292, 657, 330, + 400, 597, 630, 631, 522, 0, 584, 523, 532, 322, + 556, 568, 567, 396, 482, 0, 579, 582, 512, 656, + 0, 576, 591, 660, 590, 653, 406, 0, 428, 588, + 535, 0, 580, 554, 0, 581, 550, 585, 0, 524, + 0, 436, 464, 476, 493, 496, 525, 610, 611, 612, + 296, 495, 614, 615, 616, 617, 618, 619, 620, 613, + 467, 557, 534, 560, 475, 537, 536, 0, 0, 571, + 491, 572, 573, 390, 391, 392, 393, 350, 598, 315, + 494, 416, 0, 558, 0, 0, 0, 0, 0, 0, + 0, 0, 563, 564, 561, 665, 0, 621, 622, 0, + 0, 488, 489, 345, 352, 507, 354, 314, 405, 347, + 473, 362, 0, 500, 565, 501, 624, 627, 625, 626, + 397, 357, 359, 432, 363, 373, 420, 472, 403, 425, + 312, 463, 434, 378, 551, 578, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 606, 605, 604, 603, 602, 601, 600, 599, + 0, 0, 548, 449, 324, 285, 320, 321, 328, 654, + 651, 454, 655, 0, 293, 528, 371, 0, 415, 344, + 593, 594, 0, 645, 241, 242, 243, 244, 245, 246, + 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, + 258, 259, 260, 261, 262, 263, 264, 265, 596, 256, + 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, + 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, + 289, 290, 0, 0, 281, 282, 283, 284, 0, 0, + 0, 479, 480, 481, 503, 0, 465, 527, 652, 0, + 0, 0, 0, 0, 0, 0, 577, 589, 623, 0, + 633, 634, 636, 638, 637, 640, 439, 440, 647, 0, + 642, 643, 644, 641, 375, 426, 445, 433, 0, 658, + 518, 519, 659, 629, 402, 0, 0, 533, 566, 555, + 639, 521, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 337, 0, 0, 370, 570, 552, 562, 553, + 538, 539, 540, 547, 349, 541, 542, 543, 513, 544, + 514, 545, 546, 0, 569, 520, 435, 386, 587, 586, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 228, 0, 0, 0, 0, 0, 0, 310, 229, 515, + 635, 517, 516, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 313, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 2605, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 300, 442, 461, 311, 430, 474, + 316, 438, 453, 306, 401, 427, 0, 0, 302, 459, + 437, 383, 360, 361, 301, 0, 421, 335, 351, 332, + 399, 0, 458, 486, 331, 477, 0, 469, 304, 0, + 468, 398, 455, 460, 384, 377, 0, 303, 457, 382, + 376, 364, 341, 502, 365, 366, 355, 410, 374, 411, + 356, 388, 387, 389, 0, 0, 0, 0, 0, 497, + 498, 0, 0, 646, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 628, 0, 0, 632, 0, + 471, 0, 0, 0, 0, 0, 0, 441, 0, 0, + 367, 0, 0, 0, 487, 0, 424, 404, 661, 0, + 0, 422, 372, 456, 412, 462, 443, 470, 418, 413, + 294, 444, 334, 385, 307, 309, 329, 336, 338, 342, + 343, 394, 395, 407, 429, 446, 447, 448, 333, 317, + 423, 318, 353, 319, 295, 325, 323, 326, 431, 327, + 297, 408, 452, 0, 348, 419, 380, 298, 379, 409, + 451, 450, 308, 478, 484, 485, 574, 0, 490, 662, + 663, 664, 499, 0, 414, 0, 504, 505, 506, 508, + 509, 510, 511, 575, 592, 559, 529, 492, 583, 526, + 530, 531, 358, 595, 0, 0, 0, 483, 368, 369, + 0, 340, 339, 381, 417, 299, 346, 291, 292, 657, + 330, 400, 597, 630, 631, 522, 0, 584, 523, 532, + 322, 556, 568, 567, 396, 482, 0, 579, 582, 512, + 656, 0, 576, 591, 660, 590, 653, 406, 0, 428, + 588, 535, 0, 580, 554, 0, 581, 550, 585, 0, + 524, 0, 436, 464, 476, 493, 496, 525, 610, 611, + 612, 296, 495, 614, 615, 616, 617, 618, 619, 620, + 613, 467, 557, 534, 560, 475, 537, 536, 0, 0, + 571, 491, 572, 573, 390, 391, 392, 393, 350, 598, + 315, 494, 416, 0, 558, 0, 0, 0, 0, 0, + 0, 0, 0, 563, 564, 561, 665, 0, 621, 622, + 0, 0, 488, 489, 345, 352, 507, 354, 314, 405, + 347, 473, 362, 0, 500, 565, 501, 624, 627, 625, + 626, 397, 357, 359, 432, 363, 373, 420, 472, 403, + 425, 312, 463, 434, 378, 551, 578, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 606, 605, 604, 603, 602, 601, 600, + 599, 0, 0, 548, 449, 324, 285, 320, 321, 328, + 654, 651, 454, 655, 0, 293, 528, 371, 0, 415, + 344, 593, 594, 0, 645, 241, 242, 243, 244, 245, + 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, + 255, 258, 259, 260, 261, 262, 263, 264, 265, 596, + 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, + 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, + 288, 289, 290, 0, 0, 281, 282, 283, 284, 0, + 0, 0, 479, 480, 481, 503, 0, 465, 527, 652, + 0, 0, 0, 0, 0, 0, 0, 577, 589, 623, + 0, 633, 634, 636, 638, 637, 640, 439, 440, 647, + 0, 642, 643, 644, 641, 375, 426, 445, 433, 0, + 658, 518, 519, 659, 629, 402, 0, 0, 533, 566, + 555, 639, 521, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 337, 0, 0, 370, 570, 552, 562, + 553, 538, 539, 540, 547, 349, 541, 542, 543, 513, + 544, 514, 545, 546, 0, 569, 520, 435, 386, 587, + 586, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 228, 0, 0, 2603, 0, 0, 0, 310, 229, + 515, 635, 517, 516, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 313, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 300, 442, 461, 311, 430, + 474, 316, 438, 453, 306, 401, 427, 0, 0, 302, + 459, 437, 383, 360, 361, 301, 0, 421, 335, 351, + 332, 399, 0, 458, 486, 331, 477, 0, 469, 304, + 0, 468, 398, 455, 460, 384, 377, 0, 303, 457, + 382, 376, 364, 341, 502, 365, 366, 355, 410, 374, + 411, 356, 388, 387, 389, 0, 0, 0, 0, 0, + 497, 498, 0, 0, 646, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 628, 0, 0, 632, + 0, 471, 0, 0, 0, 0, 0, 0, 441, 0, + 0, 367, 0, 0, 0, 487, 0, 424, 404, 661, + 0, 0, 422, 372, 456, 412, 462, 443, 470, 418, + 413, 294, 444, 334, 385, 307, 309, 329, 336, 338, + 342, 343, 394, 395, 407, 429, 446, 447, 448, 333, + 317, 423, 318, 353, 319, 295, 325, 323, 326, 431, + 327, 297, 408, 452, 0, 348, 419, 380, 298, 379, + 409, 451, 450, 308, 478, 484, 485, 574, 0, 490, + 662, 663, 664, 499, 0, 414, 0, 504, 505, 506, + 508, 509, 510, 511, 575, 592, 559, 529, 492, 583, + 526, 530, 531, 358, 595, 0, 0, 0, 483, 368, + 369, 0, 340, 339, 381, 417, 299, 346, 291, 292, + 657, 330, 400, 597, 630, 631, 522, 0, 584, 523, + 532, 322, 556, 568, 567, 396, 482, 0, 579, 582, + 512, 656, 0, 576, 591, 660, 590, 653, 406, 0, + 428, 588, 535, 0, 580, 554, 0, 581, 550, 585, + 0, 524, 0, 436, 464, 476, 493, 496, 525, 610, + 611, 612, 296, 495, 614, 615, 616, 617, 618, 619, + 620, 613, 467, 557, 534, 560, 475, 537, 536, 0, + 0, 571, 491, 572, 573, 390, 391, 392, 393, 350, + 598, 315, 494, 416, 0, 558, 0, 0, 0, 0, + 0, 0, 0, 0, 563, 564, 561, 665, 0, 621, + 622, 0, 0, 488, 489, 345, 352, 507, 354, 314, + 405, 347, 473, 362, 0, 500, 565, 501, 624, 627, + 625, 626, 397, 357, 359, 432, 363, 373, 420, 472, + 403, 425, 312, 463, 434, 378, 551, 578, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 606, 605, 604, 603, 602, 601, + 600, 599, 0, 0, 548, 449, 324, 285, 320, 321, + 328, 654, 651, 454, 655, 0, 293, 528, 371, 0, + 415, 344, 593, 594, 0, 645, 241, 242, 243, 244, + 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, + 254, 255, 258, 259, 260, 261, 262, 263, 264, 265, + 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, + 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, + 287, 288, 289, 290, 0, 0, 281, 282, 283, 284, + 0, 0, 0, 479, 480, 481, 503, 0, 465, 527, + 652, 0, 0, 0, 0, 0, 0, 0, 577, 589, + 623, 0, 633, 634, 636, 638, 637, 640, 439, 440, + 647, 0, 642, 643, 644, 641, 375, 426, 445, 433, + 2371, 658, 518, 519, 659, 629, 402, 0, 0, 533, + 566, 555, 639, 521, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 337, 0, 0, 370, 570, 552, + 562, 553, 538, 539, 540, 547, 349, 541, 542, 543, + 513, 544, 514, 545, 546, 0, 569, 520, 435, 386, + 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 228, 0, 0, 0, 0, 0, 0, 310, + 229, 515, 635, 517, 516, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 313, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 300, 442, 461, 311, + 430, 474, 316, 438, 453, 306, 401, 427, 0, 0, + 302, 459, 437, 383, 360, 361, 301, 0, 421, 335, + 351, 332, 399, 0, 458, 486, 331, 477, 0, 469, + 304, 0, 468, 398, 455, 460, 384, 377, 0, 303, + 457, 382, 376, 364, 341, 502, 365, 366, 355, 410, + 374, 411, 356, 388, 387, 389, 0, 0, 0, 0, + 0, 497, 498, 0, 0, 646, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 628, 0, 0, + 632, 0, 471, 0, 0, 0, 0, 0, 0, 441, + 0, 0, 367, 0, 0, 0, 487, 0, 424, 404, + 661, 0, 0, 422, 372, 456, 412, 462, 443, 470, + 418, 413, 294, 444, 334, 385, 307, 309, 329, 336, + 338, 342, 343, 394, 395, 407, 429, 446, 447, 448, + 333, 317, 423, 318, 353, 319, 295, 325, 323, 326, + 431, 327, 297, 408, 452, 0, 348, 419, 380, 298, + 379, 409, 451, 450, 308, 478, 484, 485, 574, 0, + 490, 662, 663, 664, 499, 0, 414, 0, 504, 505, + 506, 508, 509, 510, 511, 575, 592, 559, 529, 492, + 583, 526, 530, 531, 358, 595, 0, 0, 0, 483, + 368, 369, 0, 340, 339, 381, 417, 299, 346, 291, + 292, 657, 330, 400, 597, 630, 631, 522, 0, 584, + 523, 532, 322, 556, 568, 567, 396, 482, 0, 579, + 582, 512, 656, 0, 576, 591, 660, 590, 653, 406, + 0, 428, 588, 535, 0, 580, 554, 0, 581, 550, + 585, 0, 524, 0, 436, 464, 476, 493, 496, 525, + 610, 611, 612, 296, 495, 614, 615, 616, 617, 618, + 619, 620, 613, 467, 557, 534, 560, 475, 537, 536, + 0, 0, 571, 491, 572, 573, 390, 391, 392, 393, + 350, 598, 315, 494, 416, 0, 558, 0, 0, 0, + 0, 0, 0, 0, 0, 563, 564, 561, 665, 0, + 621, 622, 0, 0, 488, 489, 345, 352, 507, 354, + 314, 405, 347, 473, 362, 0, 500, 565, 501, 624, + 627, 625, 626, 397, 357, 359, 432, 363, 373, 420, + 472, 403, 425, 312, 463, 434, 378, 551, 578, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 280, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 606, 605, 604, 603, 602, + 601, 600, 599, 0, 0, 548, 449, 324, 285, 320, + 321, 328, 654, 651, 454, 655, 0, 293, 528, 371, + 0, 415, 344, 593, 594, 0, 645, 241, 242, 243, + 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, + 253, 254, 255, 258, 259, 260, 261, 262, 263, 264, + 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, + 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, + 0, 287, 288, 289, 290, 0, 0, 281, 282, 283, + 284, 0, 0, 0, 479, 480, 481, 503, 0, 465, + 527, 652, 0, 0, 0, 0, 0, 0, 0, 577, + 589, 623, 0, 633, 634, 636, 638, 637, 640, 439, + 440, 647, 0, 642, 643, 644, 641, 375, 426, 445, + 433, 0, 658, 518, 519, 659, 629, 402, 0, 0, + 533, 566, 555, 639, 521, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 337, 0, 0, 370, 570, + 552, 562, 553, 538, 539, 540, 547, 349, 541, 542, + 543, 513, 544, 514, 545, 546, 0, 569, 520, 435, + 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 228, 0, 0, 0, 1920, 0, 0, + 310, 229, 515, 635, 517, 516, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 313, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 300, 442, 461, + 311, 430, 474, 316, 438, 453, 306, 401, 427, 0, + 0, 302, 459, 437, 383, 360, 361, 301, 0, 421, + 335, 351, 332, 399, 0, 458, 486, 331, 477, 0, + 469, 304, 0, 468, 398, 455, 460, 384, 377, 0, + 303, 457, 382, 376, 364, 341, 502, 365, 366, 355, + 410, 374, 411, 356, 388, 387, 389, 0, 0, 0, + 0, 0, 497, 498, 0, 0, 646, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 628, 0, + 0, 632, 0, 471, 0, 0, 0, 0, 0, 0, + 441, 0, 0, 367, 0, 0, 0, 487, 0, 424, + 404, 661, 0, 0, 422, 372, 456, 412, 462, 443, + 470, 418, 413, 294, 444, 334, 385, 307, 309, 329, + 336, 338, 342, 343, 394, 395, 407, 429, 446, 447, + 448, 333, 317, 423, 318, 353, 319, 295, 325, 323, + 326, 431, 327, 297, 408, 452, 0, 348, 419, 380, + 298, 379, 409, 451, 450, 308, 478, 484, 485, 574, + 0, 490, 662, 663, 664, 499, 0, 414, 0, 504, + 505, 506, 508, 509, 510, 511, 575, 592, 559, 529, + 492, 583, 526, 530, 531, 358, 595, 0, 0, 0, + 483, 368, 369, 0, 340, 339, 381, 417, 299, 346, + 291, 292, 657, 330, 400, 597, 630, 631, 522, 0, + 584, 523, 532, 322, 556, 568, 567, 396, 482, 0, + 579, 582, 512, 656, 0, 576, 591, 660, 590, 653, + 406, 0, 428, 588, 535, 0, 580, 554, 0, 581, + 550, 585, 0, 524, 0, 436, 464, 476, 493, 496, + 525, 610, 611, 612, 296, 495, 614, 615, 616, 617, + 618, 619, 620, 613, 467, 557, 534, 560, 475, 537, + 536, 0, 0, 571, 491, 572, 573, 390, 391, 392, + 393, 350, 598, 315, 494, 416, 0, 558, 0, 0, + 0, 0, 0, 0, 0, 0, 563, 564, 561, 665, + 0, 621, 622, 0, 0, 488, 489, 345, 352, 507, + 354, 314, 405, 347, 473, 362, 0, 500, 565, 501, + 624, 627, 625, 626, 397, 357, 359, 432, 363, 373, + 420, 472, 403, 425, 312, 463, 434, 378, 551, 578, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 606, 605, 604, 603, + 602, 601, 600, 599, 0, 0, 548, 449, 324, 285, + 320, 321, 328, 654, 651, 454, 655, 0, 293, 528, + 371, 0, 415, 344, 593, 594, 0, 645, 241, 242, + 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, + 252, 253, 254, 255, 258, 259, 260, 261, 262, 263, + 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, + 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, + 0, 0, 287, 288, 289, 290, 0, 0, 281, 282, + 283, 284, 0, 0, 0, 479, 480, 481, 503, 0, + 465, 527, 652, 0, 0, 0, 0, 0, 0, 0, + 577, 589, 623, 0, 633, 634, 636, 638, 637, 640, + 439, 440, 647, 0, 642, 643, 644, 641, 375, 426, + 445, 433, 0, 658, 518, 519, 659, 629, 402, 0, + 0, 533, 566, 555, 639, 521, 0, 2051, 0, 0, + 0, 0, 0, 0, 0, 0, 337, 0, 0, 370, + 570, 552, 562, 553, 538, 539, 540, 547, 349, 541, + 542, 543, 513, 544, 514, 545, 546, 0, 569, 520, + 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 228, 0, 0, 0, 0, 0, + 0, 310, 229, 515, 635, 517, 516, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 313, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 300, 442, + 461, 311, 430, 474, 316, 438, 453, 306, 401, 427, + 0, 0, 302, 459, 437, 383, 360, 361, 301, 0, + 421, 335, 351, 332, 399, 0, 458, 486, 331, 477, + 0, 469, 304, 0, 468, 398, 455, 460, 384, 377, + 0, 303, 457, 382, 376, 364, 341, 502, 365, 366, + 355, 410, 374, 411, 356, 388, 387, 389, 0, 0, + 0, 0, 0, 497, 498, 0, 0, 646, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 628, + 0, 0, 632, 0, 471, 0, 0, 0, 0, 0, + 0, 441, 0, 0, 367, 0, 0, 0, 487, 0, + 424, 404, 661, 0, 0, 422, 372, 456, 412, 462, + 443, 470, 418, 413, 294, 444, 334, 385, 307, 309, + 329, 336, 338, 342, 343, 394, 395, 407, 429, 446, + 447, 448, 333, 317, 423, 318, 353, 319, 295, 325, + 323, 326, 431, 327, 297, 408, 452, 0, 348, 419, + 380, 298, 379, 409, 451, 450, 308, 478, 484, 485, + 574, 0, 490, 662, 663, 664, 499, 0, 414, 0, + 504, 505, 506, 508, 509, 510, 511, 575, 592, 559, + 529, 492, 583, 526, 530, 531, 358, 595, 0, 0, + 0, 483, 368, 369, 0, 340, 339, 381, 417, 299, + 346, 291, 292, 657, 330, 400, 597, 630, 631, 522, + 0, 584, 523, 532, 322, 556, 568, 567, 396, 482, + 0, 579, 582, 512, 656, 0, 576, 591, 660, 590, + 653, 406, 0, 428, 588, 535, 0, 580, 554, 0, + 581, 550, 585, 0, 524, 0, 436, 464, 476, 493, + 496, 525, 610, 611, 612, 296, 495, 614, 615, 616, + 617, 618, 619, 620, 613, 467, 557, 534, 560, 475, + 537, 536, 0, 0, 571, 491, 572, 573, 390, 391, + 392, 393, 350, 598, 315, 494, 416, 0, 558, 0, + 0, 0, 0, 0, 0, 0, 0, 563, 564, 561, + 665, 0, 621, 622, 0, 0, 488, 489, 345, 352, + 507, 354, 314, 405, 347, 473, 362, 0, 500, 565, + 501, 624, 627, 625, 626, 397, 357, 359, 432, 363, + 373, 420, 472, 403, 425, 312, 463, 434, 378, 551, + 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 606, 605, 604, + 603, 602, 601, 600, 599, 0, 0, 548, 449, 324, + 285, 320, 321, 328, 654, 651, 454, 655, 0, 293, + 528, 371, 0, 415, 344, 593, 594, 0, 645, 241, + 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, + 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, + 263, 264, 265, 596, 256, 257, 266, 267, 268, 269, + 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, + 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, + 282, 283, 284, 0, 0, 0, 479, 480, 481, 503, + 0, 465, 527, 652, 0, 0, 0, 0, 0, 0, + 0, 577, 589, 623, 0, 633, 634, 636, 638, 637, + 640, 439, 440, 647, 0, 642, 643, 644, 641, 375, + 426, 445, 433, 0, 658, 518, 519, 659, 629, 402, + 0, 0, 533, 566, 555, 639, 521, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 337, 0, 0, + 370, 570, 552, 562, 553, 538, 539, 540, 547, 349, + 541, 542, 543, 513, 544, 514, 545, 546, 0, 569, + 520, 435, 386, 587, 586, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 228, 0, 0, 1555, 0, + 0, 0, 310, 229, 515, 635, 517, 516, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 313, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 300, + 442, 461, 311, 430, 474, 316, 438, 453, 306, 401, + 427, 0, 0, 302, 459, 437, 383, 360, 361, 301, + 0, 421, 335, 351, 332, 399, 0, 458, 486, 331, + 477, 0, 469, 304, 0, 468, 398, 455, 460, 384, + 377, 0, 303, 457, 382, 376, 364, 341, 502, 365, + 366, 355, 410, 374, 411, 356, 388, 387, 389, 0, + 0, 0, 0, 0, 497, 498, 0, 0, 646, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 628, 0, 0, 632, 0, 471, 0, 0, 0, 0, + 0, 0, 441, 0, 0, 367, 0, 0, 0, 487, + 0, 424, 404, 661, 0, 0, 422, 372, 456, 412, + 462, 443, 470, 1956, 413, 294, 444, 334, 385, 307, + 309, 329, 336, 338, 342, 343, 394, 395, 407, 429, + 446, 447, 448, 333, 317, 423, 318, 353, 319, 295, + 325, 323, 326, 431, 327, 297, 408, 452, 0, 348, + 419, 380, 298, 379, 409, 451, 450, 308, 478, 484, + 485, 574, 0, 490, 662, 663, 664, 499, 0, 414, + 0, 504, 505, 506, 508, 509, 510, 511, 575, 592, + 559, 529, 492, 583, 526, 530, 531, 358, 595, 0, + 0, 0, 483, 368, 369, 0, 340, 339, 381, 417, + 299, 346, 291, 292, 657, 330, 400, 597, 630, 631, + 522, 0, 584, 523, 532, 322, 556, 568, 567, 396, + 482, 0, 579, 582, 512, 656, 0, 576, 591, 660, + 590, 653, 406, 0, 428, 588, 535, 0, 580, 554, + 0, 581, 550, 585, 0, 524, 0, 436, 464, 476, + 493, 496, 525, 610, 611, 612, 296, 495, 614, 615, + 616, 617, 618, 619, 620, 613, 467, 557, 534, 560, + 475, 537, 536, 0, 0, 571, 491, 572, 573, 390, + 391, 392, 393, 350, 598, 315, 494, 416, 0, 558, + 0, 0, 0, 0, 0, 0, 0, 0, 563, 564, + 561, 665, 0, 621, 622, 0, 0, 488, 489, 345, + 352, 507, 354, 314, 405, 347, 473, 362, 0, 500, + 565, 501, 624, 627, 625, 626, 397, 357, 359, 432, + 363, 373, 420, 472, 403, 425, 312, 463, 434, 378, + 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 606, 605, + 604, 603, 602, 601, 600, 599, 0, 0, 548, 449, + 324, 285, 320, 321, 328, 654, 651, 454, 655, 0, + 293, 528, 371, 0, 415, 344, 593, 594, 0, 645, + 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, + 250, 251, 252, 253, 254, 255, 258, 259, 260, 261, + 262, 263, 264, 265, 596, 256, 257, 266, 267, 268, + 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, + 279, 0, 0, 0, 287, 288, 289, 290, 0, 0, + 281, 282, 283, 284, 0, 0, 0, 479, 480, 481, + 503, 0, 465, 527, 652, 0, 0, 0, 0, 0, + 0, 0, 577, 589, 623, 0, 633, 634, 636, 638, + 637, 640, 439, 440, 647, 0, 642, 643, 644, 641, + 375, 426, 445, 433, 0, 658, 518, 519, 659, 629, + 402, 0, 0, 533, 566, 555, 639, 521, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 337, 0, + 0, 370, 570, 552, 562, 553, 538, 539, 540, 547, + 349, 541, 542, 543, 513, 544, 514, 545, 546, 0, + 569, 520, 435, 386, 587, 586, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 228, 0, 0, 0, + 0, 0, 0, 310, 229, 515, 635, 517, 516, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 313, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 300, 442, 461, 311, 430, 474, 316, 438, 453, 306, + 401, 427, 0, 0, 302, 459, 437, 383, 360, 361, + 301, 0, 421, 335, 351, 332, 399, 0, 458, 486, + 331, 477, 0, 469, 304, 0, 468, 398, 455, 460, + 384, 377, 0, 303, 457, 382, 376, 364, 341, 502, + 365, 366, 355, 410, 374, 411, 356, 388, 387, 389, + 0, 0, 0, 0, 0, 497, 498, 0, 0, 646, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 628, 0, 0, 632, 0, 471, 0, 0, 1584, + 0, 0, 0, 441, 0, 0, 367, 0, 0, 0, + 487, 0, 424, 404, 661, 0, 0, 422, 372, 456, + 412, 462, 443, 470, 418, 413, 294, 444, 334, 385, + 307, 309, 329, 336, 338, 342, 343, 394, 395, 407, + 429, 446, 447, 448, 333, 317, 423, 318, 353, 319, + 295, 325, 323, 326, 431, 327, 297, 408, 452, 0, + 348, 419, 380, 298, 379, 409, 451, 450, 308, 478, + 484, 485, 574, 0, 490, 662, 663, 664, 499, 0, + 414, 0, 504, 505, 506, 508, 509, 510, 511, 575, + 592, 559, 529, 492, 583, 526, 530, 531, 358, 595, + 0, 0, 0, 483, 368, 369, 0, 340, 339, 381, + 417, 299, 346, 291, 292, 657, 330, 400, 597, 630, + 631, 522, 0, 584, 523, 532, 322, 556, 568, 567, + 396, 482, 0, 579, 582, 512, 656, 0, 576, 591, + 660, 590, 653, 406, 0, 428, 588, 535, 0, 580, + 554, 0, 581, 550, 585, 0, 524, 0, 436, 464, + 476, 493, 496, 525, 610, 611, 612, 296, 495, 614, + 615, 616, 617, 618, 619, 620, 613, 467, 557, 534, + 560, 475, 537, 536, 0, 0, 571, 491, 572, 573, + 390, 391, 392, 393, 350, 598, 315, 494, 416, 0, + 558, 0, 0, 0, 0, 0, 0, 0, 0, 563, + 564, 561, 665, 0, 621, 622, 0, 0, 488, 489, + 345, 352, 507, 354, 314, 405, 347, 473, 362, 0, + 500, 565, 501, 624, 627, 625, 626, 397, 357, 359, + 432, 363, 373, 420, 472, 403, 425, 312, 463, 434, + 378, 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 606, + 605, 604, 603, 602, 601, 600, 599, 0, 0, 548, + 449, 324, 285, 320, 321, 328, 654, 651, 454, 655, + 0, 293, 528, 371, 0, 415, 344, 593, 594, 0, + 645, 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, + 261, 262, 263, 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, + 0, 281, 282, 283, 284, 0, 0, 0, 479, 480, + 481, 503, 0, 465, 527, 652, 0, 0, 0, 0, + 0, 0, 0, 577, 589, 623, 0, 633, 634, 636, + 638, 637, 640, 439, 440, 647, 0, 642, 643, 644, + 641, 375, 426, 445, 433, 0, 658, 518, 519, 659, + 629, 402, 0, 0, 533, 566, 555, 639, 521, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 672, 337, + 0, 0, 370, 570, 552, 562, 553, 538, 539, 540, + 547, 349, 541, 542, 543, 513, 544, 514, 545, 546, + 0, 569, 520, 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 417, 412, 294, 443, 333, - 384, 306, 308, 749, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 619, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 310, 229, 515, 635, 517, 516, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 313, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 300, 442, 461, 311, 430, 474, 316, 438, 453, + 306, 401, 427, 0, 0, 302, 459, 437, 383, 360, + 361, 301, 0, 421, 335, 351, 332, 399, 0, 458, + 486, 331, 477, 0, 469, 304, 0, 468, 398, 455, + 460, 384, 377, 0, 303, 457, 382, 376, 364, 341, + 502, 365, 366, 355, 410, 374, 411, 356, 388, 387, + 389, 0, 0, 0, 0, 0, 497, 498, 0, 0, + 646, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 628, 0, 0, 632, 0, 471, 0, 0, + 0, 0, 0, 0, 441, 0, 0, 367, 0, 0, + 0, 487, 0, 424, 404, 661, 0, 0, 422, 372, + 456, 412, 462, 443, 470, 418, 413, 294, 444, 334, + 385, 307, 309, 329, 336, 338, 342, 343, 394, 395, + 407, 429, 446, 447, 448, 333, 317, 423, 318, 353, + 319, 295, 325, 323, 326, 431, 327, 297, 408, 452, + 0, 348, 419, 380, 298, 379, 409, 451, 450, 308, + 478, 484, 485, 574, 0, 490, 662, 663, 664, 499, + 0, 414, 0, 504, 505, 506, 508, 509, 510, 511, + 575, 592, 559, 529, 492, 583, 526, 530, 531, 358, + 595, 0, 0, 0, 483, 368, 369, 0, 340, 339, + 381, 417, 299, 346, 291, 292, 657, 330, 400, 597, + 630, 631, 522, 0, 584, 523, 532, 322, 556, 568, + 567, 396, 482, 0, 579, 582, 512, 656, 0, 576, + 591, 660, 590, 653, 406, 0, 428, 588, 535, 0, + 580, 554, 0, 581, 550, 585, 0, 524, 0, 436, + 464, 476, 493, 496, 525, 610, 611, 612, 296, 495, + 614, 615, 616, 617, 618, 619, 620, 613, 467, 557, + 534, 560, 475, 537, 536, 0, 0, 571, 491, 572, + 573, 390, 391, 392, 393, 350, 598, 315, 494, 416, + 0, 558, 0, 0, 0, 0, 0, 0, 0, 0, + 563, 564, 561, 665, 0, 621, 622, 0, 0, 488, + 489, 345, 352, 507, 354, 314, 405, 347, 473, 362, + 0, 500, 565, 501, 624, 627, 625, 626, 397, 357, + 359, 432, 363, 373, 420, 472, 403, 425, 312, 463, + 434, 378, 551, 578, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 606, 605, 604, 603, 602, 601, 600, 599, 0, 0, + 548, 449, 324, 285, 320, 321, 328, 654, 651, 454, + 655, 0, 293, 528, 371, 0, 415, 344, 593, 594, + 0, 645, 241, 242, 243, 244, 245, 246, 247, 248, + 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, + 260, 261, 262, 263, 264, 265, 596, 256, 257, 266, + 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, + 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, + 0, 0, 281, 282, 283, 284, 0, 0, 0, 479, + 480, 481, 503, 0, 465, 527, 652, 0, 0, 0, + 0, 0, 0, 0, 577, 589, 623, 0, 633, 634, + 636, 638, 637, 640, 439, 440, 647, 0, 642, 643, + 644, 641, 375, 426, 445, 433, 0, 658, 518, 519, + 659, 629, 402, 0, 0, 533, 566, 555, 639, 521, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 337, 0, 0, 370, 570, 552, 562, 553, 538, 539, + 540, 547, 349, 541, 542, 543, 513, 544, 514, 545, + 546, 0, 569, 520, 435, 386, 587, 586, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 228, 0, + 0, 0, 0, 0, 0, 310, 229, 515, 635, 517, + 516, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 313, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 300, 442, 461, 311, 430, 474, 316, 438, + 453, 306, 401, 427, 0, 0, 302, 459, 437, 383, + 360, 361, 301, 0, 421, 335, 351, 332, 399, 0, + 458, 486, 331, 477, 0, 469, 304, 0, 468, 398, + 455, 460, 384, 377, 0, 303, 457, 382, 376, 364, + 341, 502, 365, 366, 355, 410, 374, 411, 356, 388, + 387, 389, 0, 0, 0, 0, 0, 497, 498, 0, + 0, 646, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 628, 0, 682, 632, 0, 471, 0, + 0, 0, 0, 0, 0, 441, 0, 0, 367, 0, + 0, 0, 487, 0, 424, 404, 661, 0, 0, 422, + 372, 456, 412, 462, 443, 470, 418, 413, 294, 444, + 334, 385, 307, 309, 329, 336, 338, 342, 343, 394, + 395, 407, 429, 446, 447, 448, 333, 317, 423, 318, + 353, 319, 295, 325, 323, 326, 431, 327, 297, 408, + 452, 0, 348, 419, 380, 298, 379, 409, 451, 450, + 308, 478, 484, 485, 574, 0, 490, 662, 663, 664, + 499, 0, 414, 0, 504, 505, 506, 508, 509, 510, + 511, 575, 592, 559, 529, 492, 583, 526, 530, 531, + 358, 595, 0, 0, 0, 483, 368, 369, 0, 340, + 339, 381, 417, 299, 346, 291, 292, 657, 330, 400, + 597, 630, 631, 522, 0, 584, 523, 532, 322, 556, + 568, 567, 396, 482, 0, 579, 582, 512, 656, 0, + 576, 591, 660, 590, 653, 406, 0, 428, 588, 535, + 0, 580, 554, 0, 581, 550, 585, 0, 524, 0, + 436, 464, 476, 493, 496, 525, 610, 611, 612, 296, + 495, 614, 615, 616, 617, 618, 619, 620, 613, 467, + 557, 534, 560, 475, 537, 536, 0, 0, 571, 491, + 572, 573, 390, 391, 392, 393, 350, 598, 315, 494, + 416, 0, 558, 0, 0, 0, 0, 0, 0, 0, + 0, 563, 564, 561, 665, 0, 621, 622, 0, 0, + 488, 489, 345, 352, 507, 354, 314, 405, 347, 473, + 362, 0, 500, 565, 501, 624, 627, 625, 626, 397, + 357, 359, 432, 363, 373, 420, 472, 403, 425, 312, + 463, 434, 378, 551, 578, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 606, 605, 604, 603, 602, 601, 600, 599, 0, + 0, 548, 449, 324, 285, 320, 321, 328, 654, 651, + 454, 655, 0, 293, 528, 371, 0, 415, 344, 593, + 594, 0, 645, 241, 242, 243, 244, 245, 246, 247, + 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, + 259, 260, 261, 262, 263, 264, 265, 596, 256, 257, + 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, + 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, + 290, 0, 0, 281, 282, 283, 284, 0, 0, 0, + 479, 480, 481, 503, 0, 465, 527, 652, 0, 0, + 0, 0, 0, 0, 0, 577, 589, 623, 0, 633, + 634, 636, 638, 637, 640, 439, 440, 647, 0, 642, + 643, 644, 641, 375, 426, 445, 433, 0, 658, 518, + 519, 659, 629, 402, 0, 0, 533, 566, 555, 639, + 521, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 337, 0, 0, 370, 570, 552, 562, 553, 538, + 539, 540, 547, 349, 541, 542, 543, 513, 544, 514, + 545, 546, 0, 569, 520, 435, 386, 587, 586, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 228, + 0, 0, 0, 0, 0, 0, 310, 229, 515, 635, + 517, 516, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 313, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 300, 442, 461, 311, 430, 474, 316, + 438, 453, 306, 401, 427, 0, 0, 302, 459, 437, + 383, 360, 361, 301, 0, 421, 335, 351, 332, 399, + 0, 458, 486, 331, 477, 0, 469, 304, 0, 468, + 398, 455, 460, 384, 377, 0, 303, 457, 382, 376, + 364, 341, 502, 365, 366, 355, 410, 374, 411, 356, + 388, 387, 389, 0, 0, 0, 0, 0, 497, 498, + 0, 0, 646, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 628, 0, 0, 632, 0, 471, + 0, 0, 0, 0, 0, 0, 441, 0, 0, 367, + 0, 0, 0, 487, 0, 424, 404, 661, 0, 0, + 422, 372, 456, 412, 462, 443, 470, 418, 413, 294, + 444, 334, 385, 307, 309, 329, 336, 338, 342, 343, + 394, 395, 407, 429, 446, 447, 448, 333, 317, 423, + 318, 353, 319, 295, 325, 323, 326, 431, 327, 297, + 408, 452, 0, 348, 419, 380, 298, 379, 409, 451, + 450, 308, 478, 484, 485, 574, 0, 490, 662, 663, + 664, 499, 0, 414, 0, 504, 505, 506, 508, 509, + 510, 511, 575, 592, 559, 529, 492, 583, 526, 530, + 531, 358, 595, 0, 0, 0, 483, 368, 369, 0, + 340, 339, 381, 417, 299, 346, 291, 292, 657, 330, + 400, 597, 630, 631, 522, 0, 584, 523, 532, 322, + 556, 568, 567, 396, 482, 0, 579, 582, 512, 656, + 0, 576, 591, 660, 590, 653, 406, 0, 428, 588, + 535, 0, 580, 554, 0, 581, 550, 585, 0, 524, + 0, 436, 464, 476, 493, 496, 525, 610, 611, 612, + 296, 495, 614, 615, 616, 617, 618, 619, 620, 613, + 467, 557, 534, 560, 475, 537, 536, 0, 0, 571, + 491, 572, 573, 390, 391, 392, 393, 350, 598, 315, + 494, 416, 0, 558, 0, 0, 0, 0, 0, 0, + 0, 0, 563, 564, 561, 665, 0, 621, 622, 0, + 0, 488, 489, 345, 352, 507, 354, 314, 405, 347, + 473, 362, 0, 500, 565, 501, 624, 627, 625, 626, + 397, 357, 359, 432, 363, 373, 420, 472, 403, 425, + 312, 463, 434, 378, 551, 578, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 606, 605, 604, 603, 602, 601, 600, 599, + 980, 0, 548, 449, 324, 285, 320, 321, 328, 654, + 651, 454, 655, 0, 293, 528, 371, 0, 415, 344, + 593, 594, 0, 645, 241, 242, 243, 244, 245, 246, + 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, + 258, 259, 260, 261, 262, 263, 264, 265, 596, 256, + 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, + 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, + 289, 290, 0, 0, 281, 282, 283, 284, 0, 0, + 0, 479, 480, 481, 503, 0, 465, 527, 652, 0, + 0, 0, 0, 0, 0, 0, 577, 589, 623, 0, + 633, 634, 636, 638, 637, 640, 439, 440, 647, 0, + 642, 643, 644, 641, 375, 426, 445, 433, 0, 658, + 518, 519, 659, 629, 402, 0, 0, 533, 566, 555, + 639, 521, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 337, 0, 0, 370, 570, 552, 562, 553, + 538, 539, 540, 547, 349, 541, 542, 543, 513, 544, + 514, 545, 546, 0, 569, 520, 435, 386, 587, 586, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 228, 0, 0, 0, 0, 0, 0, 310, 229, 515, + 635, 517, 516, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 313, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 300, 442, 461, 311, 430, 474, + 316, 438, 453, 306, 401, 427, 0, 0, 302, 459, + 437, 383, 360, 361, 301, 0, 421, 335, 351, 332, + 399, 0, 458, 486, 331, 477, 0, 469, 304, 0, + 468, 398, 455, 460, 384, 377, 0, 303, 457, 382, + 376, 364, 341, 502, 365, 366, 355, 410, 374, 411, + 356, 388, 387, 389, 0, 0, 0, 0, 0, 497, + 498, 0, 0, 646, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 628, 0, 0, 632, 0, + 471, 0, 0, 0, 0, 0, 0, 441, 0, 0, + 367, 0, 0, 0, 487, 0, 424, 404, 661, 0, + 0, 422, 372, 456, 412, 462, 443, 470, 418, 413, + 294, 444, 334, 385, 307, 309, 329, 336, 338, 342, + 343, 394, 395, 407, 429, 446, 447, 448, 333, 317, + 423, 318, 353, 319, 295, 325, 323, 326, 431, 327, + 297, 408, 452, 0, 348, 419, 380, 298, 379, 409, + 451, 450, 308, 478, 484, 485, 574, 0, 490, 662, + 663, 664, 499, 0, 414, 0, 504, 505, 506, 508, + 509, 510, 511, 575, 592, 559, 529, 492, 583, 526, + 530, 531, 358, 595, 0, 0, 0, 483, 368, 369, + 0, 340, 339, 381, 417, 299, 346, 291, 292, 657, + 330, 400, 597, 630, 631, 522, 0, 584, 523, 532, + 322, 556, 568, 567, 396, 482, 0, 579, 582, 512, + 656, 0, 576, 591, 660, 590, 653, 406, 0, 428, + 588, 535, 0, 580, 554, 0, 581, 550, 585, 0, + 524, 0, 436, 464, 476, 493, 496, 525, 610, 611, + 612, 296, 495, 614, 615, 616, 617, 618, 619, 620, + 613, 467, 557, 534, 560, 475, 537, 536, 0, 0, + 571, 491, 572, 573, 390, 391, 392, 393, 350, 598, + 315, 494, 416, 0, 558, 0, 0, 0, 0, 0, + 0, 0, 0, 563, 564, 561, 665, 0, 621, 622, + 0, 0, 488, 489, 345, 352, 507, 354, 314, 405, + 347, 473, 362, 0, 500, 565, 501, 624, 627, 625, + 626, 397, 357, 359, 432, 363, 373, 420, 472, 403, + 425, 312, 463, 434, 378, 551, 578, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 606, 605, 604, 603, 602, 601, 600, + 599, 0, 0, 548, 449, 324, 285, 320, 321, 328, + 654, 651, 454, 655, 0, 293, 528, 371, 0, 415, + 344, 593, 594, 0, 645, 241, 242, 243, 244, 245, + 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, + 255, 258, 259, 260, 261, 262, 263, 264, 265, 596, + 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, + 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, + 288, 289, 290, 0, 0, 281, 282, 283, 284, 0, + 0, 0, 479, 480, 481, 503, 0, 465, 527, 652, + 0, 0, 0, 0, 0, 0, 0, 577, 589, 623, + 0, 633, 634, 636, 638, 637, 640, 439, 440, 647, + 0, 642, 643, 644, 641, 375, 426, 445, 433, 0, + 658, 518, 519, 659, 629, 402, 0, 0, 533, 566, + 555, 639, 521, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 337, 0, 0, 370, 570, 552, 562, + 553, 538, 539, 540, 547, 349, 541, 542, 543, 513, + 544, 514, 545, 546, 0, 569, 520, 435, 386, 587, + 586, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 228, 0, 0, 0, 0, 0, 0, 310, 229, + 515, 635, 517, 516, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 313, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 300, 442, 461, 311, 430, + 474, 316, 438, 453, 306, 401, 427, 0, 0, 302, + 459, 437, 383, 360, 361, 301, 0, 421, 335, 351, + 332, 399, 0, 458, 486, 331, 477, 0, 469, 304, + 0, 468, 398, 455, 460, 384, 377, 0, 303, 457, + 382, 376, 364, 341, 502, 365, 366, 355, 410, 374, + 411, 356, 388, 387, 389, 0, 0, 0, 0, 0, + 497, 498, 0, 0, 646, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 628, 0, 0, 632, + 0, 471, 0, 0, 0, 0, 0, 0, 441, 0, + 0, 367, 0, 0, 0, 487, 0, 424, 404, 661, + 0, 0, 422, 372, 456, 412, 462, 443, 470, 418, + 413, 294, 444, 334, 385, 307, 309, 329, 336, 338, + 342, 343, 394, 395, 407, 429, 446, 447, 448, 333, + 317, 423, 318, 353, 319, 295, 325, 323, 326, 431, + 327, 297, 408, 452, 0, 348, 3178, 380, 298, 379, + 409, 451, 450, 308, 478, 484, 485, 574, 0, 490, + 662, 663, 664, 499, 0, 414, 0, 504, 505, 506, + 508, 509, 510, 511, 575, 592, 559, 529, 492, 583, + 526, 530, 531, 358, 595, 0, 0, 0, 483, 368, + 369, 0, 340, 339, 381, 417, 299, 346, 291, 292, + 657, 330, 400, 597, 630, 631, 522, 0, 584, 523, + 532, 322, 556, 568, 567, 396, 482, 0, 579, 582, + 512, 656, 0, 576, 591, 660, 590, 653, 406, 0, + 428, 588, 535, 0, 580, 554, 0, 581, 550, 585, + 0, 524, 0, 436, 464, 476, 493, 496, 525, 610, + 611, 612, 296, 495, 614, 615, 616, 617, 618, 619, + 620, 613, 467, 557, 534, 560, 475, 537, 536, 0, + 0, 571, 491, 572, 573, 390, 391, 392, 393, 350, + 598, 315, 494, 416, 0, 558, 0, 0, 0, 0, + 0, 0, 0, 0, 563, 564, 561, 665, 0, 621, + 622, 0, 0, 488, 489, 345, 352, 507, 354, 314, + 405, 347, 473, 362, 0, 500, 565, 501, 624, 627, + 625, 626, 397, 357, 359, 432, 363, 373, 420, 472, + 403, 425, 312, 463, 434, 378, 551, 578, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 606, 605, 604, 603, 602, 601, + 600, 599, 0, 0, 548, 449, 324, 285, 320, 321, + 328, 654, 651, 454, 655, 0, 293, 528, 371, 0, + 415, 344, 593, 594, 0, 645, 241, 242, 243, 244, + 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, + 254, 255, 258, 259, 260, 261, 262, 263, 264, 265, + 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, + 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, + 287, 288, 289, 290, 0, 0, 281, 282, 283, 284, + 0, 0, 0, 479, 480, 481, 503, 0, 465, 527, + 652, 0, 0, 0, 0, 0, 0, 0, 577, 589, + 623, 0, 633, 634, 636, 638, 637, 640, 439, 440, + 647, 0, 642, 643, 644, 641, 375, 426, 445, 433, + 0, 658, 518, 519, 659, 629, 402, 0, 0, 533, + 566, 555, 639, 521, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 337, 0, 0, 370, 570, 552, + 562, 553, 538, 539, 540, 547, 349, 541, 542, 543, + 513, 544, 514, 545, 546, 0, 569, 520, 435, 386, + 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 228, 0, 0, 0, 0, 0, 0, 310, + 229, 515, 635, 517, 516, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 313, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 300, 442, 461, 311, + 430, 474, 316, 438, 1906, 306, 401, 427, 0, 0, + 302, 459, 437, 383, 360, 361, 301, 0, 421, 335, + 351, 332, 399, 0, 458, 486, 331, 477, 0, 469, + 304, 0, 468, 398, 455, 460, 384, 377, 0, 303, + 457, 382, 376, 364, 341, 502, 365, 366, 355, 410, + 374, 411, 356, 388, 387, 389, 0, 0, 0, 0, + 0, 497, 498, 0, 0, 646, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 628, 0, 0, + 632, 0, 471, 0, 0, 0, 0, 0, 0, 441, + 0, 0, 367, 0, 0, 0, 487, 0, 424, 404, + 661, 0, 0, 422, 372, 456, 412, 462, 443, 470, + 418, 413, 294, 444, 334, 385, 307, 309, 329, 336, + 338, 342, 343, 394, 395, 407, 429, 446, 447, 448, + 333, 317, 423, 318, 353, 319, 295, 325, 323, 326, + 431, 327, 297, 408, 452, 0, 348, 419, 380, 298, + 379, 409, 451, 450, 308, 478, 484, 485, 574, 0, + 490, 662, 663, 664, 499, 0, 414, 0, 504, 505, + 506, 508, 509, 510, 511, 575, 592, 559, 529, 492, + 583, 526, 530, 531, 358, 595, 0, 0, 0, 483, + 368, 369, 0, 340, 339, 381, 417, 299, 346, 291, + 292, 657, 330, 400, 597, 630, 631, 522, 0, 584, + 523, 532, 322, 556, 568, 567, 396, 482, 0, 579, + 582, 512, 656, 0, 576, 591, 660, 590, 653, 406, + 0, 428, 588, 535, 0, 580, 554, 0, 581, 550, + 585, 0, 524, 0, 436, 464, 476, 493, 496, 525, + 610, 611, 612, 296, 495, 614, 615, 616, 617, 618, + 619, 620, 613, 467, 557, 534, 560, 475, 537, 536, + 0, 0, 571, 491, 572, 573, 390, 391, 392, 393, + 350, 598, 315, 494, 416, 0, 558, 0, 0, 0, + 0, 0, 0, 0, 0, 563, 564, 561, 665, 0, + 621, 622, 0, 0, 488, 489, 345, 352, 507, 354, + 314, 405, 347, 473, 362, 0, 500, 565, 501, 624, + 627, 625, 626, 397, 357, 359, 432, 363, 373, 420, + 472, 403, 425, 312, 463, 434, 378, 551, 578, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 280, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 606, 605, 604, 603, 602, + 601, 600, 599, 0, 0, 548, 449, 324, 285, 320, + 321, 328, 654, 651, 454, 655, 0, 293, 528, 371, + 0, 415, 344, 593, 594, 0, 645, 241, 242, 243, + 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, + 253, 254, 255, 258, 259, 260, 261, 262, 263, 264, + 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, + 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, + 0, 287, 288, 289, 290, 0, 0, 281, 282, 283, + 284, 0, 0, 0, 479, 480, 481, 503, 0, 465, + 527, 652, 0, 0, 0, 0, 0, 0, 0, 577, + 589, 623, 0, 633, 634, 636, 638, 637, 640, 439, + 440, 647, 0, 642, 643, 644, 641, 375, 426, 445, + 433, 0, 658, 518, 519, 659, 629, 402, 0, 0, + 533, 566, 555, 639, 521, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 337, 0, 0, 370, 570, + 552, 562, 553, 538, 539, 540, 547, 349, 541, 542, + 543, 513, 544, 514, 545, 546, 0, 569, 520, 435, + 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 228, 0, 0, 0, 0, 0, 0, + 310, 229, 515, 635, 517, 516, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 313, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 300, 442, 1534, + 311, 430, 474, 316, 438, 453, 306, 401, 427, 0, + 0, 302, 459, 437, 383, 360, 361, 301, 0, 421, + 335, 351, 332, 399, 0, 458, 486, 331, 477, 0, + 469, 304, 0, 468, 398, 455, 460, 384, 377, 0, + 303, 457, 382, 376, 364, 341, 502, 365, 366, 355, + 410, 374, 411, 356, 388, 387, 389, 0, 0, 0, + 0, 0, 497, 498, 0, 0, 646, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 628, 0, + 0, 632, 0, 471, 0, 0, 0, 0, 0, 0, + 441, 0, 0, 367, 0, 0, 0, 487, 0, 424, + 404, 661, 0, 0, 422, 372, 456, 412, 462, 443, + 470, 418, 413, 294, 444, 334, 385, 307, 309, 329, + 336, 338, 342, 343, 394, 395, 407, 429, 446, 447, + 448, 333, 317, 423, 318, 353, 319, 295, 325, 323, + 326, 431, 327, 297, 408, 452, 0, 348, 419, 380, + 298, 379, 409, 451, 450, 308, 478, 484, 485, 574, + 0, 490, 662, 663, 664, 499, 0, 414, 0, 504, + 505, 506, 508, 509, 510, 511, 575, 592, 559, 529, + 492, 583, 526, 530, 531, 358, 595, 0, 0, 0, + 483, 368, 369, 0, 340, 339, 381, 417, 299, 346, + 291, 292, 657, 330, 400, 597, 630, 631, 522, 0, + 584, 523, 532, 322, 556, 568, 567, 396, 482, 0, + 579, 582, 512, 656, 0, 576, 591, 660, 590, 653, + 406, 0, 428, 588, 535, 0, 580, 554, 0, 581, + 550, 585, 0, 524, 0, 436, 464, 476, 493, 496, + 525, 610, 611, 612, 296, 495, 614, 615, 616, 617, + 618, 619, 620, 613, 467, 557, 534, 560, 475, 537, + 536, 0, 0, 571, 491, 572, 573, 390, 391, 392, + 393, 350, 598, 315, 494, 416, 0, 558, 0, 0, + 0, 0, 0, 0, 0, 0, 563, 564, 561, 665, + 0, 621, 622, 0, 0, 488, 489, 345, 352, 507, + 354, 314, 405, 347, 473, 362, 0, 500, 565, 501, + 624, 627, 625, 626, 397, 357, 359, 432, 363, 373, + 420, 472, 403, 425, 312, 463, 434, 378, 551, 578, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 280, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 606, 605, 604, 603, + 602, 601, 600, 599, 0, 0, 548, 449, 324, 285, + 320, 321, 328, 654, 651, 454, 655, 0, 293, 528, + 371, 0, 415, 344, 593, 594, 0, 645, 241, 242, + 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, + 252, 253, 254, 255, 258, 259, 260, 261, 262, 263, + 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, + 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, + 0, 0, 287, 288, 289, 290, 0, 0, 281, 282, + 283, 284, 0, 0, 0, 479, 480, 481, 503, 0, + 465, 527, 652, 0, 0, 0, 0, 0, 0, 0, + 577, 589, 623, 0, 633, 634, 636, 638, 637, 640, + 439, 440, 647, 0, 642, 643, 644, 641, 375, 426, + 445, 433, 0, 658, 518, 519, 659, 629, 402, 0, + 0, 533, 566, 555, 639, 521, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 337, 0, 0, 370, + 570, 552, 562, 553, 538, 539, 540, 547, 349, 541, + 542, 543, 513, 544, 514, 545, 546, 0, 569, 520, + 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 228, 0, 0, 0, 0, 0, + 0, 310, 229, 515, 635, 517, 516, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 313, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 300, 442, + 1532, 311, 430, 474, 316, 438, 453, 306, 401, 427, + 0, 0, 302, 459, 437, 383, 360, 361, 301, 0, + 421, 335, 351, 332, 399, 0, 458, 486, 331, 477, + 0, 469, 304, 0, 468, 398, 455, 460, 384, 377, + 0, 303, 457, 382, 376, 364, 341, 502, 365, 366, + 355, 410, 374, 411, 356, 388, 387, 389, 0, 0, + 0, 0, 0, 497, 498, 0, 0, 646, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 628, + 0, 0, 632, 0, 471, 0, 0, 0, 0, 0, + 0, 441, 0, 0, 367, 0, 0, 0, 487, 0, + 424, 404, 661, 0, 0, 422, 372, 456, 412, 462, + 443, 470, 418, 413, 294, 444, 334, 385, 307, 309, + 329, 336, 338, 342, 343, 394, 395, 407, 429, 446, + 447, 448, 333, 317, 423, 318, 353, 319, 295, 325, + 323, 326, 431, 327, 297, 408, 452, 0, 348, 419, + 380, 298, 379, 409, 451, 450, 308, 478, 484, 485, + 574, 0, 490, 662, 663, 664, 499, 0, 414, 0, + 504, 505, 506, 508, 509, 510, 511, 575, 592, 559, + 529, 492, 583, 526, 530, 531, 358, 595, 0, 0, + 0, 483, 368, 369, 0, 340, 339, 381, 417, 299, + 346, 291, 292, 657, 330, 400, 597, 630, 631, 522, + 0, 584, 523, 532, 322, 556, 568, 567, 396, 482, + 0, 579, 582, 512, 656, 0, 576, 591, 660, 590, + 653, 406, 0, 428, 588, 535, 0, 580, 554, 0, + 581, 550, 585, 0, 524, 0, 436, 464, 476, 493, + 496, 525, 610, 611, 612, 296, 495, 614, 615, 616, + 617, 618, 619, 620, 613, 467, 557, 534, 560, 475, + 537, 536, 0, 0, 571, 491, 572, 573, 390, 391, + 392, 393, 350, 598, 315, 494, 416, 0, 558, 0, + 0, 0, 0, 0, 0, 0, 0, 563, 564, 561, + 665, 0, 621, 622, 0, 0, 488, 489, 345, 352, + 507, 354, 314, 405, 347, 473, 362, 0, 500, 565, + 501, 624, 627, 625, 626, 397, 357, 359, 432, 363, + 373, 420, 472, 403, 425, 312, 463, 434, 378, 551, + 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 280, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 606, 605, 604, + 603, 602, 601, 600, 599, 0, 0, 548, 449, 324, + 285, 320, 321, 328, 654, 651, 454, 655, 0, 293, + 528, 371, 0, 415, 344, 593, 594, 0, 645, 241, + 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, + 251, 252, 253, 254, 255, 258, 259, 260, 261, 262, + 263, 264, 265, 596, 256, 257, 266, 267, 268, 269, + 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, + 0, 0, 0, 287, 288, 289, 290, 0, 0, 281, + 282, 283, 284, 0, 0, 0, 479, 480, 481, 503, + 0, 465, 527, 652, 0, 0, 0, 0, 0, 0, + 0, 577, 589, 623, 0, 633, 634, 636, 638, 637, + 640, 439, 440, 647, 0, 642, 643, 644, 641, 375, + 426, 445, 433, 0, 658, 518, 519, 659, 629, 402, + 0, 0, 533, 566, 555, 639, 521, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 337, 0, 0, + 370, 570, 552, 562, 553, 538, 539, 540, 547, 349, + 541, 542, 543, 513, 544, 514, 545, 546, 0, 569, + 520, 435, 386, 587, 586, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 228, 0, 0, 0, 0, + 0, 0, 310, 229, 515, 635, 517, 516, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 313, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 300, + 442, 461, 311, 430, 474, 316, 438, 1411, 306, 401, + 427, 0, 0, 302, 459, 437, 383, 360, 361, 301, + 0, 421, 335, 351, 332, 399, 0, 458, 486, 331, + 477, 0, 469, 304, 0, 468, 398, 455, 460, 384, + 377, 0, 303, 457, 382, 376, 364, 341, 502, 365, + 366, 355, 410, 374, 411, 356, 388, 387, 389, 0, + 0, 0, 0, 0, 497, 498, 0, 0, 646, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 628, 0, 0, 632, 0, 471, 0, 0, 0, 0, + 0, 0, 441, 0, 0, 367, 0, 0, 0, 487, + 0, 424, 404, 661, 0, 0, 422, 372, 456, 412, + 462, 443, 470, 418, 413, 294, 444, 334, 385, 307, + 309, 329, 336, 338, 342, 343, 394, 395, 407, 429, + 446, 447, 448, 333, 317, 423, 318, 353, 319, 295, + 325, 323, 326, 431, 327, 297, 408, 452, 0, 348, + 419, 380, 298, 379, 409, 451, 450, 308, 478, 484, + 485, 574, 0, 490, 662, 663, 664, 499, 0, 414, + 0, 504, 505, 506, 508, 509, 510, 511, 575, 592, + 559, 529, 492, 583, 526, 530, 531, 358, 595, 0, + 0, 0, 483, 368, 369, 0, 340, 339, 381, 417, + 299, 346, 291, 292, 657, 330, 400, 597, 630, 631, + 522, 0, 584, 523, 532, 322, 556, 568, 567, 396, + 482, 0, 579, 582, 512, 656, 0, 576, 591, 660, + 590, 653, 406, 0, 428, 588, 535, 0, 580, 554, + 0, 581, 550, 585, 0, 524, 0, 436, 464, 476, + 493, 496, 525, 610, 611, 612, 296, 495, 614, 615, + 616, 617, 618, 619, 620, 613, 467, 557, 534, 560, + 475, 537, 536, 0, 0, 571, 491, 572, 573, 390, + 391, 392, 393, 350, 598, 315, 494, 416, 0, 558, + 0, 0, 0, 0, 0, 0, 0, 0, 563, 564, + 561, 665, 0, 621, 622, 0, 0, 488, 489, 345, + 352, 507, 354, 314, 405, 347, 473, 362, 0, 500, + 565, 501, 624, 627, 625, 626, 397, 357, 359, 432, + 363, 373, 420, 472, 403, 425, 312, 463, 434, 378, + 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 280, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 606, 605, + 604, 603, 602, 601, 600, 599, 0, 0, 548, 449, + 324, 285, 320, 321, 328, 654, 651, 454, 655, 0, + 293, 528, 371, 0, 415, 344, 593, 594, 0, 645, + 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, + 250, 251, 252, 253, 254, 255, 258, 259, 260, 261, + 262, 263, 264, 265, 596, 256, 257, 266, 267, 268, + 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, + 279, 0, 0, 0, 287, 288, 289, 290, 0, 0, + 281, 282, 283, 284, 0, 0, 0, 479, 480, 481, + 503, 0, 465, 527, 652, 0, 0, 0, 0, 0, + 0, 0, 577, 589, 623, 0, 633, 634, 636, 638, + 637, 640, 439, 440, 647, 0, 642, 643, 644, 641, + 375, 426, 445, 433, 0, 658, 518, 519, 659, 629, + 402, 0, 0, 533, 566, 555, 639, 521, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 337, 0, + 0, 370, 570, 552, 562, 553, 538, 539, 540, 547, + 349, 541, 542, 543, 513, 544, 514, 545, 546, 0, + 569, 520, 435, 386, 587, 586, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 228, 0, 0, 0, + 0, 0, 0, 310, 229, 515, 635, 517, 516, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 313, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 300, 442, 461, 311, 430, 474, 316, 438, 453, 306, + 401, 427, 0, 0, 302, 459, 437, 383, 360, 361, + 301, 0, 421, 335, 351, 332, 399, 0, 458, 486, + 331, 477, 0, 469, 304, 0, 468, 398, 455, 460, + 384, 377, 0, 303, 457, 382, 376, 364, 341, 502, + 365, 366, 355, 410, 374, 411, 356, 388, 387, 389, + 0, 0, 0, 0, 0, 497, 498, 0, 0, 646, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 628, 0, 0, 632, 0, 471, 0, 0, 0, + 0, 0, 0, 441, 0, 0, 367, 0, 0, 0, + 487, 0, 424, 404, 661, 0, 0, 422, 372, 456, + 412, 462, 443, 470, 418, 413, 294, 444, 334, 385, + 307, 309, 750, 336, 338, 342, 343, 394, 395, 407, + 429, 446, 447, 448, 333, 317, 423, 318, 353, 319, + 295, 325, 323, 326, 431, 327, 297, 408, 452, 0, + 348, 419, 380, 298, 379, 409, 451, 450, 308, 478, + 484, 485, 574, 0, 490, 662, 663, 664, 499, 0, + 414, 0, 504, 505, 506, 508, 509, 510, 511, 575, + 592, 559, 529, 492, 583, 526, 530, 531, 358, 595, + 0, 0, 0, 483, 368, 369, 0, 340, 339, 381, + 417, 299, 346, 291, 292, 657, 330, 400, 597, 630, + 631, 522, 0, 584, 523, 532, 322, 556, 568, 567, + 396, 482, 0, 579, 582, 512, 656, 0, 576, 591, + 660, 590, 653, 406, 0, 428, 588, 535, 0, 580, + 554, 0, 581, 550, 585, 0, 524, 0, 436, 464, + 476, 493, 496, 525, 610, 611, 612, 296, 495, 614, + 615, 616, 617, 618, 619, 620, 613, 467, 557, 534, + 560, 475, 537, 536, 0, 0, 571, 491, 572, 573, + 390, 391, 392, 393, 350, 598, 315, 494, 416, 0, + 558, 0, 0, 0, 0, 0, 0, 0, 0, 563, + 564, 561, 665, 0, 621, 622, 0, 0, 488, 489, + 345, 352, 507, 354, 314, 405, 347, 473, 362, 0, + 500, 565, 501, 624, 627, 625, 626, 397, 357, 359, + 432, 363, 373, 420, 472, 403, 425, 312, 463, 434, + 378, 551, 578, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 606, + 605, 604, 603, 602, 601, 600, 599, 0, 0, 548, + 449, 324, 285, 320, 321, 328, 654, 651, 454, 655, + 0, 293, 528, 371, 0, 415, 344, 593, 594, 0, + 645, 241, 242, 243, 244, 245, 246, 247, 248, 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, + 261, 262, 263, 264, 265, 596, 256, 257, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 401, 0, 0, 532, 565, 554, 638, 520, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 336, - 0, 0, 369, 569, 551, 561, 552, 537, 538, 539, - 546, 348, 540, 541, 542, 512, 543, 513, 544, 545, - 0, 568, 519, 434, 385, 586, 585, 0, 0, 0, + 0, 281, 282, 283, 284, 0, 0, 0, 479, 480, + 481, 503, 0, 465, 527, 652, 0, 0, 0, 0, + 0, 0, 0, 577, 589, 623, 0, 633, 634, 636, + 638, 637, 640, 439, 440, 647, 0, 642, 643, 644, + 641, 375, 426, 445, 433, 0, 658, 518, 519, 659, + 629, 402, 0, 0, 533, 566, 555, 639, 521, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 337, + 0, 0, 370, 570, 552, 562, 553, 538, 539, 540, + 547, 349, 541, 542, 543, 513, 544, 514, 545, 546, + 0, 569, 520, 435, 386, 587, 586, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 228, 0, 0, - 0, 0, 0, 0, 309, 229, 514, 634, 516, 515, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 312, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 299, 441, 460, 310, 429, 473, 315, 437, 452, - 305, 400, 426, 0, 0, 301, 458, 436, 382, 359, - 360, 300, 0, 420, 334, 350, 331, 398, 0, 457, - 485, 330, 476, 0, 468, 303, 0, 467, 397, 454, - 459, 383, 376, 0, 302, 456, 381, 375, 363, 340, - 501, 364, 365, 354, 409, 373, 410, 355, 387, 386, - 388, 0, 0, 0, 0, 0, 496, 497, 0, 0, - 645, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 627, 0, 0, 631, 0, 470, 0, 0, - 0, 0, 0, 0, 440, 0, 0, 366, 0, 0, - 0, 486, 0, 423, 403, 660, 0, 0, 421, 371, - 455, 411, 461, 442, 469, 706, 412, 294, 443, 333, - 384, 306, 308, 328, 335, 337, 341, 342, 393, 394, - 406, 428, 445, 446, 447, 332, 316, 422, 317, 352, - 318, 295, 324, 322, 325, 430, 326, 297, 407, 451, - 0, 347, 418, 379, 298, 378, 408, 450, 449, 307, - 477, 483, 484, 573, 0, 489, 661, 662, 663, 498, - 0, 413, 0, 503, 504, 505, 507, 508, 509, 510, - 574, 591, 558, 528, 491, 582, 525, 529, 530, 357, - 594, 0, 0, 0, 482, 367, 368, 0, 339, 338, - 380, 416, 345, 291, 292, 656, 329, 399, 596, 629, - 630, 521, 0, 583, 522, 531, 321, 555, 567, 566, - 395, 481, 0, 578, 581, 511, 655, 0, 575, 590, - 659, 589, 652, 405, 0, 427, 587, 534, 0, 579, - 553, 0, 580, 549, 584, 0, 523, 0, 435, 463, - 475, 492, 495, 524, 609, 610, 611, 296, 494, 613, - 614, 615, 616, 617, 618, 707, 612, 466, 556, 533, - 559, 474, 536, 535, 0, 0, 570, 490, 571, 572, - 389, 390, 391, 392, 349, 597, 314, 493, 415, 0, - 557, 0, 0, 0, 0, 0, 0, 0, 0, 562, - 563, 560, 664, 0, 620, 621, 0, 0, 487, 488, - 344, 351, 506, 353, 313, 404, 346, 472, 361, 0, - 499, 564, 500, 623, 626, 624, 625, 396, 356, 358, - 431, 362, 372, 419, 471, 402, 424, 311, 462, 433, - 377, 550, 577, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 280, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 605, - 604, 603, 602, 601, 600, 599, 598, 0, 0, 547, - 448, 323, 285, 319, 320, 327, 653, 650, 453, 654, - 0, 293, 527, 370, 0, 414, 343, 592, 593, 0, - 644, 241, 242, 243, 244, 245, 246, 247, 248, 286, - 249, 250, 251, 252, 253, 254, 255, 258, 259, 260, - 261, 262, 263, 264, 265, 595, 256, 257, 266, 267, - 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - 278, 279, 0, 0, 0, 287, 288, 289, 290, 0, - 0, 281, 282, 283, 284, 0, 0, 0, 478, 479, - 480, 502, 0, 464, 526, 651, 0, 0, 0, 0, - 0, 0, 0, 576, 588, 622, 0, 632, 633, 635, - 637, 636, 639, 438, 439, 646, 0, 641, 642, 643, - 640, 374, 425, 444, 432, 0, 657, 517, 518, 658, - 628, 728, 727, 734, 724, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 731, 732, 0, 733, 737, 0, - 0, 718, 2037, 0, 0, 728, 727, 734, 724, 0, - 0, 742, 0, 0, 0, 0, 0, 0, 731, 732, - 0, 733, 737, 0, 0, 718, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 742, 0, 0, 2039, 0, - 2037, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 746, 0, 0, - 748, 0, 0, 0, 0, 747, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 2039, 0, 0, 0, - 0, 0, 3839, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 2014, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 2014, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 2030, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 2037, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 3809, 0, 0, 0, 2030, 0, - 0, 0, 0, 0, 0, 719, 721, 720, 0, 0, - 0, 0, 0, 2039, 0, 0, 726, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 730, 719, - 721, 720, 0, 0, 0, 745, 0, 0, 0, 0, - 726, 0, 723, 0, 2018, 0, 0, 0, 0, 0, - 0, 0, 730, 0, 0, 2024, 0, 0, 0, 745, - 0, 0, 0, 0, 0, 0, 723, 2014, 0, 0, - 0, 0, 0, 0, 0, 2012, 2046, 0, 0, 2013, - 2015, 2017, 2018, 2019, 2020, 2021, 2025, 2026, 2027, 2029, - 2032, 2033, 2034, 2024, 0, 0, 0, 0, 0, 0, - 2022, 2031, 2023, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 2012, 2046, 0, 0, 2013, 2015, 2017, - 0, 2019, 2020, 2021, 2025, 2026, 2027, 2029, 2032, 2033, - 2034, 0, 0, 0, 0, 2030, 0, 2038, 2022, 2031, - 2023, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 725, 729, 735, 0, 736, 738, 0, 0, 739, 740, - 741, 0, 0, 743, 744, 2038, 0, 0, 0, 0, - 0, 0, 0, 0, 725, 729, 735, 2035, 736, 738, - 0, 0, 739, 740, 741, 0, 0, 743, 744, 0, + 0, 0, 0, 0, 310, 229, 515, 635, 517, 516, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 313, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 300, 442, 461, 311, 430, 474, 316, 438, 453, + 306, 401, 427, 0, 0, 302, 459, 437, 383, 360, + 361, 301, 0, 421, 335, 351, 332, 399, 0, 458, + 486, 331, 477, 0, 469, 304, 0, 468, 398, 455, + 460, 384, 377, 0, 303, 457, 382, 376, 364, 341, + 502, 365, 366, 355, 410, 374, 411, 356, 388, 387, + 389, 0, 0, 0, 0, 0, 497, 498, 0, 0, + 646, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 628, 0, 0, 632, 0, 471, 0, 0, + 0, 0, 0, 0, 441, 0, 0, 367, 0, 0, + 0, 487, 0, 424, 404, 661, 0, 0, 422, 372, + 456, 412, 462, 443, 470, 707, 413, 294, 444, 334, + 385, 307, 309, 329, 336, 338, 342, 343, 394, 395, + 407, 429, 446, 447, 448, 333, 317, 423, 318, 353, + 319, 295, 325, 323, 326, 431, 327, 297, 408, 452, + 0, 348, 419, 380, 298, 379, 409, 451, 450, 308, + 478, 484, 485, 574, 0, 490, 662, 663, 664, 499, + 0, 414, 0, 504, 505, 506, 508, 509, 510, 511, + 575, 592, 559, 529, 492, 583, 526, 530, 531, 358, + 595, 0, 0, 0, 483, 368, 369, 0, 340, 339, + 381, 417, 299, 346, 291, 292, 657, 330, 400, 597, + 630, 631, 522, 0, 584, 523, 532, 322, 556, 568, + 567, 396, 482, 0, 579, 582, 512, 656, 0, 576, + 591, 660, 590, 653, 406, 0, 428, 588, 535, 0, + 580, 554, 0, 581, 550, 585, 0, 524, 0, 436, + 464, 476, 493, 496, 525, 610, 611, 612, 296, 495, + 614, 615, 616, 617, 618, 619, 708, 613, 467, 557, + 534, 560, 475, 537, 536, 0, 0, 571, 491, 572, + 573, 390, 391, 392, 393, 350, 598, 315, 494, 416, + 0, 558, 0, 0, 0, 0, 0, 0, 0, 0, + 563, 564, 561, 665, 0, 621, 622, 0, 0, 488, + 489, 345, 352, 507, 354, 314, 405, 347, 473, 362, + 0, 500, 565, 501, 624, 627, 625, 626, 397, 357, + 359, 432, 363, 373, 420, 472, 403, 425, 312, 463, + 434, 378, 551, 578, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 280, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 606, 605, 604, 603, 602, 601, 600, 599, 0, 0, + 548, 449, 324, 285, 320, 321, 328, 654, 651, 454, + 655, 0, 293, 528, 371, 0, 415, 344, 593, 594, + 0, 645, 241, 242, 243, 244, 245, 246, 247, 248, + 286, 249, 250, 251, 252, 253, 254, 255, 258, 259, + 260, 261, 262, 263, 264, 265, 596, 256, 257, 266, + 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, + 277, 278, 279, 0, 0, 0, 287, 288, 289, 290, + 0, 0, 281, 282, 283, 284, 0, 0, 0, 479, + 480, 481, 503, 0, 465, 527, 652, 0, 0, 0, + 0, 0, 0, 0, 577, 589, 623, 0, 633, 634, + 636, 638, 637, 640, 439, 440, 647, 0, 642, 643, + 644, 641, 375, 426, 445, 433, 2038, 658, 518, 519, + 659, 629, 0, 206, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 3661, 0, 0, 0, + 0, 0, 2040, 0, 2038, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2040, 0, 2038, 0, 0, 0, 202, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 2015, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 2040, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 2015, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 2031, 0, 0, 0, 0, 0, + 0, 0, 2015, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 3810, 0, + 0, 0, 2031, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2031, 0, 0, 0, 0, 0, 0, 0, 2019, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 2025, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 2013, + 2047, 0, 0, 2014, 2016, 2018, 2019, 2020, 2021, 2022, + 2026, 2027, 2028, 2030, 2033, 2034, 2035, 2025, 0, 0, + 0, 0, 0, 0, 2023, 2032, 2024, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 2013, 2047, 0, + 0, 2014, 2016, 2018, 2019, 2020, 2021, 2022, 2026, 2027, + 2028, 2030, 2033, 2034, 2035, 2025, 0, 0, 0, 0, + 0, 2039, 2023, 2032, 2024, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 2013, 2047, 0, 0, 2014, + 2016, 2018, 0, 2020, 2021, 2022, 2026, 2027, 2028, 2030, + 2033, 2034, 2035, 0, 0, 0, 0, 0, 0, 2039, + 2023, 2032, 2024, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 2036, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 2012, + 0, 0, 0, 0, 0, 0, 2011, 2039, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2036, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 2029, 0, 0, 0, 0, 0, 0, 2012, 0, 2017, 0, 0, 0, 0, 2011, 0, 0, 0, 0, 0, - 0, 2010, 0, 0, 0, 0, 0, 0, 0, 2018, - 0, 0, 0, 0, 0, 2035, 0, 0, 0, 0, - 2024, 0, 0, 0, 0, 2028, 0, 0, 0, 0, - 0, 0, 2011, 0, 2016, 0, 0, 0, 0, 2010, - 2012, 2046, 0, 0, 2013, 2015, 2017, 0, 2019, 2020, - 2021, 2025, 2026, 2027, 2029, 2032, 2033, 2034, 0, 0, - 0, 0, 0, 2028, 0, 2022, 2031, 2023, 0, 0, - 0, 0, 2016, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 2038, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 722, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 2036, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 2029, 0, + 0, 0, 0, 0, 0, 2012, 0, 2017, 0, 0, + 0, 0, 2011, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 722, 0, 0, 0, 0, 0, 0, - 0, 0, 2035, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 2011, - 0, 0, 0, 0, 0, 0, 2010, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 2029, 0, 0, 0, + 0, 0, 0, 0, 0, 2017, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 2028, 0, 0, 0, 0, 0, 0, 0, 0, 2016, + 0, 0, 0, 0, 0, 0, 0, 169, } var yyPact = [...]int{ - 4265, -1000, -1000, -1000, -337, 15446, -1000, -1000, -1000, -1000, + 4192, -1000, -1000, -1000, -336, 15736, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, 49398, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, 49741, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, 477, 49398, -333, 30838, 47478, -1000, -1000, 2849, -1000, - 48118, 17386, 49398, 563, 547, 49398, -1000, -1000, -1000, -1000, + -1000, 479, 49741, -333, 31152, 47818, -1000, -1000, 2910, -1000, + 48459, 17679, 49741, 558, 555, 49741, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, 989, -1000, 53878, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, 883, 5377, 53238, 11579, - -219, -1000, 1601, -37, 2745, 509, -205, -211, 1158, 1167, - 1373, 1043, 49398, 1130, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, 271, 1037, 48758, + -1000, -1000, -1000, -1000, 1019, -1000, 54228, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, 923, 5408, 53587, 11863, + -217, -1000, 1647, -36, 2760, 508, -201, -205, 1192, 1218, + 1204, 1166, 49741, 1152, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, 247, 1060, 49100, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, 267, 256, 988, 1037, 22514, 129, - 127, 1601, 468, -83, 331, -1000, 1737, 4305, 198, -1000, + -1000, -1000, -1000, -1000, 241, 260, 1017, 1060, 22815, 122, + 118, 1647, 457, -72, 209, -1000, 1955, 4372, 199, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - 11579, 11579, 15446, -372, 15446, 11579, 49398, 49398, -1000, -1000, - -1000, -1000, -333, 48118, 883, 5377, 11579, 2745, 509, -205, - -211, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + 11863, 11863, 15736, -384, 15736, 11863, 49741, 49741, -1000, -1000, + -1000, -1000, -333, 48459, 923, 5408, 11863, 2760, 508, -201, + -205, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -83, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -72, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, @@ -7351,7 +7379,7 @@ var yyPact = [...]int{ -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, 127, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, 118, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, @@ -7369,426 +7397,426 @@ var yyPact = [...]int{ -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, 5383, -1000, 1741, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 5177, -1000, + 1726, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, 2477, 3263, 1725, 2759, + 862, 47818, 49741, -1000, 144, 862, -1000, -1000, -1000, 1647, + 3628, -1000, 49741, 49741, 207, 2029, -1000, 551, 519, 395, + 538, 379, 1720, -1000, -1000, -1000, -1000, -1000, -1000, 789, + 3610, -1000, 49741, 49741, 3277, 49741, -1000, 2453, 828, -1000, + 5600, 3427, 1434, 1023, 3287, -1000, -1000, 3262, -1000, 384, + 408, 244, 786, 468, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, 334, -1000, 3497, -1000, -1000, 365, -1000, -1000, 338, + -1000, -1000, -1000, 113, -1000, -1000, -1000, -1000, -1000, -1000, + 2, -1000, -1000, 1265, 2092, 11863, 2016, -1000, 2972, 1731, + -1000, -1000, -1000, 7349, 14439, 14439, 14439, 14439, 49741, -1000, + -1000, 3109, 11863, 3259, 3258, 3253, 3251, -1000, -1000, -1000, + -1000, -1000, -1000, 3249, 1708, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, 2137, -1000, -1000, -1000, 15083, -1000, + 3248, 3247, 3245, 3244, 3241, 3239, 3238, 3236, 3234, 3233, + 3232, 3230, 3229, 3228, 2954, 17028, 3219, 2757, 2754, 3218, + 3217, 3212, 2751, 3211, 3208, 3207, 2954, 2954, 3203, 3201, + 3200, 3199, 3197, 3195, 3192, 3188, 3184, 3181, 3179, 3178, + 3177, 3176, 3171, 3170, 3169, 3167, 3166, 3165, 3164, 3160, + 3159, 3158, 3157, 3136, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, 2494, 3220, 1740, 2740, 849, - 47478, 49398, -1000, 148, 849, -1000, -1000, -1000, 1601, 3579, - -1000, 49398, 49398, 206, 1995, -1000, 478, 411, 389, 436, - 366, 1738, -1000, -1000, -1000, -1000, -1000, -1000, 764, 3545, - -1000, 49398, 49398, 3232, 49398, -1000, 2478, 813, -1000, 54528, - 3390, 1597, 986, 3240, -1000, -1000, 3217, -1000, 377, 607, - 296, 464, 476, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - 351, -1000, 3456, -1000, -1000, 352, -1000, -1000, 344, -1000, - -1000, -1000, 119, -1000, -1000, -1000, -1000, -1000, -1000, -15, - -1000, -1000, 1218, 2290, 11579, 2113, -1000, 2916, 1705, -1000, - -1000, -1000, 7072, 14151, 14151, 14151, 14151, 49398, -1000, -1000, - 3115, 11579, 3211, 3210, 3200, 3199, -1000, -1000, -1000, -1000, - -1000, -1000, 3196, 1735, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, 2187, -1000, -1000, -1000, 14794, -1000, 3195, - 3194, 3193, 3192, 3191, 3190, 3189, 3187, 3186, 3184, 3182, - 3181, 3177, 3176, 2954, 16736, 3175, 2738, 2737, 3174, 3173, - 3172, 2734, 3171, 3170, 3169, 2954, 2954, 3168, 3167, 3164, - 3163, 3159, 3158, 3156, 3154, 3153, 3152, 3151, 3150, 3149, - 3147, 3146, 3145, 3144, 3142, 3141, 3140, 3139, 3138, 3134, - 3130, 3128, 3127, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 1686, -1000, + 3125, 3622, 2994, -1000, 3460, 3458, 3456, 3450, -263, 3124, + 2381, -1000, -1000, 104, 3609, 49741, -283, 49741, 429, -80, + -84, -85, -1000, -66, -1000, -1000, 1174, -1000, 1138, 52946, + 985, -1000, -1000, 49741, 920, 920, 920, 49741, 228, 963, + 920, 920, 920, 920, 920, 939, 920, 3521, 1012, 1009, + 1007, 1006, 920, -34, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, 2028, 2025, 3358, 1126, -1000, -1000, -1000, -1000, 1590, + 49741, -1000, 3057, 429, -317, 1836, 1836, 3587, 3587, 3519, + 3517, 836, 822, 815, 1836, 646, -1000, 1958, 1958, 1958, + 1958, 1836, 515, 834, 3526, 3526, 187, 1958, 86, 1836, + 1836, 86, 1836, 1836, -1000, 1996, 292, -271, -1000, -1000, + -1000, -1000, 1958, 1958, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, 3492, 3490, 923, 923, 49741, 923, 227, 49741, 923, + 923, 923, 49741, 928, -324, 62, 52305, 51664, 2169, 2453, + 826, 803, 1593, 1970, -1000, 1852, 49741, 49741, 1852, 1852, + 26024, 25383, -1000, 49741, -1000, 3622, 2994, 2923, 1763, 2913, + 2994, -87, 429, 923, 923, 923, 923, 923, 327, 923, + 923, 923, 923, 923, 49741, 49741, 47177, 923, 923, 923, + 923, 9925, 1955, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, 15736, 2046, 2235, 196, + -9, -314, 279, -1000, -1000, 49741, 3401, 324, -1000, -1000, + -1000, 3020, -1000, 3053, 3053, 3053, 3053, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, 3053, 3053, 3056, + 3119, -1000, -1000, 3025, 3025, 3025, 3020, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, 1393, -1000, 3126, - 3549, 3018, -1000, 3441, 3439, 3437, 3430, -271, 3125, 2413, - -1000, -1000, 105, 3544, 49398, -290, 49398, 421, -89, -98, - -102, -1000, -78, -1000, -1000, 1147, -1000, 1116, 52598, 938, - -1000, -1000, 49398, 882, 882, 882, 49398, 302, 991, 882, - 882, 882, 882, 882, 951, 882, 3477, 985, 984, 981, - 975, 882, -46, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - 1986, 1974, 3304, 1092, -1000, -1000, -1000, -1000, 1503, 49398, - -1000, 3060, 421, -316, 1851, 1851, 3526, 3526, 3476, 3468, - 826, 824, 820, 1851, 647, -1000, 1912, 1912, 1912, 1912, - 1851, 525, 818, 3464, 3464, 152, 1912, 93, 1851, 1851, - 93, 1851, 1851, -1000, 1905, 349, -278, -1000, -1000, -1000, - -1000, 1912, 1912, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - 3451, 3448, 883, 883, 49398, 883, 216, 49398, 883, 883, - 883, 49398, 889, -324, 70, 51958, 51318, 2623, 2478, 806, - 804, 1554, 1925, -1000, 1909, 49398, 49398, 1909, 1909, 25718, - 25078, -1000, 49398, -1000, 3549, 3018, 2945, 1873, 2943, 3018, - -104, 421, 883, 883, 883, 883, 883, 309, 883, 883, - 883, 883, 883, 49398, 49398, 46838, 883, 883, 883, 883, - 9644, 1737, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, 15446, 2182, 2203, 197, -13, - -312, 265, -1000, -1000, 49398, 3360, 308, -1000, -1000, -1000, - 3045, -1000, 3054, 3054, 3054, 3054, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, 3054, 3054, 3058, 3123, - -1000, -1000, 3053, 3053, 3053, 3045, -1000, -1000, -1000, -1000, + -1000, -1000, 3054, 3054, 3055, 3055, 3054, 49741, -123, -1000, + -1000, 11863, 49741, 3411, 403, 3117, 862, -1000, -1000, 49741, + 318, 411, 3622, 3410, 3526, 3573, -1000, -1000, 1702, 2380, + 2741, -1000, 379, -1000, 539, 379, -1000, 437, 437, 1879, + -1000, 1240, -1000, -1000, -1000, -1000, -1000, -1000, 49741, 2, + 502, -1000, -1000, 2707, 3115, -1000, 655, 1421, 1588, -1000, + 627, 4845, 40126, 2453, 40126, 49741, -1000, -1000, -1000, -1000, + -1000, -1000, 111, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, 3055, 3055, 3056, 3056, 3055, 49398, -124, -1000, -1000, - 11579, 49398, 3385, 410, 3122, 849, -1000, -1000, 49398, 320, - 437, 3549, 3384, 3464, 3518, -1000, -1000, 1724, 2410, 2733, - -1000, 366, -1000, 443, 366, -1000, 495, 495, 1878, -1000, - 1205, -1000, -1000, -1000, -1000, -1000, -1000, 49398, -15, 469, - -1000, -1000, 2710, 3120, -1000, 637, 1440, 1420, -1000, 339, - 54552, 39798, 2478, 39798, 49398, -1000, -1000, -1000, -1000, -1000, - -1000, 114, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, 343, -1000, 11863, + 11863, 11863, 11863, 11863, -1000, 813, 13795, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, 14439, 14439, 14439, 14439, 14439, 14439, + 14439, 14439, 14439, 14439, 14439, 14439, 3108, 1941, 14439, 14439, + 14439, 14439, 27947, 1763, 3193, 1592, 317, 1731, 1731, 1731, + 1731, 11863, -1000, 1978, 2092, 11863, 11863, 11863, 11863, 34357, + 49741, -1000, -1000, 4280, 11863, 11863, 4247, 11863, 3447, 11863, + 11863, 11863, 2911, 6052, 49741, 11863, -1000, 2908, 2906, -1000, + -1000, 2143, 11863, -1000, -1000, 11863, -1000, -1000, 11863, 14439, + 11863, -1000, 11863, 11863, 11863, -1000, -1000, 628, 3447, 3447, + 3447, 1903, 11863, 11863, 3447, 3447, 3447, 1895, 3447, 3447, + 3447, 3447, 3447, 3447, 3447, 3447, 3447, 3447, 3447, 2905, + 2903, 2902, 11219, 3526, -217, -1000, 9281, 3410, 3526, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -265, + 3111, 49741, 2739, 2734, -346, 186, 485, 49741, 1230, -1000, + -1000, 49741, 2364, 49741, 2360, 52, 1167, 1145, 1148, -1000, + -1000, 49741, 51023, -1000, 49741, 2053, 49741, 49741, 3442, -1000, + 49741, 49741, 920, 920, 920, -1000, 45254, 40126, 49741, 49741, + 2453, 49741, 49741, 49741, 920, 920, 920, 920, 49741, -1000, + 3368, 40126, 3363, 928, -1000, 49741, 1590, 3440, 49741, -1000, + -1000, -1000, -1000, 3587, 14439, 14439, -1000, -1000, 11863, -1000, + 294, 46536, 1958, 1836, 1836, -1000, -1000, 49741, -1000, -1000, + -1000, 1958, 49741, 1958, 1958, 3587, 1958, -1000, -1000, -1000, + 1836, 1836, -1000, -1000, 11863, -1000, -1000, 1958, 1958, -1000, + -1000, 3587, 49741, 103, 3587, 3587, 100, -1000, -1000, -1000, + 1836, 49741, 49741, 920, 49741, -1000, 49741, 49741, -1000, -1000, + 49741, 49741, 4661, 49741, 45254, 45895, 3487, -1000, 40126, 49741, + 49741, 1581, -1000, 979, 37562, -1000, 49741, 1516, -1000, 36, + -1000, 31, 62, 1852, 62, 1852, 978, -1000, 645, 788, + 24101, 587, 40126, 6696, -1000, -1000, 1852, 1852, 6696, 6696, + 1740, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 1579, -1000, + 339, 3526, -1000, -1000, -1000, -1000, -1000, 2359, -1000, 49741, + 45254, 40126, 2453, 49741, 923, 49741, 49741, 49741, 49741, 49741, + -1000, 3110, 1701, -1000, 3422, 49741, 49741, 49741, 49741, 1584, + -1000, -1000, 20884, 1675, -1000, -1000, 2058, -1000, 11863, 15736, + -250, 11863, 15736, 15736, 11863, 15736, -1000, 11863, 309, -1000, + -1000, -1000, -1000, 2358, -1000, 2352, -1000, -1000, -1000, -1000, + -1000, 2729, 2729, -1000, 2351, -1000, -1000, -1000, -1000, 2349, + -1000, -1000, 2348, -1000, -1000, -1000, -1000, -158, 2900, 1265, + -1000, 2724, 3286, -218, -1000, 22174, 49741, 49741, 403, -356, + 2013, 2009, 1994, 3503, -1000, -218, -1000, 21529, 49741, 3526, + -1000, -221, 3410, 11863, 49741, -1000, 3512, -1000, -1000, 379, + -1000, -1000, -1000, 437, 466, -1000, -1000, -1000, -1000, -1000, + -1000, 1659, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -73, -76, 1578, -1000, 49741, -1000, -1000, + 627, 40126, 42049, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + 269, -1000, -1000, 172, -1000, 974, 256, 1878, -1000, -1000, + 234, 210, 218, 1047, 2092, -1000, 2050, 2050, 2072, -1000, + 758, -1000, -1000, -1000, -1000, 3109, -1000, -1000, -1000, 2239, + 2138, -1000, 1905, 1905, 1753, 1753, 1753, 1753, 1753, 1962, + 1962, -1000, -1000, -1000, 7349, 3108, 14439, 14439, 14439, 14439, + 998, 998, 2416, 3596, -1000, -1000, -1000, -1000, 11863, 182, + 2057, -1000, 11863, 2691, 1727, 2491, 1468, 1876, -1000, 3020, + 11863, 1648, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, 338, -1000, 11579, 11579, - 11579, 11579, 11579, -1000, 772, 13508, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, 14151, 14151, 14151, 14151, 14151, 14151, 14151, - 14151, 14151, 14151, 14151, 14151, 3114, 2007, 14151, 14151, 14151, - 14151, 27638, 1873, 3064, 1511, 310, 1705, 1705, 1705, 1705, - 11579, -1000, 2024, 2290, 11579, 11579, 11579, 11579, 34038, 49398, - -1000, -1000, 4648, 11579, 11579, 4527, 11579, 3411, 11579, 11579, - 11579, 2942, 5777, 49398, 11579, -1000, 2941, 2939, -1000, -1000, - 2198, 11579, -1000, -1000, 11579, -1000, -1000, 11579, 14151, 11579, - -1000, 11579, 11579, 11579, -1000, -1000, 3888, 3411, 3411, 3411, - 1956, 11579, 11579, 3411, 3411, 3411, 1889, 3411, 3411, 3411, - 3411, 3411, 3411, 3411, 3411, 3411, 3411, 3411, 2938, 2937, - 2935, 10936, 3464, -219, -1000, 9001, 3384, 3464, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -273, 3119, - 49398, 2732, 2726, -349, 180, 471, 49398, 1211, -1000, -1000, - 49398, 2398, 49398, 2397, 61, 1146, 1118, 1124, -1000, -1000, - 49398, 50678, -1000, 49398, 2042, 49398, 49398, 3402, -1000, 49398, - 49398, 882, 882, 882, -1000, 44918, 39798, 49398, 49398, 2478, - 49398, 49398, 49398, 882, 882, 882, 882, 49398, -1000, 3343, - 39798, 3314, 889, -1000, 49398, 1503, 3399, 49398, -1000, -1000, - -1000, -1000, 3526, 14151, 14151, -1000, -1000, 11579, -1000, 260, - 46198, 1912, 1851, 1851, -1000, -1000, 49398, -1000, -1000, -1000, - 1912, 49398, 1912, 1912, 3526, 1912, -1000, -1000, -1000, 1851, - 1851, -1000, -1000, 11579, -1000, -1000, 1912, 1912, -1000, -1000, - 3526, 49398, 113, 3526, 3526, 95, -1000, -1000, -1000, 1851, - 49398, 49398, 882, 49398, -1000, 49398, 49398, -1000, -1000, 49398, - 49398, 4698, 49398, 44918, 45558, 3447, -1000, 39798, 49398, 49398, - 1502, -1000, 937, 37238, -1000, 49398, 1435, -1000, 38, -1000, - 56, 70, 1909, 70, 1909, 931, -1000, 635, 634, 23798, - 568, 39798, 6420, -1000, -1000, 1909, 1909, 6420, 6420, 1715, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, 1490, -1000, 283, - 3464, -1000, -1000, -1000, -1000, -1000, 2396, -1000, 49398, 44918, - 39798, 2478, 49398, 883, 49398, 49398, 49398, 49398, 49398, -1000, - 3116, 1704, -1000, 3389, 49398, 49398, 49398, 49398, 1376, -1000, - -1000, 20586, 1703, -1000, -1000, 2014, -1000, 11579, 15446, -242, - 11579, 15446, 15446, 11579, 15446, -1000, 11579, 287, -1000, -1000, - -1000, -1000, 2388, -1000, 2385, -1000, -1000, -1000, -1000, -1000, - 2725, 2725, -1000, 2384, -1000, -1000, -1000, -1000, 2382, -1000, - -1000, 2381, -1000, -1000, -1000, -1000, -161, 2920, 1218, -1000, - 2724, 3239, -220, -1000, 21874, 49398, 49398, 410, -354, 1973, - 1972, 1971, 3460, -1000, -220, -1000, 21230, 49398, 3464, -1000, - -224, 3384, 11579, 49398, -1000, 3467, -1000, -1000, 366, -1000, - -1000, -1000, 495, 557, -1000, -1000, -1000, -1000, -1000, -1000, - 1686, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -84, -100, 1484, -1000, 49398, -1000, -1000, 339, - 39798, 41718, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 275, - -1000, -1000, 181, -1000, 930, 251, 1872, -1000, -1000, 222, - 214, 212, 1028, 2290, -1000, 2034, 2034, 2066, -1000, 923, - -1000, -1000, -1000, -1000, 3115, -1000, -1000, -1000, 2521, 2118, - -1000, 1913, 1913, 1706, 1706, 1706, 1706, 1706, 1961, 1961, - -1000, -1000, -1000, 7072, 3114, 14151, 14151, 14151, 14151, 974, - 974, 3950, 3637, -1000, -1000, -1000, -1000, 11579, 182, 2011, - -1000, 11579, 2652, 1716, 2477, 1451, 1834, -1000, 3045, 11579, - 1683, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, 2895, 2893, 2747, 3608, 2892, 11863, -1000, -1000, + 1864, 1861, 1860, -1000, 2342, 10575, -1000, -1000, -1000, 2891, + 1643, 2889, -1000, -1000, -1000, 2886, 1835, 1307, 2878, 1413, + 2877, 2865, 2864, 2863, 1572, 11863, 11863, 11863, 11863, 2858, + 1827, 1823, 11863, 11863, 11863, 11863, 2857, 11863, 11863, 11863, + 11863, 11863, 11863, 11863, 11863, 11863, 11863, 49741, 145, 145, + 145, 1571, 1570, -1000, -1000, 1821, -1000, 2092, -1000, -1000, + 3410, -1000, 3107, 2347, 1565, -1000, -1000, -330, 2642, 49741, + 49741, 185, 49741, 2719, -284, 49741, -1000, -1000, 2710, -1000, + -1000, -1000, 1188, 1133, 1143, -1000, 49741, -1000, 2709, 3415, + 3509, 905, 49741, 3106, 3100, 49741, 49741, 49741, 295, -1000, + -1000, 1378, -1000, 256, -8, 570, 1299, 3276, 884, -125, + 49741, 49741, 49741, 49741, 3439, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, 44613, -1000, 3098, 1819, -1000, -1000, 1731, + 1731, 2092, 49741, 49741, 49741, 3275, 49741, 49741, 3587, 3587, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, 1958, 3587, 3587, + 1696, 1836, 1958, -1000, -1000, 1958, -356, -1000, 1958, -1000, + -356, 1642, -356, 49741, -1000, -1000, -1000, 3438, 3057, 1561, + -1000, -1000, -1000, 3572, 1600, 897, 897, 1134, 892, 3570, + 19602, -1000, 1912, 1290, 961, 3387, 381, -1000, 1912, -155, + 864, 1912, 1912, 1912, 1912, 1912, 1912, 1912, 781, 770, + 1912, 1912, 1912, 1912, 1912, 1912, 1912, 1912, 1912, 1912, + 1912, 1211, 1912, 1912, 1912, 1912, 1912, -1000, 1912, 3095, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, 820, 735, 293, + 3481, 430, -1000, 438, 1378, 650, 3480, 467, 49741, 49741, + 3850, 1358, -1000, -1000, -1000, -1000, -1000, 28588, 28588, 23460, + 28588, -1000, 177, 1852, 62, 43, -1000, -1000, 1516, 6696, + 1516, 6696, 2343, -1000, -1000, 958, -1000, -1000, 1299, -1000, + 49741, 49741, -1000, -1000, 3094, 1993, -1000, -1000, 17028, -1000, + 6696, 6696, -1000, -1000, 30511, 49741, -1000, -3, -1000, 11, + 3410, -1000, 1277, -1000, -1000, 1510, 1299, 3285, 49741, 1277, + 1277, 1277, -1000, -1000, 18320, 49741, 49741, -1000, -1000, -1000, + -295, 3587, 9925, -1000, 37562, -1000, -1000, 43972, -1000, 43331, + 1999, -1000, 15736, 2222, 197, -1000, 275, -318, 193, 2014, + 190, 2092, -1000, -1000, 2855, 2854, 1817, -1000, 1811, 2853, + 1810, 1807, 2329, -1000, 81, -1000, 3403, 1330, -1000, 3087, + -1000, 1796, 3351, -1000, 1504, -1000, 1990, 1785, -1000, -1000, + -1000, 11863, 42690, 11863, 1107, 1330, 1783, 3350, 1504, 3410, + 2700, -1000, 1501, -1000, 2156, 1641, 194, -1000, -1000, -1000, + 49741, 2707, 1779, 42049, 1406, -1000, 946, 1624, 1621, -1000, + 40126, 375, 40126, -1000, 40126, -1000, -1000, 426, -1000, 49741, + 3409, -1000, -1000, -1000, 2642, 1989, -355, 49741, -1000, -1000, + -1000, -1000, -1000, 1778, -1000, 998, 998, 2416, 2926, -1000, + 14439, -1000, 14439, 3112, -1000, 1965, -1000, 11863, 2146, 4284, + 11863, 4284, 950, 27306, 34357, -105, 3408, 3092, 49741, -1000, + -1000, 11863, 11863, -1000, 3074, -1000, -1000, -1000, -1000, 11863, + 11863, 2356, -1000, 49741, -1000, -1000, -1000, -1000, 27306, -1000, + 14439, -1000, -1000, -1000, -1000, 11863, 1478, 1478, 3050, 1765, + 145, 145, 145, 3016, 3012, 2943, 1760, 145, 2919, 2844, + 2840, 2832, 2793, 2784, 2708, 2703, 2646, 2639, 1732, -1000, + 3086, -1000, -1000, 2129, 13151, 9281, -1000, -1000, 321, 1485, + 2326, 2699, 121, -1000, 1976, -1000, 2694, 49741, 49741, 1173, + -1000, 49741, 3606, -1000, -1000, -1000, -1000, 1130, -1000, 2692, + -1000, 250, 249, 2166, 330, 1316, 18320, 3057, 3083, 3057, + 150, 1912, 653, 40126, 800, -1000, 49741, 2140, 1975, 3284, + 1183, 3400, 49741, 49741, 3082, 425, 3077, 3076, 3436, 556, + 5361, 49741, 1393, -1000, 1616, 4372, -1000, 49741, -1000, -1000, + 49741, -1000, 2453, -1000, 1836, -1000, -1000, 3587, -1000, -1000, + 11863, 11863, 3587, 1836, 1836, -1000, 1958, -1000, 49741, -1000, + -356, 556, 5361, 3430, 5036, 723, 2631, -1000, 49741, -1000, + -1000, -1000, 846, -1000, 1123, 920, 49741, 2106, 1123, 2104, + 3061, -1000, -1000, 49741, 49741, 49741, 49741, -1000, -1000, 49741, + -1000, 49741, 49741, 49741, 49741, 49741, 41408, -1000, 49741, 49741, + -1000, 49741, 2101, 49741, 2097, 888, -1000, 1912, 1912, 1084, + -1000, -1000, 629, -1000, 41408, 2321, 2317, 2316, 2309, 2690, + 2685, 2680, 1912, 1912, 2308, 2679, 40767, 2677, 1318, 2305, + 2296, 2295, 2320, 2676, 1247, -1000, 2666, 2314, 2313, 2306, + 49741, 3059, 2545, -1000, -1000, 2166, 150, 1912, 406, 49741, + 1974, 1956, 653, 593, 593, 565, -23, 24742, -1000, -1000, + -1000, 49741, 37562, 37562, 37562, 37562, 37562, 37562, -1000, 3327, + 3304, 3058, -1000, 3311, 3302, 3318, 3326, 3080, 49741, 37562, + 3057, -1000, 40767, -1000, -1000, -1000, 1763, 1729, 3539, 1115, + 11863, 6696, -1000, -1000, 24, 26, -1000, -1000, -1000, -1000, + 40126, 2665, 587, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + 3506, 49741, 49741, 913, 2851, 1482, -1000, -1000, -1000, 5361, + 3053, 3053, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, 3053, 3053, 3056, -1000, -1000, 3025, 3025, 3025, 3020, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, 2908, 2907, 2285, 3539, 2905, 11579, -1000, -1000, 1833, - 1832, 1826, -1000, 2341, 10293, -1000, -1000, -1000, 2902, 1676, - 2895, -1000, -1000, -1000, 2888, 1824, 1404, 2886, 1489, 2884, - 2875, 2872, 2871, 1483, 11579, 11579, 11579, 11579, 2869, 1822, - 1815, 11579, 11579, 11579, 11579, 2868, 11579, 11579, 11579, 11579, - 11579, 11579, 11579, 11579, 11579, 11579, 49398, 121, 121, 121, - 1464, 1452, -1000, -1000, 1811, -1000, 2290, -1000, -1000, 3384, - -1000, 3113, 2380, 1446, -1000, -1000, -329, 2630, 49398, 49398, - 178, 49398, 2722, -292, 49398, -1000, -1000, 2713, -1000, -1000, - -1000, 1141, 1109, 1114, -1000, 49398, -1000, 2712, 3376, 3466, - 971, 49398, 3106, 3103, 49398, 49398, 49398, 298, -1000, -1000, - 1340, -1000, 251, -27, 577, 1232, 3230, 886, -125, 49398, - 49398, 49398, 49398, 3398, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, 44278, -1000, 3102, 1806, -1000, -1000, 1705, 1705, - 2290, 49398, 49398, 49398, 3229, 49398, 49398, 3526, 3526, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, 1912, 3526, 3526, 1711, - 1851, 1912, -1000, -1000, 1912, -354, -1000, 1912, -1000, -354, - 1663, -354, 49398, -1000, -1000, -1000, 3397, 3060, 1441, -1000, - -1000, -1000, 3515, 1469, 870, 870, 1089, 768, 3511, 19306, - -1000, 1818, 1289, 927, 3348, 374, -1000, 1818, -154, 852, - 1818, 1818, 1818, 1818, 1818, 1818, 1818, 758, 755, 1818, - 1818, 1818, 1818, 1818, 1818, 1818, 1818, 1818, 1818, 1818, - 1163, 1818, 1818, 1818, 1818, 1818, -1000, 1818, 3099, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, 789, 700, 295, 3445, - 417, -1000, 429, 1340, 672, 3444, 473, 49398, 49398, 3219, - 1357, -1000, -1000, -1000, -1000, -1000, 28278, 28278, 23158, 28278, - -1000, 207, 1909, 70, 49, -1000, -1000, 1435, 6420, 1435, - 6420, 2368, -1000, -1000, 926, -1000, -1000, 1232, -1000, 49398, - 49398, -1000, -1000, 3098, 1969, -1000, -1000, 16736, -1000, 6420, - 6420, -1000, -1000, 30198, 49398, -1000, -16, -1000, 4, 3384, - -1000, 1225, -1000, -1000, 1433, 1232, 3238, 49398, 1225, 1225, - 1225, -1000, -1000, 18026, 49398, 49398, -1000, -1000, -1000, -301, - 3526, 9644, -1000, 37238, -1000, -1000, 43638, -1000, 42998, 2006, - -1000, 15446, 2193, 194, -1000, 258, -314, 189, 2106, 188, - 2290, -1000, -1000, 2867, 2863, 1804, -1000, 1790, 2860, 1781, - 1779, 2365, -1000, 87, -1000, 3363, 1239, -1000, 3097, -1000, - 1777, 3300, -1000, 1431, -1000, 1967, 1768, -1000, -1000, -1000, - 11579, 42358, 11579, 1070, 1239, 1767, 3298, 1431, 3384, 2711, - -1000, 1424, -1000, 2297, 1654, 200, -1000, -1000, -1000, 49398, - 2710, 1725, 41718, 1318, -1000, 921, 1650, 1642, -1000, 39798, - 333, 39798, -1000, 39798, -1000, -1000, 413, -1000, 49398, 3368, - -1000, -1000, -1000, 2630, 1966, -352, 49398, -1000, -1000, -1000, - -1000, -1000, 1713, -1000, 974, 974, 3950, 1935, -1000, 14151, - -1000, 14151, 3019, -1000, 2004, -1000, 11579, 2172, 5131, 11579, - 5131, 970, 26998, 34038, -109, 3373, 3005, 49398, -1000, -1000, - 11579, 11579, -1000, 3001, -1000, -1000, -1000, -1000, 11579, 11579, - 2233, -1000, 49398, -1000, -1000, -1000, -1000, 26998, -1000, 14151, - -1000, -1000, -1000, -1000, 11579, 1334, 1334, 2995, 1709, 121, - 121, 121, 2955, 2885, 2862, 1701, 121, 2816, 2812, 2753, - 2706, 2695, 2636, 2624, 2620, 2613, 2603, 1699, -1000, 3090, - -1000, -1000, 2132, 12865, 9001, -1000, -1000, 346, 1414, 2363, - 2707, 132, -1000, 1965, -1000, 2705, 49398, 49398, 1131, -1000, - 49398, 3537, -1000, -1000, -1000, -1000, 1106, -1000, 2698, -1000, - 321, 290, 2241, 319, 1234, 18026, 3060, 3089, 3060, 154, - 1818, 630, 39798, 782, -1000, 49398, 2185, 1964, 3236, 845, - 3358, 49398, 49398, 3088, 438, 3086, 3082, 3396, 537, 5535, - 49398, 1356, -1000, 1609, 4305, -1000, 49398, -1000, -1000, 49398, - -1000, 2478, -1000, 1851, -1000, -1000, 3526, -1000, -1000, 11579, - 11579, 3526, 1851, 1851, -1000, 1912, -1000, 49398, -1000, -354, - 537, 5535, 3395, 4990, 794, 2947, -1000, 49398, -1000, -1000, - -1000, 925, -1000, 1094, 882, 49398, 2100, 1094, 2096, 3068, - -1000, -1000, 49398, 49398, 49398, 49398, -1000, -1000, 49398, -1000, - 49398, 49398, 49398, 49398, 49398, 41078, -1000, 49398, 49398, -1000, - 49398, 2094, 49398, 2089, 1054, -1000, 1818, 1818, 1063, -1000, - -1000, 624, -1000, 41078, 2361, 2359, 2351, 2349, 2689, 2672, - 2670, 1818, 1818, 2348, 2667, 40438, 2665, 1308, 2340, 2328, - 2325, 2315, 2664, 1260, -1000, 2662, 2287, 2281, 2280, 49398, - 3062, 2547, -1000, -1000, 2241, 154, 1818, 415, 49398, 1960, - 1943, 630, 602, 602, 570, -29, 24438, -1000, -1000, -1000, - 49398, 37238, 37238, 37238, 37238, 37238, 37238, -1000, 3275, 3257, - 3061, -1000, 3267, 3260, 3274, 3271, 3244, 49398, 37238, 3060, - -1000, 40438, -1000, -1000, -1000, 1873, 1696, 3564, 1055, 11579, - 6420, -1000, -1000, 12, 15, -1000, -1000, -1000, -1000, 39798, - 2654, 568, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 3465, - 49398, 49398, 898, 2859, 1403, -1000, -1000, -1000, 5535, 3054, - 3054, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - 3054, 3054, 3058, -1000, -1000, 3053, 3053, 3053, 3045, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 3055, - 3055, 3056, 3056, 3055, -1000, -1000, -1000, -1000, 3524, -1000, - 1394, -1000, -1000, 1582, -1000, 1968, -339, 15446, 2016, 1746, - -1000, 11579, 15446, 11579, -245, 396, -253, -1000, -1000, -1000, - 2653, -1000, -1000, -1000, 2320, -1000, 2307, -1000, 173, 190, - 2084, -220, 9001, 463, 49398, -220, 49398, 9001, -1000, 49398, - 174, -360, -361, 170, 2651, 457, -220, 3465, 87, 11579, - 3345, -1000, -1000, 49398, 2295, -1000, -1000, -1000, 3535, 39798, - 2478, 1763, 39158, -1000, 335, -1000, 270, 609, 2650, -1000, - 966, 122, 2633, 2630, -1000, -1000, -1000, -1000, 14151, 1705, - -1000, -1000, -1000, 2290, 11579, 2858, -1000, 1093, 1093, 2379, - 2857, 2852, -1000, 3054, 3054, -1000, 3045, 3053, 3045, 1093, - 1093, 2851, -1000, 3044, -1000, 3373, -1000, 2258, 2536, -1000, - 2531, 2449, 11579, -1000, 2850, 3864, 1630, -49, -189, 121, - 121, -1000, -1000, -1000, -1000, 121, 121, 121, 121, -1000, - 121, 121, 121, 121, 121, 121, 121, 121, 121, 121, - 121, 851, -101, -282, -103, -284, -1000, 2836, 1389, -1000, - -1000, -1000, -1000, -1000, 4527, 1384, 588, 588, 2630, 2621, - -1000, 916, 2617, 1133, 49398, 2616, -293, -1000, 2612, -1000, - -1000, 49398, 49398, 49398, 50038, 688, 49398, 49398, 2601, -1000, - 2597, 2835, 1383, -1000, -1000, 49398, -1000, -1000, -1000, 2834, - 3394, 18666, 3392, 2420, -1000, -1000, -1000, 29558, 602, -1000, - -1000, -1000, 750, 373, 2294, 586, -1000, 49398, 565, 3325, - 1938, 2595, 49398, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, 3358, -1000, 1091, -354, 516, 35958, 16096, -1000, 409, - 49398, -1000, 49398, 18666, 18666, 409, 522, 2026, -1000, 849, - 1352, 144, 37238, 49398, -1000, 36598, 2833, -1000, -1000, 1232, - 3526, -1000, 2290, 2290, -354, 3526, 3526, 1851, -1000, -1000, - 522, -1000, 409, -1000, 1566, 19946, 608, 507, 460, -1000, - 733, -1000, -1000, 848, 3341, 5535, -1000, 49398, -1000, 49398, - -1000, 49398, 49398, 882, 11579, 3341, 49398, 902, -1000, 1186, - 543, 515, 857, 857, 1378, -1000, 3373, -1000, -1000, 1377, - -1000, -1000, -1000, -1000, 49398, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, 26998, 26998, 3436, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2594, - 2591, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + 3054, 3054, 3055, 3055, 3054, -1000, -1000, -1000, -1000, 3584, + -1000, 1477, -1000, -1000, 1609, -1000, 1902, -337, 15736, 2018, + 1866, -1000, 11863, 15736, 11863, -252, 392, -254, -1000, -1000, + -1000, 2652, -1000, -1000, -1000, 2293, -1000, 2292, -1000, 167, + 195, 2085, -218, 9281, 450, 49741, -218, 49741, 9281, -1000, + 49741, 178, -365, -380, 157, 2651, 412, -218, 3506, 81, + 11863, 3382, -1000, -1000, 49741, 2290, -1000, -1000, -1000, 3605, + 40126, 2453, 1814, 39485, -1000, 357, -1000, 267, 610, 2644, + -1000, 1003, 120, 2643, 2642, -1000, -1000, -1000, -1000, 14439, + 1731, -1000, -1000, -1000, 2092, 11863, 2850, -1000, 1124, 1124, + 2289, 2847, 2845, -1000, 3053, 3053, -1000, 3020, 3025, 3020, + 1124, 1124, 2843, -1000, 3018, -1000, 3408, -1000, 2254, 2625, + -1000, 2559, 2534, 11863, -1000, 2841, 3752, 1517, -33, -186, + 145, 145, -1000, -1000, -1000, -1000, 145, 145, 145, 145, + -1000, 145, 145, 145, 145, 145, 145, 145, 145, 145, + 145, 145, 863, -95, -276, -97, -278, -1000, 2833, 1475, + -1000, -1000, -1000, -1000, -1000, 4247, 1465, 577, 577, 2642, + 2640, -1000, 945, 2637, 1184, 49741, 2636, -286, -1000, 2630, + -1000, -1000, 49741, 49741, 49741, 50382, 717, 49741, 49741, 2621, + -1000, 2618, 2827, 1449, -1000, -1000, 49741, -1000, -1000, -1000, + 2826, 3429, 18961, 3412, 2389, -1000, -1000, -1000, 29870, 593, + -1000, -1000, -1000, 747, 393, 2278, 603, -1000, 49741, 552, + 3372, 1954, 2617, 49741, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, 3400, -1000, 1004, -356, 533, 36280, 16387, -1000, + 427, 49741, -1000, 49741, 18961, 18961, 427, 535, 1939, -1000, + 862, 1319, 130, 37562, 49741, -1000, 36921, 2825, -1000, -1000, + 1299, 3587, -1000, 2092, 2092, -356, 3587, 3587, 1836, -1000, + -1000, 535, -1000, 427, -1000, 1623, 20243, 601, 549, 547, + -1000, 737, -1000, -1000, 860, 3380, 5361, -1000, 49741, -1000, + 49741, -1000, 49741, 49741, 920, 11863, 3380, 49741, 944, -1000, + 1242, 525, 513, 937, 937, 1447, -1000, 3408, -1000, -1000, + 1415, -1000, -1000, -1000, -1000, 49741, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, 27306, 27306, 3479, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + 2610, 2609, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - 49398, 1687, -1000, 1929, 2590, 2420, 29558, 1926, 1909, 2586, - 2585, 602, -1000, 2584, 2583, -1000, 2185, 1923, 958, 49398, - -1000, 1227, 49398, 49398, -1000, 1395, -1000, 1921, 3225, 3235, - 3225, -1000, 3225, -1000, -1000, -1000, -1000, 3270, 2570, -1000, - 3263, -1000, 3259, -1000, -1000, -1000, -1000, 1395, -1000, -1000, - -1000, -1000, -1000, 1055, -1000, 3463, 1094, 1094, 1094, 2831, - -1000, -1000, -1000, -1000, 1318, 2829, -1000, -1000, -1000, 3560, - -1000, -1000, -1000, -1000, -1000, -1000, 18026, 3353, 3521, 3509, - 38518, -1000, -339, 1908, -1000, 2160, 186, 2005, 49398, -1000, - -1000, -1000, 2826, 2824, -226, 199, 3507, 3506, 1123, -1000, - 2823, 1280, -220, -1000, -1000, 1239, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -363, -220, -1000, 1239, -1000, 173, -1000, - -1000, 3337, -1000, -1000, 2478, -1000, 261, -1000, -1000, -1000, - -1000, -1000, -1000, 225, -1000, 49398, -1000, 1274, 120, -1000, - 2290, -1000, -1000, -1000, -1000, -1000, 5131, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2569, -1000, -1000, - 11579, -1000, -1000, -1000, 2445, -1000, -1000, 11579, 2820, 2566, - 2814, 2565, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 3549, - -1000, 3505, 1680, 2813, 2804, 1679, 2801, 2799, -1000, 11579, - 2798, 4527, 1049, 2551, 1049, -1000, -1000, 459, 28918, 49398, - 3530, -1000, 49398, 2550, -1000, -1000, 49398, 2241, 686, 2241, - 692, 49398, -301, -1000, -115, 1234, 5535, 929, 409, 2797, - 1259, -1000, -1000, -1000, -1000, 409, -1000, 2549, 249, -1000, - -1000, -1000, -1000, 2292, -1000, -1000, 2249, 1598, 262, -1000, - -1000, -1000, -1000, -1000, -1000, 2236, 49398, 37878, 2264, 1915, - -355, -1000, 3040, -1000, 1818, 1818, 1818, 900, 49398, 1678, - -1000, 1818, 1818, 2792, -1000, -1000, 899, 2790, 2787, -136, - 855, 1883, 1853, -1000, 2291, 28278, 37238, 36598, 1365, -1000, - 1574, -1000, -1000, -1000, -1000, -1000, -1000, 3526, 855, -1000, - 599, 2283, 14151, 3038, 14151, 3037, 621, 3021, 1674, -1000, - 49398, -1000, -1000, 49398, 4256, 3014, -1000, 3013, 3228, 587, - 3012, 3011, 49398, 2394, -1000, 3341, 49398, 825, 3352, -1000, - -1000, -1000, 486, -1000, -1000, -1000, 714, -1000, 49398, -1000, - 49398, -1000, 1637, -1000, 26998, -1000, -1000, 1656, -1000, 2547, - 2546, -1000, -1000, 249, 2542, 6420, -1000, -1000, -1000, -1000, - -1000, 3325, 2541, 2236, 49398, -1000, 49398, 1227, 1227, 3549, - 49398, 9001, -1000, -1000, 11579, 3008, -1000, 11579, -1000, -1000, - -1000, 2786, -1000, -1000, -1000, -1000, -1000, 3003, 3319, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, 1744, -1000, 11579, 12222, - -1000, 879, 15446, -254, 390, -1000, -1000, -1000, -228, 2540, - -1000, -1000, 3504, 2539, 2451, 49398, -1000, -1000, 1239, -1000, - 1239, -226, -1000, -1000, 1232, -1000, -1000, 1099, 760, -1000, - 2785, 277, -1000, 2362, -1000, 2357, 121, -1000, 121, -1000, - 301, 11579, -1000, 2538, -1000, -1000, -1000, 2535, -1000, -1000, - 2304, -1000, 2784, -1000, 2534, -1000, -1000, 49398, -1000, -1000, - 1125, 2533, -356, -1000, 2529, 2241, 2527, 2241, 49398, 682, - -1000, 2525, 2523, -1000, -1000, 5535, -137, -136, 18666, -137, - -1000, -1000, 412, 446, -1000, -1000, 2210, 655, -1000, -1000, - 2522, 644, -1000, 1227, -1000, 1914, 2109, 2487, 34038, 26998, - 27638, 2518, 453, -1000, -1000, 35958, 1744, 1744, 4322, 441, - 338, 54731, -1000, 2999, 1180, 1805, -1000, 2279, -1000, 2277, - -1000, 3526, 1365, 141, -1000, -1000, 1758, -1000, 1180, 2947, - 3503, -1000, 3462, 49398, 3015, 49398, 2998, 1911, 14151, -1000, - 848, 3293, -1000, -1000, 4256, -1000, -1000, 2117, 14151, -1000, - -1000, 2513, 27638, 1011, 1907, 1906, 1035, 2993, -1000, 721, - 3556, -1000, -1000, -1000, 1046, 2992, -1000, 2081, 2078, -1000, - 49398, -1000, 34038, 34038, 1182, 1182, 34038, 34038, 2991, 857, - -1000, -1000, 14151, -1000, -1000, 1818, -1000, -1000, -1000, 1818, - 1605, -1000, -1000, -1000, -1000, -1000, -1000, 2264, -1000, -1000, - 1225, -1000, 3464, -1000, -1000, 2290, 49398, 2290, -1000, 35318, - -1000, 3502, 3501, -1000, 2290, 254, 257, 2990, 2969, -1000, - -339, 49398, 49398, -230, 2268, -1000, 2510, 187, -1000, -1000, - 1224, -228, -233, 95, 26998, 1902, -1000, 2776, 363, -144, - -1000, -1000, -1000, -1000, 2774, -1000, 972, -1000, -1000, -1000, - 1218, 2773, 2768, -1000, -1000, -1000, -1000, 49398, -1000, 2479, - -301, 2509, -301, 2508, 660, 2241, -1000, -1000, -117, -1000, - -1000, 499, -1000, -1000, -1000, 690, 2428, -1000, -1000, 427, - -1000, -1000, -1000, 2236, 2506, -1000, -1000, 116, -1000, 1888, - 1638, -1000, -1000, -1000, 49398, -1000, -1000, -1000, 841, -1000, - 409, 54594, -1000, 1289, 49398, -1000, 1099, 841, 32758, 716, - 314, -1000, 2266, -1000, -1000, 3549, -1000, 704, -1000, 614, - -1000, 1633, -1000, 1625, 34678, 2265, 1876, -1000, 54556, 976, - -1000, -1000, 3950, -1000, -1000, -1000, -1000, -1000, -1000, 2504, - 2503, -1000, -1000, -1000, -1000, -1000, 2257, 2964, 26, 3433, - 2495, -1000, -1000, 2962, 1624, 1622, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, -1000, -1000, 1620, 1619, 34038, -1000, - -1000, 3950, 2253, 26998, 1818, -1000, -1000, 1618, 1603, -1000, - -1000, -1000, -1000, -1000, -311, 2959, 11579, 11579, -1000, -1000, - -1000, 2958, -1000, -1000, 3491, -230, -235, 2492, 151, 195, - -1000, 2491, -1000, -119, 3286, -150, -1000, -1000, 964, -221, - 137, 135, 124, -1000, -1000, -1000, 11579, -1000, -1000, -1000, - 110, -1000, 1830, -1000, -301, -1000, -301, 2241, 2488, 49398, - 717, -1000, -1000, -1000, -1000, 223, -1000, -1000, -1000, -1000, - -1000, -1000, 2487, 2485, -1000, -1000, 590, 3490, -1000, 54731, - -1000, 1818, -1000, -1000, 590, 1589, -1000, 1818, 1818, -1000, - 533, -1000, 1801, -1000, 2240, -1000, 3464, -1000, 527, -1000, - 594, -1000, -1000, -1000, 1568, -1000, -1000, -1000, 54556, 603, - -1000, 828, 2957, -1000, -1000, 2758, 11579, 2954, 1818, 2755, - -107, 34038, 3227, 3226, 3066, 3017, 1555, -1000, -1000, 26998, - -1000, -1000, 33398, -1000, 2953, 1517, 1510, 49398, 2451, -1000, - -1000, 2481, -1000, 888, 183, 195, -1000, 3489, 184, 3488, - 3487, 1193, 3285, -1000, -1000, 2064, -1000, 168, 157, 153, - -1000, -1000, -1000, -1000, -1000, 2479, 2464, -1000, -1000, 2462, - -301, 582, -1000, 329, -1000, -1000, -1000, 332, -1000, 3483, - 794, -1000, 26998, -1000, -1000, 32758, 1744, 1744, -1000, -1000, - 2228, -1000, -1000, -1000, -1000, 2212, -1000, -1000, -1000, 1496, - -1000, 49398, 1030, 8358, -1000, 2224, -1000, 49398, -1000, 3234, - -1000, 303, 1461, 332, 1182, 332, 1182, 332, 1182, 332, - 1182, 326, -1000, -1000, -1000, 1434, 11579, -1000, -1000, 1402, - -1000, -1000, -1000, 2952, 2201, 199, 171, 3482, -1000, 2451, - 3481, 2451, 2451, -1000, 142, -138, 964, -1000, -1000, -1000, - -1000, -1000, -301, -1000, 2458, -1000, -1000, -1000, -1000, 1818, - 1818, 2456, 2453, 492, -1000, -1000, 1818, 1818, 1818, 1818, - 32118, 608, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 603, - 54731, -1000, 8358, 1362, -1000, 2290, -1000, 857, -1000, -1000, - 3004, 2853, 3543, -1000, -1000, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, 2949, 2754, -1000, 49398, 3426, 26358, 179, - -1000, -1000, -1000, 2452, -1000, 2451, -1000, -1000, 1816, -145, - -1000, -1000, -280, 2178, 2153, -1000, -1000, 49398, 2149, 2131, - 2126, 2442, -1000, 49398, 599, -1000, 54731, 1343, -1000, 8358, - -1000, -1000, 3554, -1000, 3548, 1050, 1050, 332, 332, 332, - 332, 11579, -1000, -1000, -1000, 49398, -1000, 1336, -1000, -1000, - -1000, 1572, -1000, -1000, -1000, -1000, 2441, -151, -1000, -1000, - 2367, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 1323, 2947, - -1000, -1000, -1000, -1000, -1000, 2230, 719, -1000, 2715, 1189, - -1000, 1812, -1000, 31478, 49398, -1000, -1000, -1000, -1000, -1000, - -1000, -1000, -1000, -1000, 49398, 7715, -1000, 1470, -1000, -1000, - 2290, 49398, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, 49741, 1722, -1000, 1952, 2605, 2389, 29870, 1948, 1852, + 2590, 2588, 593, -1000, 2587, 2585, -1000, 2140, 1944, 995, + 49741, -1000, 1287, 49741, 49741, -1000, 1379, -1000, 1938, 3267, + 3283, 3267, -1000, 3267, -1000, -1000, -1000, -1000, 3317, 2574, + -1000, 3312, -1000, 3303, -1000, -1000, -1000, -1000, 1379, -1000, + -1000, -1000, -1000, -1000, 1115, -1000, 3505, 1123, 1123, 1123, + 2824, -1000, -1000, -1000, -1000, 1406, 2818, -1000, -1000, -1000, + 3617, -1000, -1000, -1000, -1000, -1000, -1000, 18320, 3399, 3580, + 3569, 38844, -1000, -337, 1901, -1000, 2134, 188, 1972, 49741, + -1000, -1000, -1000, 2817, 2816, -223, 198, 3568, 3567, 1142, + -1000, 2810, 1391, -218, -1000, -1000, 1330, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -382, -218, -1000, 1330, -1000, 167, + -1000, -1000, 3388, -1000, -1000, 2453, -1000, 263, -1000, -1000, + -1000, -1000, -1000, -1000, 236, -1000, 49741, -1000, 1382, 119, + -1000, 2092, -1000, -1000, -1000, -1000, -1000, 4284, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 2571, -1000, + -1000, 11863, -1000, -1000, -1000, 2528, -1000, -1000, 11863, 2809, + 2570, 2804, 2568, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + 3622, -1000, 3566, 1703, 2803, 2802, 1699, 2799, 2798, -1000, + 11863, 2795, 4247, 1093, 2565, 1093, -1000, -1000, 461, 29229, + 49741, 3604, -1000, 49741, 2555, -1000, -1000, 49741, 2166, 692, + 2166, 681, 49741, -295, -1000, -110, 1316, 5361, 1026, 427, + 2791, 1337, -1000, -1000, -1000, -1000, 427, -1000, 2547, 255, + -1000, -1000, -1000, -1000, 2277, -1000, -1000, 2251, 1599, 259, + -1000, -1000, -1000, -1000, -1000, -1000, 2367, 49741, 38203, 2383, + 1937, -357, -1000, 3015, -1000, 1912, 1912, 1912, 938, 49741, + 1691, -1000, 1912, 1912, 2789, -1000, -1000, 931, 2786, 2785, + -126, 874, 1898, 1871, -1000, 2273, 28588, 37562, 36921, 1377, + -1000, 1606, -1000, -1000, -1000, -1000, -1000, -1000, 3587, 874, + -1000, 592, 2264, 14439, 3014, 14439, 3009, 609, 3003, 1679, + -1000, 49741, -1000, -1000, 49741, 3183, 3000, -1000, 2999, 3272, + 576, 2998, 2995, 49741, 2509, -1000, 3380, 49741, 811, 3397, + -1000, -1000, -1000, 489, -1000, -1000, -1000, 674, -1000, 49741, + -1000, 49741, -1000, 1707, -1000, 27306, -1000, -1000, 1673, -1000, + 2545, 2543, -1000, -1000, 255, 2541, 6696, -1000, -1000, -1000, + -1000, -1000, 3372, 2540, 2367, 49741, -1000, 49741, 1287, 1287, + 3622, 49741, 9281, -1000, -1000, 11863, 2993, -1000, 11863, -1000, + -1000, -1000, 2781, -1000, -1000, -1000, -1000, -1000, 2980, 3386, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, 1926, -1000, 11863, + 12507, -1000, 919, 15736, -256, 391, -1000, -1000, -1000, -225, + 2538, -1000, -1000, 3565, 2537, 2404, 49741, -1000, -1000, 1330, + -1000, 1330, -223, -1000, -1000, 1299, -1000, -1000, 1187, 787, + -1000, 2779, 284, -1000, 2459, -1000, 2400, 145, -1000, 145, + -1000, 248, 11863, -1000, 2536, -1000, -1000, -1000, 2526, -1000, + -1000, 2377, -1000, 2778, -1000, 2525, -1000, -1000, 49741, -1000, + -1000, 1182, 2520, -360, -1000, 2519, 2166, 2518, 2166, 49741, + 691, -1000, 2512, 2511, -1000, -1000, 5361, -131, -126, 18961, + -131, -1000, -1000, 398, 456, -1000, -1000, 2224, 676, -1000, + -1000, 2508, 668, -1000, 1287, -1000, 1936, 2115, 2448, 34357, + 27306, 27947, 2506, 453, -1000, -1000, 36280, 1926, 1926, 54880, + 440, 343, 54956, -1000, 2978, 1223, 1847, -1000, 2241, -1000, + 2231, -1000, 3587, 1377, 129, -1000, -1000, 1794, -1000, 1223, + 2631, 3561, -1000, 3090, 49741, 3007, 49741, 2977, 1935, 14439, + -1000, 860, 3347, -1000, -1000, 3183, -1000, -1000, 2114, 14439, + -1000, -1000, 2505, 27947, 1040, 1934, 1930, 1033, 2976, -1000, + 738, 3615, -1000, -1000, -1000, 1080, 2975, -1000, 2084, 2083, + -1000, 49741, -1000, 34357, 34357, 773, 773, 34357, 34357, 2970, + 937, -1000, -1000, 14439, -1000, -1000, 1912, -1000, -1000, -1000, + 1912, 1690, -1000, -1000, -1000, -1000, -1000, -1000, 2383, -1000, + -1000, 1277, -1000, 3526, -1000, -1000, 2092, 49741, 2092, -1000, + 35639, -1000, 3560, 3558, -1000, 2092, 261, 251, 2969, 2968, + -1000, -337, 49741, 49741, -236, 2229, -1000, 2503, 204, -1000, + -1000, 1275, -225, -242, 100, 27306, 1919, -1000, 2772, 369, + -140, -1000, -1000, -1000, -1000, 2771, -1000, 940, -1000, -1000, + -1000, 1265, 2770, 2769, -1000, -1000, -1000, -1000, 49741, -1000, + 2437, -295, 2501, -295, 2500, 688, 2166, -1000, -1000, -115, + -1000, -1000, 469, -1000, -1000, -1000, 673, 2396, -1000, -1000, + 439, -1000, -1000, -1000, 2367, 2499, -1000, -1000, 117, -1000, + 1918, 1672, -1000, -1000, -1000, 49741, -1000, -1000, -1000, 857, + -1000, 427, 54918, -1000, 1290, 49741, -1000, 1187, 857, 33075, + 709, 313, -1000, 2212, -1000, -1000, 3622, -1000, 705, -1000, + 606, -1000, 1660, -1000, 1637, 34998, 2175, 2544, -1000, 5539, + 990, -1000, -1000, 2416, -1000, -1000, -1000, -1000, -1000, -1000, + 2497, 2495, -1000, -1000, -1000, -1000, -1000, 2174, 2965, 136, + 3474, 2492, -1000, -1000, 2963, 1619, 1617, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, -1000, 1614, 1598, 34357, + -1000, -1000, 2416, 2173, 27306, 1912, -1000, -1000, 1585, 1563, + -1000, -1000, -1000, -1000, -1000, -319, 2962, 11863, 11863, -1000, + -1000, -1000, 2959, -1000, -1000, 3555, -236, -244, 2479, 154, + 211, -1000, 2478, -1000, -119, 3340, -147, -1000, -1000, 1113, + -219, 142, 137, 128, -1000, -1000, -1000, 11863, -1000, -1000, + -1000, 115, -1000, 1915, -1000, -295, -1000, -295, 2166, 2452, + 49741, 707, -1000, -1000, -1000, -1000, 235, -1000, -1000, -1000, + -1000, -1000, -1000, 2448, 2447, -1000, -1000, 583, 3548, -1000, + 54956, -1000, 1912, -1000, -1000, 583, 1557, -1000, 1912, 1912, + -1000, 548, -1000, 1840, -1000, 2163, -1000, 3526, -1000, 543, + -1000, 588, -1000, -1000, -1000, 1549, -1000, -1000, -1000, 5539, + 598, -1000, 840, 2955, -1000, -1000, 2767, 11863, 2954, 1912, + 2766, -93, 34357, 3270, 3268, 3185, 2654, 1481, -1000, -1000, + 27306, -1000, -1000, 33716, -1000, 2953, 1448, 1439, 49741, 2404, + -1000, -1000, 2446, -1000, 926, 164, 211, -1000, 3546, 202, + 3543, 3540, 1251, 3332, -1000, -1000, 2059, -1000, 139, 134, + 123, -1000, -1000, -1000, -1000, -1000, 2437, 2430, -1000, -1000, + 2426, -295, 567, -1000, 353, -1000, -1000, -1000, 337, -1000, + 3537, 723, -1000, 27306, -1000, -1000, 33075, 1926, 1926, -1000, + -1000, 2162, -1000, -1000, -1000, -1000, 2150, -1000, -1000, -1000, + 1437, -1000, 49741, 1041, 8637, -1000, 2361, -1000, 49741, -1000, + 3280, -1000, 276, 1436, 337, 773, 337, 773, 337, 773, + 337, 773, 347, -1000, -1000, -1000, 1435, 11863, -1000, -1000, + 1407, -1000, -1000, -1000, 2951, 2145, 198, 175, 3535, -1000, + 2404, 3534, 2404, 2404, -1000, 148, -137, 1113, -1000, -1000, + -1000, -1000, -1000, -295, -1000, 2420, -1000, -1000, -1000, -1000, + 1912, 1912, 2409, 2408, 514, -1000, -1000, 1912, 1912, 1912, + 1912, -1000, 32434, 601, -1000, -1000, -1000, -1000, -1000, -1000, + -1000, 598, 54956, -1000, 8637, 1336, -1000, 2092, -1000, 937, + -1000, -1000, 3279, 3019, 3591, -1000, -1000, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, 2945, 2752, -1000, 49741, 3468, + 26665, 180, -1000, -1000, -1000, 2407, -1000, 2404, -1000, -1000, + 1909, -144, -1000, -1000, -273, 2144, 2141, -1000, -1000, 49741, + 2135, 2133, 2124, 2403, -1000, 49741, 592, -1000, 54956, 1322, + -1000, 8637, -1000, -1000, 3614, -1000, 3612, 1037, 1037, 337, + 337, 337, 337, 11863, -1000, -1000, -1000, 49741, -1000, 1312, + -1000, -1000, -1000, 1604, -1000, -1000, -1000, -1000, 2394, -152, + -1000, -1000, 2148, -1000, -1000, -1000, -1000, -1000, -1000, -1000, + 1309, 2631, -1000, -1000, -1000, -1000, -1000, 2185, 757, -1000, + 2514, 1245, -1000, 1899, -1000, 31793, 49741, -1000, -1000, -1000, + -1000, -1000, -1000, -1000, -1000, -1000, 49741, 7993, -1000, 1596, + -1000, -1000, 2092, 49741, -1000, } var yyPgo = [...]int{ - 0, 183, 3579, 250, 180, 4198, 93, 267, 272, 253, - 266, 265, 4197, 4195, 4194, 3354, 3353, 4193, 4192, 4191, - 4190, 4189, 4188, 4187, 4186, 4185, 4183, 4182, 4181, 4180, - 4179, 4178, 4177, 4176, 4175, 4174, 4173, 4172, 4171, 4169, - 4168, 4167, 4166, 4165, 4164, 4162, 4161, 248, 4160, 4159, - 4157, 4156, 4155, 4154, 4153, 4151, 4150, 4149, 4148, 4146, - 4145, 4144, 4143, 4135, 4134, 4133, 4130, 4129, 4126, 4123, - 4122, 4121, 4119, 4118, 4117, 4116, 4114, 4113, 4112, 4111, - 4110, 4109, 4108, 4106, 4105, 245, 4104, 3347, 4103, 4089, - 4088, 4086, 4085, 4083, 4081, 4079, 4078, 4074, 4073, 301, - 4072, 4071, 4070, 4068, 4067, 4066, 4065, 4063, 4062, 4061, - 4060, 4051, 4050, 262, 4049, 4048, 4043, 4041, 279, 4040, - 211, 4035, 178, 142, 4034, 4029, 4028, 4027, 4026, 4025, - 4024, 4023, 4021, 4019, 4018, 4017, 4003, 3999, 246, 195, - 75, 3998, 48, 3997, 3996, 222, 3995, 154, 3994, 151, - 3993, 3989, 3988, 3987, 3984, 3982, 3977, 3975, 3973, 3971, - 3970, 3969, 3966, 3964, 3963, 3962, 3961, 3958, 3957, 3956, - 3955, 3954, 3952, 3949, 51, 3948, 260, 3947, 79, 3945, - 184, 3944, 77, 3943, 45, 132, 268, 1550, 274, 3940, - 189, 3939, 3937, 244, 176, 3936, 3935, 281, 3934, 192, - 231, 165, 123, 130, 3933, 138, 3931, 264, 47, 62, - 238, 149, 3930, 3929, 57, 190, 128, 3927, 218, 97, - 112, 3926, 3924, 148, 3923, 239, 177, 3921, 108, 3920, - 3919, 3918, 21, 3917, 3914, 205, 198, 3912, 3911, 98, - 3908, 3907, 64, 129, 3906, 82, 122, 173, 121, 3905, - 2714, 125, 90, 3902, 134, 103, 3901, 115, 3900, 3899, - 3898, 3896, 185, 3895, 3894, 158, 61, 3893, 3891, 3890, - 70, 3887, 78, 3886, 28, 3885, 59, 3883, 3879, 3878, - 3877, 3875, 3867, 3866, 3865, 3864, 3862, 3861, 3857, 55, - 3856, 3855, 3854, 3849, 7, 14, 17, 3847, 29, 3846, - 174, 3845, 3844, 171, 3843, 201, 3841, 3840, 95, 92, - 3838, 94, 168, 3837, 9, 30, 74, 3835, 3834, 3833, - 257, 3832, 3831, 3830, 278, 3828, 3827, 3826, 166, 3825, - 3824, 3823, 647, 3822, 3820, 3818, 3817, 3816, 3815, 106, - 3814, 1, 219, 42, 3813, 143, 145, 3812, 39, 32, - 3811, 52, 113, 233, 135, 101, 3810, 3809, 3807, 141, - 200, 119, 37, 0, 100, 224, 163, 3805, 3804, 3803, - 251, 3802, 236, 215, 235, 188, 255, 213, 3801, 3800, - 60, 3799, 167, 50, 54, 136, 85, 23, 220, 3797, - 1589, 10, 212, 3796, 206, 3795, 8, 18, 133, 159, - 3794, 3793, 36, 261, 3776, 3775, 3774, 131, 3773, 3768, - 191, 84, 3767, 3766, 3765, 3764, 3763, 40, 3761, 186, - 16, 3760, 109, 3759, 256, 3758, 258, 147, 182, 193, - 162, 226, 232, 86, 81, 3757, 1904, 161, 104, 15, - 3755, 229, 3753, 203, 126, 3751, 105, 3750, 241, 263, - 208, 3748, 187, 11, 49, 38, 31, 44, 12, 277, - 204, 3747, 3746, 25, 53, 3745, 56, 3744, 20, 3743, - 3742, 41, 3741, 67, 5, 3738, 3737, 19, 22, 3736, - 34, 207, 175, 124, 99, 68, 3735, 3733, 157, 144, - 3732, 155, 164, 156, 3731, 80, 3730, 3728, 3727, 3726, - 3171, 259, 3725, 3722, 3720, 3718, 3714, 3713, 3712, 3711, - 217, 3710, 140, 43, 3709, 3708, 3707, 3705, 88, 150, - 3704, 3703, 3702, 3701, 33, 146, 3700, 13, 3699, 26, - 24, 35, 3697, 107, 3694, 3, 194, 3693, 3688, 4, - 3686, 3683, 2, 3682, 3681, 137, 3680, 96, 27, 172, - 110, 3679, 3678, 91, 216, 152, 3677, 3675, 102, 243, - 210, 3673, 160, 237, 252, 3672, 214, 3666, 3664, 3663, - 3662, 3659, 1248, 3658, 3657, 240, 69, 83, 3656, 221, - 116, 3654, 3653, 89, 169, 120, 118, 58, 87, 3652, - 114, 209, 3651, 202, 3649, 275, 3648, 3646, 111, 3641, - 3631, 3627, 3626, 196, 3622, 3621, 197, 230, 3620, 3617, - 269, 3615, 3601, 3599, 3598, 3597, 3596, 3593, 3592, 3591, - 3581, 242, 254, 3576, + 0, 175, 3640, 252, 180, 4234, 89, 247, 276, 253, + 246, 244, 4233, 4232, 4230, 3404, 3401, 4229, 4228, 4227, + 4226, 4225, 4221, 4220, 4219, 4213, 4212, 4211, 4209, 4204, + 4202, 4201, 4199, 4198, 4197, 4196, 4195, 4194, 4193, 4192, + 4191, 4190, 4189, 4188, 4187, 4186, 4185, 242, 4184, 4183, + 4182, 4181, 4180, 4179, 4178, 4176, 4175, 4174, 4173, 4172, + 4171, 4170, 4169, 4168, 4167, 4165, 4164, 4163, 4162, 4161, + 4160, 4159, 4158, 4157, 4156, 4155, 4154, 4153, 4150, 4149, + 4148, 4147, 4146, 4145, 4143, 245, 4142, 3399, 4141, 4140, + 4137, 4135, 4133, 4131, 4128, 4125, 4124, 4123, 4122, 311, + 4121, 4120, 4118, 4117, 4116, 4115, 4114, 4113, 4112, 4111, + 4110, 4109, 4108, 300, 4107, 4106, 4105, 4104, 270, 4100, + 285, 4099, 178, 148, 4098, 4097, 4094, 4093, 4092, 4091, + 4090, 4088, 4087, 4086, 4083, 4082, 4077, 4075, 248, 212, + 74, 4073, 50, 4072, 4071, 218, 4070, 157, 4069, 154, + 4068, 4067, 4065, 4064, 4063, 4062, 4061, 4058, 4057, 4056, + 4055, 4052, 4051, 4050, 4045, 4043, 4040, 4036, 4035, 4029, + 4028, 4027, 4026, 4025, 49, 4023, 257, 4021, 77, 4019, + 182, 4017, 67, 4016, 102, 146, 260, 2652, 265, 4015, + 191, 4014, 4013, 249, 177, 4012, 4011, 278, 4010, 164, + 221, 161, 99, 120, 4009, 137, 4008, 264, 47, 40, + 251, 145, 4007, 4006, 56, 163, 131, 4005, 216, 98, + 113, 4004, 3998, 147, 3997, 235, 186, 3996, 108, 3995, + 3994, 3991, 36, 3990, 3989, 202, 203, 3988, 3987, 104, + 3986, 3983, 68, 134, 3981, 81, 128, 173, 125, 3979, + 2640, 122, 103, 3978, 123, 109, 3976, 94, 3974, 3972, + 3969, 3968, 185, 3967, 3966, 140, 64, 3965, 3964, 3963, + 69, 3962, 78, 3961, 86, 3960, 61, 3959, 3958, 3957, + 3956, 3955, 3952, 3951, 3950, 3948, 3946, 3944, 3943, 55, + 3942, 3940, 3937, 3936, 5, 13, 15, 3935, 27, 3934, + 172, 3932, 3930, 167, 3928, 197, 3918, 3916, 96, 91, + 3915, 93, 165, 3913, 9, 28, 70, 3912, 3911, 3910, + 195, 3907, 3906, 3905, 267, 3891, 3890, 3889, 162, 3888, + 3887, 3886, 647, 3885, 3884, 3880, 3878, 3876, 3875, 100, + 3874, 1, 217, 41, 3867, 132, 135, 3866, 38, 30, + 3865, 44, 117, 200, 136, 107, 3862, 3860, 3859, 282, + 206, 106, 88, 0, 101, 219, 160, 3858, 3857, 3856, + 250, 3855, 232, 205, 231, 187, 255, 268, 3854, 3852, + 60, 3846, 166, 35, 54, 133, 335, 23, 211, 3844, + 1952, 8, 184, 3843, 208, 3841, 12, 18, 53, 152, + 3840, 3838, 34, 261, 3837, 3836, 3832, 130, 3828, 3826, + 291, 79, 3825, 3809, 3808, 3803, 3799, 39, 3797, 188, + 16, 3796, 138, 3795, 241, 3794, 201, 143, 190, 183, + 159, 224, 230, 83, 80, 3792, 1915, 156, 112, 22, + 3790, 220, 3789, 322, 126, 3788, 90, 3787, 238, 259, + 210, 3785, 189, 10, 48, 32, 29, 45, 14, 287, + 204, 3784, 3783, 21, 51, 3782, 52, 3781, 20, 3780, + 3779, 42, 3777, 57, 7, 3776, 3775, 17, 19, 3774, + 37, 226, 176, 124, 97, 62, 3773, 3772, 150, 142, + 3771, 141, 155, 158, 3768, 75, 3767, 3766, 3765, 3763, + 747, 254, 3762, 3761, 3760, 3758, 3757, 3756, 3755, 3754, + 215, 3752, 111, 43, 3751, 3750, 3749, 3736, 84, 149, + 3734, 3732, 3731, 3729, 31, 144, 3727, 11, 3722, 26, + 24, 33, 3720, 105, 3716, 3, 194, 3715, 3714, 4, + 3711, 3710, 2, 3708, 3707, 129, 3706, 95, 25, 171, + 116, 3705, 3703, 92, 214, 151, 3702, 3701, 114, 243, + 207, 3700, 168, 237, 258, 3698, 213, 3697, 3695, 3693, + 3692, 3691, 1288, 3690, 3689, 240, 59, 82, 3688, 222, + 119, 3681, 3680, 87, 169, 121, 118, 58, 85, 3677, + 115, 209, 3675, 198, 3674, 256, 3673, 3671, 110, 3668, + 3667, 3665, 3664, 196, 3663, 3661, 192, 229, 3657, 3655, + 266, 3654, 3653, 3652, 3651, 3650, 3649, 3646, 3645, 3644, + 3643, 236, 233, 3642, } -//line mysql_sql.y:13036 +//line mysql_sql.y:13045 type yySymType struct { union interface{} id int @@ -8944,80 +8972,80 @@ var yyR1 = [...]int{ 592, 592, 591, 591, 591, 362, 362, 32, 422, 422, 424, 425, 425, 425, 416, 416, 416, 416, 36, 420, 420, 421, 421, 421, 421, 421, 421, 421, 421, 421, - 421, 421, 417, 417, 419, 419, 414, 414, 414, 414, - 414, 414, 414, 414, 35, 35, 35, 180, 180, 413, - 413, 410, 410, 232, 232, 408, 408, 409, 409, 407, - 407, 407, 411, 411, 43, 78, 44, 45, 46, 42, - 412, 412, 34, 34, 34, 34, 34, 34, 34, 34, - 34, 34, 34, 34, 141, 140, 140, 140, 140, 140, - 143, 143, 346, 346, 345, 345, 142, 286, 286, 41, - 264, 264, 487, 487, 482, 482, 482, 482, 482, 502, - 502, 502, 483, 483, 483, 484, 484, 484, 486, 486, - 486, 485, 485, 485, 485, 485, 501, 501, 503, 503, - 503, 454, 454, 455, 455, 455, 458, 458, 474, 474, - 475, 475, 473, 473, 480, 480, 479, 479, 478, 478, - 477, 477, 476, 476, 476, 476, 469, 469, 468, 468, - 456, 456, 456, 456, 456, 457, 457, 457, 467, 467, - 472, 472, 317, 317, 316, 316, 272, 272, 273, 273, - 315, 315, 270, 270, 271, 271, 271, 314, 314, 314, + 421, 421, 421, 417, 417, 419, 419, 414, 414, 414, + 414, 414, 414, 414, 414, 35, 35, 35, 180, 180, + 413, 413, 410, 410, 232, 232, 408, 408, 409, 409, + 407, 407, 407, 411, 411, 43, 78, 44, 45, 46, + 42, 412, 412, 34, 34, 34, 34, 34, 34, 34, + 34, 34, 34, 34, 34, 141, 140, 140, 140, 140, + 140, 143, 143, 346, 346, 345, 345, 142, 286, 286, + 41, 264, 264, 487, 487, 482, 482, 482, 482, 482, + 502, 502, 502, 483, 483, 483, 484, 484, 484, 486, + 486, 486, 485, 485, 485, 485, 485, 501, 501, 503, + 503, 503, 454, 454, 455, 455, 455, 458, 458, 474, + 474, 475, 475, 473, 473, 480, 480, 479, 479, 478, + 478, 477, 477, 476, 476, 476, 476, 469, 469, 468, + 468, 456, 456, 456, 456, 456, 457, 457, 457, 467, + 467, 472, 472, 317, 317, 316, 316, 272, 272, 273, + 273, 315, 315, 270, 270, 271, 271, 271, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, 314, - 314, 314, 552, 552, 553, 275, 275, 287, 287, 287, - 287, 287, 287, 274, 274, 276, 276, 252, 252, 250, - 250, 242, 242, 242, 242, 242, 242, 243, 243, 244, - 244, 245, 245, 245, 249, 249, 248, 248, 248, 248, - 246, 246, 247, 247, 247, 247, 247, 247, 440, 440, - 549, 549, 550, 550, 545, 545, 545, 548, 548, 548, - 548, 548, 548, 548, 548, 551, 551, 551, 547, 547, - 254, 340, 340, 340, 363, 363, 363, 363, 365, 339, - 339, 339, 269, 269, 268, 268, 266, 266, 266, 266, + 314, 314, 314, 552, 552, 553, 275, 275, 287, 287, + 287, 287, 287, 287, 274, 274, 276, 276, 252, 252, + 250, 250, 242, 242, 242, 242, 242, 242, 243, 243, + 244, 244, 245, 245, 245, 249, 249, 248, 248, 248, + 248, 246, 246, 247, 247, 247, 247, 247, 247, 440, + 440, 549, 549, 550, 550, 545, 545, 545, 548, 548, + 548, 548, 548, 548, 548, 548, 551, 551, 551, 547, + 547, 254, 340, 340, 340, 363, 363, 363, 363, 365, + 339, 339, 339, 269, 269, 268, 268, 266, 266, 266, 266, 266, 266, 266, 266, 266, 266, 266, 266, 266, - 266, 266, 266, 266, 266, 266, 266, 266, 439, 439, - 379, 379, 380, 380, 298, 297, 297, 297, 297, 297, - 295, 296, 294, 294, 294, 294, 294, 291, 291, 290, - 290, 290, 292, 292, 292, 292, 292, 418, 418, 288, - 288, 278, 278, 278, 277, 277, 277, 481, 386, 386, + 266, 266, 266, 266, 266, 266, 266, 266, 266, 439, + 439, 379, 379, 380, 380, 298, 297, 297, 297, 297, + 297, 295, 296, 294, 294, 294, 294, 294, 291, 291, + 290, 290, 290, 292, 292, 292, 292, 292, 418, 418, + 288, 288, 278, 278, 278, 277, 277, 277, 481, 386, 386, 386, 386, 386, 386, 386, 386, 386, 386, 386, - 386, 388, 388, 388, 388, 388, 388, 388, 388, 388, + 386, 386, 388, 388, 388, 388, 388, 388, 388, 388, 388, 388, 388, 388, 388, 388, 388, 388, 388, 388, - 388, 388, 388, 388, 388, 388, 388, 388, 293, 337, - 337, 337, 338, 338, 338, 338, 338, 338, 338, 338, - 389, 389, 395, 395, 561, 561, 560, 255, 255, 255, - 256, 256, 256, 256, 256, 256, 256, 256, 256, 265, - 265, 265, 463, 463, 463, 463, 464, 464, 464, 464, - 465, 465, 465, 461, 461, 462, 462, 400, 401, 401, - 508, 508, 509, 509, 459, 459, 460, 336, 336, 336, + 388, 388, 388, 388, 388, 388, 388, 388, 388, 293, + 337, 337, 337, 338, 338, 338, 338, 338, 338, 338, + 338, 389, 389, 395, 395, 561, 561, 560, 255, 255, + 255, 256, 256, 256, 256, 256, 256, 256, 256, 256, + 265, 265, 265, 463, 463, 463, 463, 464, 464, 464, + 464, 465, 465, 465, 461, 461, 462, 462, 400, 401, + 401, 508, 508, 509, 509, 459, 459, 460, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, 336, - 516, 516, 516, 333, 333, 333, 333, 333, 333, 333, - 333, 333, 333, 333, 333, 333, 333, 333, 333, 571, - 571, 571, 557, 557, 557, 558, 558, 558, 558, 558, - 558, 558, 558, 558, 558, 558, 558, 559, 559, 559, + 336, 516, 516, 516, 333, 333, 333, 333, 333, 333, + 333, 333, 333, 333, 333, 333, 333, 333, 333, 333, + 571, 571, 571, 557, 557, 557, 558, 558, 558, 558, + 558, 558, 558, 558, 558, 558, 558, 558, 559, 559, 559, 559, 559, 559, 559, 559, 559, 559, 559, 559, - 559, 559, 559, 559, 335, 335, 335, 334, 334, 334, + 559, 559, 559, 559, 559, 335, 335, 335, 334, 334, 334, 334, 334, 334, 334, 334, 334, 334, 334, 334, - 334, 334, 334, 334, 334, 402, 402, 403, 403, 513, - 513, 513, 513, 513, 513, 514, 514, 515, 515, 515, - 515, 507, 507, 507, 507, 507, 507, 507, 507, 507, + 334, 334, 334, 334, 334, 334, 402, 402, 403, 403, + 513, 513, 513, 513, 513, 513, 514, 514, 515, 515, + 515, 515, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, 507, - 507, 387, 332, 332, 332, 404, 396, 396, 397, 397, - 398, 398, 390, 390, 390, 390, 390, 390, 391, 391, - 393, 393, 393, 393, 393, 393, 393, 393, 393, 393, - 393, 385, 385, 385, 385, 385, 385, 385, 385, 385, - 385, 385, 392, 392, 394, 394, 406, 406, 406, 405, - 405, 405, 405, 405, 405, 405, 267, 267, 267, 267, - 384, 384, 384, 383, 383, 383, 383, 383, 383, 383, - 383, 383, 383, 383, 383, 257, 257, 257, 257, 261, - 261, 263, 263, 263, 263, 263, 263, 263, 263, 263, - 263, 263, 263, 263, 263, 262, 262, 262, 262, 262, - 260, 260, 260, 260, 260, 258, 258, 258, 258, 258, + 507, 507, 387, 332, 332, 332, 404, 396, 396, 397, + 397, 398, 398, 390, 390, 390, 390, 390, 390, 391, + 391, 393, 393, 393, 393, 393, 393, 393, 393, 393, + 393, 393, 385, 385, 385, 385, 385, 385, 385, 385, + 385, 385, 385, 392, 392, 394, 394, 406, 406, 406, + 405, 405, 405, 405, 405, 405, 405, 267, 267, 267, + 267, 384, 384, 384, 383, 383, 383, 383, 383, 383, + 383, 383, 383, 383, 383, 383, 257, 257, 257, 257, + 261, 261, 263, 263, 263, 263, 263, 263, 263, 263, + 263, 263, 263, 263, 263, 263, 262, 262, 262, 262, + 262, 260, 260, 260, 260, 260, 258, 258, 258, 258, 258, 258, 258, 258, 258, 258, 258, 258, 258, 258, - 258, 258, 258, 258, 121, 122, 122, 259, 342, 342, - 488, 488, 491, 491, 489, 489, 490, 492, 492, 492, - 493, 493, 493, 494, 494, 494, 498, 498, 351, 351, - 351, 359, 359, 358, 358, 358, 358, 358, 358, 358, + 258, 258, 258, 258, 258, 121, 122, 122, 259, 342, + 342, 488, 488, 491, 491, 489, 489, 490, 492, 492, + 492, 493, 493, 493, 494, 494, 494, 498, 498, 351, + 351, 351, 359, 359, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, @@ -9053,13 +9081,13 @@ var yyR1 = [...]int{ 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, - 358, 358, 358, 358, 358, 358, 358, 358, 357, 357, - 357, 357, 357, 357, 357, 357, 357, 357, 356, 356, + 358, 358, 358, 358, 358, 358, 358, 358, 358, 358, + 357, 357, 357, 357, 357, 357, 357, 357, 357, 357, + 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, 356, - 356, 356, 356, 356, 356, 356, 356, 356, } var yyR2 = [...]int{ @@ -9179,80 +9207,81 @@ var yyR2 = [...]int{ 0, 1, 3, 4, 3, 1, 1, 4, 1, 3, 1, 1, 1, 1, 0, 1, 1, 1, 11, 0, 2, 3, 3, 2, 2, 3, 1, 1, 3, 3, - 3, 3, 1, 3, 3, 4, 0, 2, 2, 2, - 2, 2, 2, 2, 6, 7, 10, 0, 4, 1, - 1, 0, 3, 0, 1, 0, 1, 1, 2, 4, - 4, 4, 0, 1, 8, 2, 4, 4, 4, 9, - 0, 2, 11, 9, 11, 8, 6, 9, 7, 10, - 7, 6, 7, 10, 2, 2, 9, 4, 5, 3, - 0, 4, 1, 3, 0, 3, 6, 0, 2, 10, - 0, 2, 0, 2, 0, 3, 2, 4, 3, 0, - 2, 1, 0, 2, 3, 0, 2, 3, 0, 2, - 1, 0, 3, 2, 4, 3, 0, 1, 0, 1, - 1, 0, 6, 0, 3, 5, 0, 4, 0, 3, - 1, 3, 4, 5, 0, 3, 1, 3, 2, 3, - 1, 2, 0, 4, 6, 5, 0, 2, 0, 2, - 4, 5, 4, 5, 1, 5, 6, 5, 0, 3, - 0, 1, 1, 3, 3, 3, 0, 4, 1, 3, - 3, 3, 0, 1, 1, 3, 2, 3, 3, 3, - 4, 4, 3, 3, 3, 3, 4, 4, 3, 3, + 3, 3, 1, 1, 3, 3, 4, 0, 2, 2, + 2, 2, 2, 2, 2, 6, 7, 10, 0, 4, + 1, 1, 0, 3, 0, 1, 0, 1, 1, 2, + 4, 4, 4, 0, 1, 8, 2, 4, 4, 4, + 9, 0, 2, 11, 9, 11, 8, 6, 9, 7, + 10, 7, 6, 7, 10, 2, 2, 9, 4, 5, + 3, 0, 4, 1, 3, 0, 3, 6, 0, 2, + 10, 0, 2, 0, 2, 0, 3, 2, 4, 3, + 0, 2, 1, 0, 2, 3, 0, 2, 3, 0, + 2, 1, 0, 3, 2, 4, 3, 0, 1, 0, + 1, 1, 0, 6, 0, 3, 5, 0, 4, 0, + 3, 1, 3, 4, 5, 0, 3, 1, 3, 2, + 3, 1, 2, 0, 4, 6, 5, 0, 2, 0, + 2, 4, 5, 4, 5, 1, 5, 6, 5, 0, + 3, 0, 1, 1, 3, 3, 3, 0, 4, 1, + 3, 3, 3, 0, 1, 1, 3, 2, 3, 3, + 3, 4, 4, 3, 3, 3, 3, 4, 4, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 2, 3, 3, 3, 3, 3, 3, 3, 3, 1, - 5, 4, 1, 3, 3, 2, 2, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 3, 2, - 4, 0, 5, 5, 5, 5, 6, 0, 1, 1, - 3, 1, 1, 1, 1, 1, 7, 9, 7, 9, - 2, 1, 7, 9, 7, 9, 8, 5, 0, 1, - 0, 1, 1, 1, 1, 3, 3, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, - 3, 1, 3, 5, 1, 1, 1, 1, 1, 1, - 3, 5, 0, 1, 1, 2, 1, 2, 2, 1, - 1, 2, 2, 2, 3, 3, 2, 2, 1, 5, - 6, 4, 1, 1, 1, 5, 4, 1, 1, 2, - 0, 1, 1, 2, 5, 0, 1, 1, 2, 2, - 3, 3, 1, 1, 2, 2, 2, 0, 1, 2, - 2, 2, 0, 4, 7, 3, 3, 0, 3, 0, - 3, 1, 1, 1, 1, 1, 1, 1, 3, 3, + 3, 2, 3, 3, 3, 3, 3, 3, 3, 3, + 1, 5, 4, 1, 3, 3, 2, 2, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 3, + 2, 4, 0, 5, 5, 5, 5, 6, 0, 1, + 1, 3, 1, 1, 1, 1, 1, 7, 9, 7, + 9, 2, 1, 7, 9, 7, 9, 8, 5, 0, + 1, 0, 1, 1, 1, 1, 3, 3, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, + 1, 3, 1, 3, 5, 1, 1, 1, 1, 1, + 1, 3, 5, 0, 1, 1, 2, 1, 2, 2, + 1, 1, 2, 2, 2, 3, 3, 2, 2, 1, + 5, 6, 4, 1, 1, 1, 5, 4, 1, 1, + 2, 0, 1, 1, 2, 5, 0, 1, 1, 2, + 2, 3, 3, 1, 1, 2, 2, 2, 0, 1, + 2, 2, 2, 0, 4, 7, 3, 3, 0, 3, + 0, 3, 1, 1, 1, 1, 1, 1, 1, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 1, 1, 1, 1, 3, 5, 2, 2, 2, 2, - 4, 1, 1, 2, 5, 6, 8, 6, 6, 6, - 1, 1, 1, 1, 1, 1, 3, 9, 1, 4, - 4, 4, 7, 9, 7, 7, 7, 9, 7, 7, - 0, 2, 0, 1, 1, 2, 4, 1, 2, 2, - 1, 2, 2, 1, 2, 2, 2, 2, 2, 0, - 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, - 1, 1, 1, 2, 5, 0, 1, 3, 0, 1, - 0, 2, 0, 2, 0, 1, 6, 8, 8, 6, - 6, 5, 5, 5, 6, 6, 6, 6, 5, 6, + 3, 1, 1, 1, 1, 3, 5, 2, 2, 2, + 2, 4, 1, 1, 2, 5, 6, 8, 6, 6, + 6, 1, 1, 1, 1, 1, 1, 3, 9, 1, + 4, 4, 4, 7, 9, 7, 7, 7, 9, 7, + 7, 0, 2, 0, 1, 1, 2, 4, 1, 2, + 2, 1, 2, 2, 1, 2, 2, 2, 2, 2, + 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, + 2, 1, 1, 1, 2, 5, 0, 1, 3, 0, + 1, 0, 2, 0, 2, 0, 1, 6, 8, 8, + 6, 6, 5, 5, 5, 6, 6, 6, 6, 5, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, - 1, 1, 1, 4, 4, 6, 8, 6, 4, 5, - 4, 4, 4, 3, 4, 6, 6, 7, 4, 1, + 6, 1, 1, 1, 4, 4, 6, 8, 6, 4, + 5, 4, 4, 4, 3, 4, 6, 6, 7, 4, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 2, 2, 8, 4, 2, 3, - 2, 4, 2, 2, 4, 6, 2, 2, 4, 6, - 4, 2, 4, 4, 4, 0, 1, 2, 3, 1, - 1, 1, 1, 1, 1, 0, 2, 1, 1, 1, + 1, 1, 1, 1, 1, 2, 2, 8, 4, 2, + 3, 2, 4, 2, 2, 4, 6, 2, 2, 4, + 6, 4, 2, 4, 4, 4, 0, 1, 2, 3, + 1, 1, 1, 1, 1, 1, 0, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 3, 0, 1, 1, 3, 0, 1, 1, 3, - 1, 3, 3, 3, 3, 3, 2, 1, 1, 1, - 3, 4, 3, 4, 3, 4, 3, 4, 3, 4, - 1, 3, 4, 4, 5, 4, 5, 3, 4, 5, - 6, 1, 0, 2, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 2, 2, 1, 1, + 1, 1, 3, 0, 1, 1, 3, 0, 1, 1, + 3, 1, 3, 3, 3, 3, 3, 2, 1, 1, + 1, 3, 4, 3, 4, 3, 4, 3, 4, 3, + 4, 1, 3, 4, 4, 5, 4, 5, 3, 4, + 5, 6, 1, 0, 2, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 2, 1, 1, 1, 2, 3, 1, 1, 1, 2, + 1, 2, 1, 1, 1, 2, 3, 1, 1, 1, + 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, + 2, 1, 2, 2, 2, 2, 2, 2, 2, 2, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 2, 2, 4, 4, 1, 2, 3, 5, 1, 1, + 3, 0, 1, 0, 3, 0, 3, 3, 0, 3, + 5, 0, 3, 5, 0, 1, 1, 0, 1, 1, + 2, 2, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, - 1, 2, 2, 2, 2, 2, 2, 2, 2, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, - 2, 4, 4, 1, 2, 3, 5, 1, 1, 3, - 0, 1, 0, 3, 0, 3, 3, 0, 3, 5, - 0, 3, 5, 0, 1, 1, 0, 1, 1, 2, - 2, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, @@ -9294,425 +9323,424 @@ var yyR2 = [...]int{ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, } var yyChk = [...]int{ - -1000, -616, -619, -2, -5, 638, -1, -4, -122, -91, + -1000, -616, -619, -2, -5, 639, -1, -4, -122, -91, -7, -14, -124, -125, -8, -120, -9, -10, -12, -98, -115, -117, -119, -118, -47, -11, -114, -85, -86, -100, -108, -111, -112, -113, -126, -121, -123, -184, -127, -128, - -129, -171, -132, -134, -135, 628, -92, -93, -94, -95, + -129, -171, -132, -134, -135, 629, -92, -93, -94, -95, -96, -97, -33, -32, -31, -30, -157, -162, -165, -167, - -130, 561, 634, 464, 14, 513, -15, -16, -562, -17, + -130, 562, 635, 465, 14, 514, -15, -16, -562, -17, 267, -367, -368, -369, -371, -620, -48, -49, -50, -60, -61, -62, -63, -64, -74, -75, -76, -51, -52, -53, -56, -54, -67, -66, -68, -69, -70, -71, -72, -73, -55, -59, -160, -161, -77, -57, -78, -58, -169, -172, -131, -79, -80, -81, -83, -82, -88, -84, -89, -159, -164, -13, -170, -90, 241, -87, 77, -101, -102, -103, - -104, -105, -106, -107, -109, -110, 388, 394, 451, 627, - 62, -185, -187, 657, 658, 661, 548, 551, 163, 164, + -104, -105, -106, -107, -109, -110, 389, 395, 452, 628, + 62, -185, -187, 658, 659, 662, 549, 552, 163, 164, 166, 167, 171, 174, -34, -35, -36, -37, -38, -39, - -41, -40, -42, -43, -44, -45, -46, 237, 16, 556, + -41, -40, -42, -43, -44, -45, -46, 237, 16, 557, -18, -21, -19, -22, -20, -28, -29, -27, -24, -26, -158, -25, -163, -23, -166, -168, -133, 262, 261, 39, - 328, 329, 330, 392, 260, 238, 240, 15, 32, 43, - 367, -186, 86, 549, 239, -188, 13, 663, -6, -3, + 328, 329, 330, 393, 260, 238, 240, 15, 32, 43, + 368, -186, 86, 550, 239, -188, 13, 664, -6, -3, -2, -144, -148, -152, -155, -156, -153, -154, -4, -122, - 121, 252, 629, -363, 384, 630, 632, 631, 89, 97, - -356, -358, 464, 267, 388, 394, 627, 658, 661, 548, - 551, 563, 564, 565, 566, 567, 568, 569, 570, 572, - 573, 574, 575, 576, 577, 578, 588, 589, 579, 580, - 581, 582, 583, 584, 585, 586, 590, 591, 592, 593, - 594, 595, 596, 597, 598, 599, 600, 601, 602, 603, - 516, 613, 614, 615, 616, 544, 571, 607, 608, 609, - 610, 365, 366, 553, 279, 303, 419, 309, 316, 163, - 183, 177, 206, 197, 549, 172, 283, 321, 284, 96, - 166, 499, 111, 476, 448, 169, 298, 300, 302, 545, - 546, 378, 305, 543, 304, 306, 308, 547, 285, 368, - 193, 188, 297, 281, 186, 286, 41, 287, 361, 360, - 211, 288, 289, 558, 472, 364, 478, 313, 53, 446, - 187, 473, 301, 475, 215, 219, 490, 351, 491, 181, - 182, 480, 493, 210, 213, 214, 259, 357, 358, 44, - 555, 271, 494, 217, 653, 209, 204, 502, 317, 315, - 362, 208, 180, 203, 282, 66, 221, 220, 222, 442, - 443, 444, 445, 290, 291, 382, 489, 200, 189, 369, - 173, 23, 497, 266, 477, 395, 292, 310, 318, 216, - 218, 273, 278, 333, 557, 450, 363, 277, 314, 495, - 185, 270, 299, 265, 498, 654, 174, 397, 293, 167, - 307, 492, 656, 501, 65, 410, 179, 170, 645, 646, - 256, 164, 275, 280, 655, 294, 295, 296, 542, 320, - 319, 311, 171, 550, 201, 272, 207, 191, 178, 202, - 165, 274, 500, 411, 625, 367, 429, 199, 196, 276, - 249, 496, 479, 168, 433, 412, 194, 322, 620, 621, - 622, 383, 356, 323, 324, 192, 263, 470, 471, 327, - 439, 346, 413, 449, 420, 414, 228, 229, 331, 482, - 484, 212, 623, 335, 336, 337, 474, 338, 339, 340, - 341, 387, 57, 59, 98, 101, 100, 659, 660, 64, - 30, 373, 376, 408, 415, 348, 626, 554, 345, 349, - 350, 377, 26, 431, 399, 435, 434, 49, 50, 51, - 54, 55, 56, 58, 60, 61, 52, 541, 392, 405, - 503, 46, 48, 402, 28, 379, 430, 452, 344, 432, - 463, 47, 461, 462, 483, 27, 381, 380, 63, 45, - 438, 440, 441, 325, 342, 390, 635, 504, 385, 401, - 404, 386, 347, 375, 406, 68, 67, 398, 636, 393, - 391, 343, 559, 560, 352, 587, 370, 447, 538, 537, - 536, 535, 534, 533, 532, 531, 328, 329, 330, 416, - 417, 418, 428, 421, 422, 423, 424, 425, 426, 427, - 466, 467, 637, 485, 487, 488, 486, 244, 662, 371, - 372, 247, 639, 640, 99, 641, 643, 642, 29, 644, - 652, 649, 650, 651, 562, 232, 647, -445, -443, -363, - 549, 627, 394, 548, 551, 388, 367, 658, 661, 392, - 267, 328, 329, 330, 464, 365, -236, -363, 662, -197, - 251, 40, -250, -363, -197, -87, -16, -15, -186, -187, - -250, 246, -372, 24, 446, -99, 447, 241, 242, 86, - 78, -363, -9, -113, -8, -120, -85, -184, 451, -370, - -363, 328, 328, -370, 246, -365, 277, 427, -363, -500, - 252, -449, -422, 278, -448, -424, -451, -425, 33, 237, - 239, 238, 561, 274, 16, 392, 248, 14, 13, 393, - 260, 26, 27, 29, 15, 394, 396, 30, 397, 400, - 401, 402, 43, 405, 406, 267, 89, 97, 92, 285, - -235, -363, -398, -390, 118, -393, -385, -386, -388, -341, - -536, -383, 86, 145, 146, 153, 119, 664, -387, -481, - 37, 121, 567, 571, 607, 514, -333, -334, -335, -336, - -337, -338, 552, -363, -537, -535, 92, 102, 104, 108, - 109, 107, 105, 157, 190, 106, 93, 158, -187, 89, - -557, 577, -357, 600, 613, 614, 615, 616, 599, 62, - -507, -515, 245, -513, 156, 195, 263, 191, 14, 151, - 439, 192, 608, 609, 610, 574, 596, 516, 578, 588, - 603, 569, 570, 572, 564, 565, 566, 568, 579, 581, - 595, -516, 591, 601, 602, 587, 611, 612, 649, 604, - 605, 606, 643, 91, 90, 594, 593, 580, 575, 576, - 582, 563, 573, 583, 584, 592, 597, 598, 376, 111, - 377, 378, 506, 368, 81, 379, 252, 446, 71, 380, - 381, 382, 383, 384, 513, 385, 72, 386, 375, 267, - 429, 387, 194, 212, 518, 517, 519, 510, 507, 505, - 508, 509, 511, 512, 585, 586, 590, -136, -138, 618, - -610, -324, -611, 6, 7, 8, 9, -612, 158, -601, - 448, 557, 92, 321, 365, 17, 506, 648, 547, 648, - 547, 168, 165, -436, 168, 117, 174, 173, 250, 168, - -436, -363, 171, 648, 170, 645, 331, -412, -175, 365, - 429, 338, 98, 277, -416, -413, 545, -501, 325, 321, - 297, 247, 114, -176, 257, 256, 112, 506, 245, 403, - 316, 57, 59, -572, -573, 234, 235, 236, -564, 539, - -563, -363, 648, 653, 378, 100, 101, 645, 646, 28, - 246, 389, 273, 484, 482, 483, 485, 486, 487, 488, - -65, -517, -499, 479, 478, -376, 471, 477, 469, 481, - 472, 366, 340, 561, 339, 237, 639, 546, 540, -351, - 413, 449, 503, 504, 390, 450, 490, 492, 473, 111, - 198, 195, 247, 249, 246, 645, 365, 506, 429, 98, - 338, 246, -572, 653, 165, 490, 492, 448, 277, 427, - 42, -442, 439, -441, -443, 491, 502, 90, 91, 489, - -351, 111, 470, 470, -610, -324, -185, -187, -123, -562, - 547, 648, 247, 365, 429, 277, 248, 246, 542, 545, - 249, 506, 245, 328, 389, 273, 338, 98, 170, 645, - -191, -192, -193, 230, 231, 232, 70, 235, 233, 67, - 33, 34, 35, -1, 125, 663, -390, -390, -6, 666, - -6, -390, -363, -363, 160, -257, -261, -258, -260, -259, - -263, -262, 195, 196, 156, 199, 205, 201, 202, 203, - 204, 206, 207, 208, 209, 210, 213, 214, 211, 32, - 212, 263, 191, 192, 193, 194, 215, 177, 197, 554, - 223, 178, 224, 179, 225, 180, 226, 181, 182, 227, - 183, 186, 187, 188, 189, 185, 159, -224, 92, 33, - 86, 159, 92, -216, 269, -197, -250, -242, 159, 664, - -216, -610, -207, -208, 11, -250, -339, -363, 448, 128, - -99, 78, -99, 447, 78, -99, 447, 241, -565, -566, - -567, -569, 241, 447, 446, 242, -118, 159, 285, 17, - -370, -370, 84, -250, -424, 277, -449, -422, 37, 83, - 160, 250, 160, 83, 86, 390, 365, 429, 391, 506, - 246, 403, 249, 277, 404, 365, 429, 246, 249, 506, - 277, 365, 246, 249, 429, 277, 404, 365, 469, 470, - 249, 28, 395, 398, 399, 470, -521, 502, 160, 117, - 114, 115, 116, -390, 135, -405, 128, 129, 130, 131, - 132, 133, 134, 142, 141, 152, 145, 146, 147, 148, - 149, 150, 151, 143, 144, 138, 118, 136, 140, 137, - 120, 155, -187, -390, -398, 62, -388, -388, -388, -388, - -363, -481, -395, -390, 86, 86, 86, 86, 86, 159, - 105, 92, -390, 86, 86, 86, 86, 86, 86, 86, - 86, 86, 86, 86, 86, -514, 86, 86, -402, -403, - 86, 86, -383, -339, 86, 92, 92, 86, 86, 86, - 92, 86, 86, 86, -403, -403, 86, 86, 86, 86, + 121, 252, 630, -363, 385, 631, 633, 632, 89, 97, + -356, -358, 465, 267, 389, 395, 628, 659, 662, 549, + 552, 564, 565, 566, 567, 568, 569, 570, 571, 573, + 574, 575, 576, 577, 578, 579, 589, 590, 580, 581, + 582, 583, 584, 585, 586, 587, 591, 592, 593, 594, + 595, 596, 597, 598, 599, 600, 601, 602, 603, 604, + 517, 614, 615, 616, 617, 545, 572, 608, 609, 610, + 611, 366, 367, 554, 279, 303, 420, 309, 316, 364, + 163, 183, 177, 206, 197, 550, 172, 283, 321, 284, + 96, 166, 500, 111, 477, 449, 169, 298, 300, 302, + 546, 547, 379, 305, 544, 304, 306, 308, 548, 285, + 369, 193, 188, 297, 281, 186, 286, 41, 287, 361, + 360, 211, 288, 289, 559, 473, 365, 479, 313, 53, + 447, 187, 474, 301, 476, 215, 219, 491, 351, 492, + 181, 182, 481, 494, 210, 213, 214, 259, 357, 358, + 44, 556, 271, 495, 217, 654, 209, 204, 503, 317, + 315, 362, 208, 180, 203, 282, 66, 221, 220, 222, + 443, 444, 445, 446, 290, 291, 383, 490, 200, 189, + 370, 173, 23, 498, 266, 478, 396, 292, 310, 318, + 216, 218, 273, 278, 333, 558, 451, 363, 277, 314, + 496, 185, 270, 299, 265, 499, 655, 174, 398, 293, + 167, 307, 493, 657, 502, 65, 411, 179, 170, 646, + 647, 256, 164, 275, 280, 656, 294, 295, 296, 543, + 320, 319, 311, 171, 551, 201, 272, 207, 191, 178, + 202, 165, 274, 501, 412, 626, 368, 430, 199, 196, + 276, 249, 497, 480, 168, 434, 413, 194, 322, 621, + 622, 623, 384, 356, 323, 324, 192, 263, 471, 472, + 327, 440, 346, 414, 450, 421, 415, 228, 229, 331, + 483, 485, 212, 624, 335, 336, 337, 475, 338, 339, + 340, 341, 388, 57, 59, 98, 101, 100, 660, 661, + 64, 30, 374, 377, 409, 416, 348, 627, 555, 345, + 349, 350, 378, 26, 432, 400, 436, 435, 49, 50, + 51, 54, 55, 56, 58, 60, 61, 52, 542, 393, + 406, 504, 46, 48, 403, 28, 380, 431, 453, 344, + 433, 464, 47, 462, 463, 484, 27, 382, 381, 63, + 45, 439, 441, 442, 325, 342, 391, 636, 505, 386, + 402, 405, 387, 347, 376, 407, 68, 67, 399, 637, + 394, 392, 343, 560, 561, 352, 588, 371, 448, 539, + 538, 537, 536, 535, 534, 533, 532, 328, 329, 330, + 417, 418, 419, 429, 422, 423, 424, 425, 426, 427, + 428, 467, 468, 638, 486, 488, 489, 487, 244, 663, + 372, 373, 247, 640, 641, 99, 642, 644, 643, 29, + 645, 653, 650, 651, 652, 563, 232, 648, -445, -443, + -363, 550, 628, 395, 549, 552, 389, 368, 659, 662, + 393, 267, 328, 329, 330, 465, 366, -236, -363, 663, + -197, 251, 40, -250, -363, -197, -87, -16, -15, -186, + -187, -250, 246, -372, 24, 447, -99, 448, 241, 242, + 86, 78, -363, -9, -113, -8, -120, -85, -184, 452, + -370, -363, 328, 328, -370, 246, -365, 277, 428, -363, + -500, 252, -449, -422, 278, -448, -424, -451, -425, 33, + 237, 239, 238, 562, 274, 16, 393, 248, 14, 13, + 394, 260, 26, 27, 29, 15, 395, 397, 30, 398, + 401, 402, 403, 43, 406, 407, 267, 89, 97, 92, + 285, -235, -363, -398, -390, 118, -393, -385, -386, -388, + -341, -536, -383, 86, 145, 146, 153, 119, 665, -387, + -481, 37, 121, 568, 572, 608, 515, -333, -334, -335, + -336, -337, -338, 553, -363, -537, -535, 92, 102, 104, + 108, 109, 107, 105, 157, 190, 106, 93, 158, -187, + 89, -557, 578, -357, 601, 614, 615, 616, 617, 600, + 62, -507, -515, 245, -513, 156, 195, 263, 191, 14, + 151, 440, 192, 609, 610, 611, 575, 597, 517, 579, + 589, 604, 570, 571, 573, 565, 566, 567, 569, 580, + 582, 596, -516, 592, 602, 603, 588, 612, 613, 650, + 605, 606, 607, 644, 91, 90, 595, 594, 581, 576, + 577, 583, 564, 574, 584, 585, 593, 598, 599, 377, + 111, 378, 379, 507, 369, 81, 380, 252, 447, 71, + 381, 382, 383, 384, 385, 514, 386, 72, 387, 376, + 267, 430, 388, 194, 212, 519, 518, 520, 511, 508, + 506, 509, 510, 512, 513, 586, 587, 591, -136, -138, + 619, -610, -324, -611, 6, 7, 8, 9, -612, 158, + -601, 449, 558, 92, 321, 366, 17, 507, 649, 548, + 649, 548, 168, 165, -436, 168, 117, 174, 173, 250, + 168, -436, -363, 171, 649, 170, 646, 331, -412, -175, + 366, 430, 338, 98, 277, -416, -413, 546, -501, 325, + 321, 297, 247, 114, -176, 257, 256, 112, 507, 245, + 404, 316, 57, 59, -572, -573, 234, 235, 236, -564, + 540, -563, -363, 649, 654, 379, 100, 101, 646, 647, + 28, 246, 390, 273, 485, 483, 484, 486, 487, 488, + 489, -65, -517, -499, 480, 479, -376, 472, 478, 470, + 482, 473, 367, 340, 562, 339, 237, 640, 547, 541, + -351, 414, 450, 504, 505, 391, 451, 491, 493, 474, + 111, 198, 195, 247, 249, 246, 646, 366, 507, 430, + 98, 338, 246, -572, 654, 165, 491, 493, 449, 277, + 428, 42, -442, 440, -441, -443, 492, 503, 90, 91, + 490, -351, 111, 471, 471, -610, -324, -185, -187, -123, + -562, 548, 649, 247, 366, 430, 277, 248, 246, 543, + 546, 249, 507, 245, 328, 390, 273, 338, 98, 170, + 646, -191, -192, -193, 230, 231, 232, 70, 235, 233, + 67, 33, 34, 35, -1, 125, 664, -390, -390, -6, + 667, -6, -390, -363, -363, 160, -257, -261, -258, -260, + -259, -263, -262, 195, 196, 156, 199, 205, 201, 202, + 203, 204, 206, 207, 208, 209, 210, 213, 214, 211, + 32, 212, 263, 191, 192, 193, 194, 215, 177, 197, + 555, 223, 178, 224, 179, 225, 180, 226, 181, 182, + 227, 183, 186, 187, 188, 189, 185, 159, -224, 92, + 33, 86, 159, 92, -216, 269, -197, -250, -242, 159, + 665, -216, -610, -207, -208, 11, -250, -339, -363, 449, + 128, -99, 78, -99, 448, 78, -99, 448, 241, -565, + -566, -567, -569, 241, 448, 447, 242, -118, 159, 285, + 17, -370, -370, 84, -250, -424, 277, -449, -422, 37, + 83, 160, 250, 160, 83, 86, 391, 366, 430, 392, + 507, 246, 404, 249, 277, 405, 366, 430, 246, 249, + 507, 277, 366, 246, 249, 430, 277, 405, 366, 470, + 471, 249, 28, 396, 399, 400, 471, -521, 503, 160, + 117, 114, 115, 116, -390, 135, -405, 128, 129, 130, + 131, 132, 133, 134, 142, 141, 152, 145, 146, 147, + 148, 149, 150, 151, 143, 144, 138, 118, 136, 140, + 137, 120, 155, -187, -390, -398, 62, -388, -388, -388, + -388, -363, -481, -395, -390, 86, 86, 86, 86, 86, + 159, 105, 92, -390, 86, 86, 86, 86, 86, 86, + 86, 86, 86, 86, 86, 86, -514, 86, 86, -402, + -403, 86, 86, -383, -339, 86, 92, 92, 86, 86, + 86, 92, 86, 86, 86, -403, -403, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, 86, - 86, 86, -208, 160, -207, 86, -207, -208, -188, -187, - 33, 34, 33, 34, 33, 34, 33, 34, -613, 636, - 86, 102, 659, 228, 17, -363, 645, -363, -595, 33, - 550, 550, 550, 550, 495, 556, 172, 173, 174, -363, - 171, 250, -363, -410, 252, -410, -410, -234, -363, 273, - 389, 249, 542, 249, -176, -410, -410, -410, -410, -410, - 248, -410, 24, 246, 246, 246, 246, -410, 513, 128, - 128, 60, -574, 176, 160, -564, -215, 86, -595, 654, - 655, 656, -375, 136, 140, -375, -320, 18, -320, 24, - 24, 275, 275, 275, -375, 315, -621, -622, 17, 138, - -373, -622, -373, -373, -375, -623, 248, 480, 44, 276, - 275, -209, -210, 22, -209, 474, 470, -466, 475, 476, - -377, -622, -376, -375, -375, -376, -375, -375, -375, 33, - 246, 249, 506, 338, 640, -621, -621, 32, 32, -500, - -500, -250, -500, -500, 540, -352, -363, -500, -500, -500, - -304, -305, -250, -575, 251, 656, -607, -606, 493, -609, - 495, 165, -443, 165, -443, 89, -424, 277, 277, 160, - 128, 24, -444, 128, 139, -443, -443, -444, -444, -274, - 42, -362, 156, -363, 92, -274, 42, -604, -603, -250, - -208, -188, -187, 87, 87, 87, 550, -595, -500, -500, - -500, -500, -500, -501, -500, -500, -500, -500, -500, -370, - -225, -363, -236, 252, -500, -500, -500, -500, -189, -190, - 147, -390, -363, -193, -3, -146, -145, 122, 123, 125, - 630, 384, 629, 633, 627, -443, 42, -494, 411, 410, - -488, -490, 86, -489, 86, -489, -489, -489, -489, -489, - 86, 86, -491, 86, -491, -491, -488, -492, 86, -492, - -493, 86, -493, -492, -363, -470, 556, -396, -398, -363, - 40, -510, 62, -184, 86, 32, 86, -216, -363, 192, - 170, 644, 36, -511, 62, -184, 86, 32, -208, -139, - 40, -210, 21, 159, 102, 92, -118, -99, 78, -118, - -99, -99, 87, 160, -568, 108, 109, -570, 210, 201, - -363, -116, 92, -535, -7, -11, -8, -9, -10, -47, - -85, -184, 548, 551, -538, -536, 86, 33, 438, 83, - 17, -450, 246, 506, 389, 273, 249, 365, -448, -431, - -428, -426, -362, -424, -427, -426, -453, -339, 470, -140, - 453, 452, 327, -390, -390, -390, -390, -390, 107, 118, - 356, 108, 109, -385, -406, 33, 323, 324, -386, -386, + 86, 86, 86, -208, 160, -207, 86, -207, -208, -188, + -187, 33, 34, 33, 34, 33, 34, 33, 34, -613, + 637, 86, 102, 660, 228, 17, -363, 646, -363, -595, + 33, 551, 551, 551, 551, 496, 557, 172, 173, 174, + -363, 171, 250, -363, -410, 252, -410, -410, -234, -363, + 273, 390, 249, 543, 249, -176, -410, -410, -410, -410, + -410, 248, -410, 24, 246, 246, 246, 246, -410, 514, + 128, 128, 60, -574, 176, 160, -564, -215, 86, -595, + 655, 656, 657, -375, 136, 140, -375, -320, 18, -320, + 24, 24, 275, 275, 275, -375, 315, -621, -622, 17, + 138, -373, -622, -373, -373, -375, -623, 248, 481, 44, + 276, 275, -209, -210, 22, -209, 475, 471, -466, 476, + 477, -377, -622, -376, -375, -375, -376, -375, -375, -375, + 33, 246, 249, 507, 338, 641, -621, -621, 32, 32, + -500, -500, -250, -500, -500, 541, -352, -363, -500, -500, + -500, -304, -305, -250, -575, 251, 657, -607, -606, 494, + -609, 496, 165, -443, 165, -443, 89, -424, 277, 277, + 160, 128, 24, -444, 128, 139, -443, -443, -444, -444, + -274, 42, -362, 156, -363, 92, -274, 42, -604, -603, + -250, -208, -188, -187, 87, 87, 87, 551, -595, -500, + -500, -500, -500, -500, -501, -500, -500, -500, -500, -500, + -370, -225, -363, -236, 252, -500, -500, -500, -500, -189, + -190, 147, -390, -363, -193, -3, -146, -145, 122, 123, + 125, 631, 385, 630, 634, 628, -443, 42, -494, 412, + 411, -488, -490, 86, -489, 86, -489, -489, -489, -489, + -489, 86, 86, -491, 86, -491, -491, -488, -492, 86, + -492, -493, 86, -493, -492, -363, -470, 557, -396, -398, + -363, 40, -510, 62, -184, 86, 32, 86, -216, -363, + 192, 170, 645, 36, -511, 62, -184, 86, 32, -208, + -139, 40, -210, 21, 159, 102, 92, -118, -99, 78, + -118, -99, -99, 87, 160, -568, 108, 109, -570, 210, + 201, -363, -116, 92, -535, -7, -11, -8, -9, -10, + -47, -85, -184, 549, 552, -538, -536, 86, 33, 439, + 83, 17, -450, 246, 507, 390, 273, 249, 366, -448, + -431, -428, -426, -362, -424, -427, -426, -453, -339, 471, + -140, 454, 453, 327, -390, -390, -390, -390, -390, 107, + 118, 356, 108, 109, -385, -406, 33, 323, 324, -386, -386, -386, -386, -386, -386, -386, -386, -386, -386, -386, - -394, -404, -481, 86, 138, 136, 140, 137, 120, -388, - -388, -386, -386, -276, -362, 156, 87, 160, -390, -561, - -560, 122, -390, -390, -390, -390, -417, -419, -339, 86, - -363, -558, -559, 520, 521, 522, 523, 524, 525, 526, - 527, 528, 529, 530, 380, 375, 381, 379, 368, 387, - 382, 383, 194, 537, 538, 531, 532, 533, 534, 535, - 536, -396, -396, -390, -558, -396, -332, 34, 33, -398, - -398, -398, 87, -390, -571, 354, 353, 355, -211, -363, - -396, 87, 87, 87, 102, -398, -398, -396, -386, -396, - -396, -396, -396, -559, -332, -332, -332, -332, 147, -398, - -398, -332, -332, -332, -332, 147, -332, -332, -332, -332, - -332, -332, -332, -332, -332, -332, -332, 87, 87, 87, - 147, -398, -209, -138, -519, -518, -390, 42, -139, -210, - -614, 637, 86, -339, -602, 92, 92, 664, 170, 645, - 17, 506, -363, 17, 246, -363, 102, -363, 102, 496, - 497, 169, 173, 172, -363, 171, -363, -363, 118, -363, - -363, 36, -236, -225, -410, -410, -410, -579, -363, 93, - -432, -429, -426, -363, -363, -422, -363, -352, -250, -410, - -410, -410, -410, -250, -285, 54, 55, 56, -426, -177, - 57, 58, -575, -563, 36, -214, -363, -320, -388, -388, - -390, 365, 506, 246, -426, 277, -621, -375, -375, -353, - -352, -377, -372, -377, -377, -320, -373, -375, -375, -390, - -377, -373, -320, -363, 470, -320, -320, -466, -375, -374, - -363, -374, -410, -352, -353, -353, -250, -250, -299, -306, - -300, -307, 269, 243, 373, 374, 240, 238, 11, 239, - -314, 316, -411, 514, -280, -281, 78, 43, -283, 267, - 415, 408, 279, 283, 96, 284, 448, 285, 248, 287, - 288, 289, 304, 306, 259, 290, 291, 292, 439, 293, - 164, 305, 294, 295, 296, 391, -275, 6, 341, 42, - 52, 53, 462, 461, 559, 556, 280, -363, -579, -577, - 32, -363, 32, -432, -426, -363, -363, 160, 250, -200, - -202, -199, -195, -196, -201, -323, -325, -198, 86, -250, - -187, -363, -443, 160, 494, 496, 497, -607, -444, -607, - -444, 250, 33, 438, -447, 438, 33, -422, -441, 490, - 492, -437, 92, 439, -427, -446, 83, 156, -518, -444, - -444, -446, -446, 155, 160, -605, 495, 496, 234, -209, - 102, -252, -250, -579, -431, -422, -363, -500, -252, -252, - -252, -365, -365, 86, 159, 37, -363, -363, -363, -363, - -319, 160, -318, 17, -364, -363, 36, 92, 159, -147, - -145, 124, -390, -6, 629, -390, -6, -6, -390, -6, - -390, -498, 412, 102, 102, -342, 92, -342, 102, 102, - 102, 562, 87, 92, -435, 83, -512, -399, -556, 618, - -218, 87, -211, -554, -555, -211, -217, -363, -510, -242, - 128, 128, 128, 25, -512, -218, 87, -554, -209, 619, - -139, -206, -205, -390, -363, 24, -118, -99, -566, 159, - 160, -214, -450, -430, -427, -452, 147, -363, -438, 160, - 556, 667, 90, 250, -592, -591, 430, 87, 160, -522, - 251, 513, 92, 664, 446, 228, 229, 107, 356, 108, - 109, -481, -398, -394, -388, -388, -386, -386, -392, 264, - -392, 117, -390, 665, -389, -560, 124, -390, 36, 160, - 36, 160, 84, 160, 87, -488, -390, 159, 87, 87, - 17, 17, 87, -390, 87, 87, 87, 87, 17, 17, - -390, 87, 159, 87, 87, 87, 87, 84, 87, 160, - 87, 87, 87, 87, 160, -398, -398, -390, -398, 87, - 87, 87, -390, -390, -390, -398, 87, -390, -390, -390, - -390, -390, -390, -390, -390, -390, -390, -214, -460, 465, - -460, -460, 160, 160, 160, 87, -139, 86, 102, 160, - 660, -346, -345, 92, -363, -363, 170, 645, -363, 92, - 645, -363, 92, 170, 174, 174, 173, -363, 92, 37, - 24, 24, 314, -235, 86, 86, -250, -250, -250, -581, - 416, -593, 160, 42, -591, 506, -173, 327, -414, 84, - -180, 334, 17, 556, -250, -250, -250, -250, -264, 36, - 17, -194, -251, -363, 86, 87, 160, -363, -363, -363, - -423, 84, -363, -353, -320, -320, -377, -320, -320, 160, - 23, -375, -377, -377, -242, -373, -242, 159, -242, -352, - -487, 36, -215, 160, 21, 269, -249, -360, -246, -248, - 254, -380, -247, 257, -550, 255, 253, 112, 258, 312, - 113, 248, -360, -360, 254, -284, 250, 36, -360, -302, - 248, 359, 312, 255, 21, 269, -301, 248, 113, -363, - 254, 258, 255, 253, -359, 128, -351, 155, 250, 44, - 391, -359, 560, 269, -359, -359, -359, -359, -359, -359, - -359, 286, 286, -359, -359, -359, -359, -359, -359, -359, - -359, -359, -359, -359, 165, -359, -359, -359, -359, -359, - -359, 86, 281, 282, 314, -582, 416, 32, 371, 371, - 372, -593, 367, 43, 32, -181, 365, -305, -303, -374, - 32, -326, -327, -328, -329, -331, -330, 69, 73, 75, - 79, 70, 71, 72, 76, 81, 74, 32, 160, -361, - -366, 36, -363, 92, -361, -187, -202, -200, -361, 86, - -444, -606, -608, 498, 495, 501, -446, -446, 102, 250, - 86, 128, -446, -446, 42, -362, -603, 502, 496, -139, - 160, 83, -252, -226, -227, -228, -229, -257, -339, 196, - 199, 201, 202, 203, 204, 206, 207, 208, 209, 210, - 213, 214, 211, 212, 263, 191, 192, 193, 194, 215, - 177, 197, 554, 178, 179, 180, 181, 182, 183, 186, - 187, 188, 189, 185, -363, -236, -232, 647, -320, -190, - -202, -363, 92, -363, 147, 125, -6, 123, -151, -150, - -149, 126, 627, 633, 125, 125, 125, 87, 87, 87, - 160, 87, 87, 87, 160, 87, 160, 102, -525, 475, - 41, 160, 86, 87, 160, 62, 160, 128, 87, 160, - -390, -363, 92, -390, 192, 87, 62, -139, 92, 160, - -203, 38, 39, 159, 448, -363, -536, 87, -452, 160, - 250, 159, 159, -428, 394, -362, -430, 21, 556, -339, - 40, -346, 128, 664, -363, 87, -392, -392, 117, -388, - -385, 87, 125, -390, 123, -255, -257, 410, 411, -390, - -255, -256, -262, 156, 195, 263, 194, 193, 191, 410, - 411, -274, -419, 553, -203, 87, -363, -390, -390, 87, - -390, -390, 17, -363, -274, -386, -390, -208, -208, 87, - 87, -459, -460, -459, -459, 87, 87, 87, 87, -459, - 87, 87, 87, 87, 87, 87, 87, 87, 87, 87, - 87, 86, 102, 104, 102, 104, -518, -615, 64, 635, - 63, 438, 107, 317, 160, 102, 92, 665, 160, 128, - 92, -363, -363, 17, 246, -363, 17, 174, 92, -594, - 321, 365, 506, 246, 365, 321, 506, 246, -471, 102, - 402, -237, -238, -239, -240, -241, 138, 161, 162, -226, - -215, 86, -215, -584, 477, 418, 428, -359, -382, -381, - 367, 43, -505, 439, 424, 425, -429, 277, -352, -590, - 99, 128, 83, 345, 349, 351, 350, 346, 347, 348, - -408, -409, -407, -411, -352, -577, 86, 86, -184, 36, - 136, -180, 334, 86, 86, 36, -482, 335, -257, -250, - -194, -363, 17, 160, -576, 159, -1, -363, -363, -422, - -375, -320, -390, -390, -320, -375, -375, -377, -363, -242, - -482, -257, 36, -300, 243, 239, -456, 314, 315, -457, - -472, 317, -474, 86, -254, -339, -247, -549, -550, -410, - -363, 113, -549, 113, 86, -254, -339, -339, -303, -339, - -363, -363, -363, -363, -310, -309, -339, -312, 33, -313, - -363, -363, -363, -363, 113, -363, 113, -279, 42, 49, - 50, 51, 334, -359, -359, 198, -282, 42, 438, 440, - 441, -312, 102, 102, 102, 102, 92, 92, 92, -359, - -359, 102, 92, -366, 92, -551, 173, 46, 47, 102, - 102, 102, 102, 42, 92, -287, 42, 297, 301, 298, - 299, 300, 92, 102, 42, 102, 42, 102, 42, -363, - 86, -552, -553, 92, -471, -584, -359, 371, -443, 128, - 128, -382, -586, 96, 419, -586, -589, 327, -183, 506, - 33, -219, 243, 239, -577, -434, -433, -339, -199, -199, - -199, -199, -199, -199, 69, 80, 69, -212, 86, 69, - 74, 69, 74, 69, -328, 69, 80, -434, -201, -215, - -366, 87, -600, -599, -598, -596, 77, 251, 78, -396, - -446, 495, 499, 500, -430, -378, 92, -437, -223, 24, - -250, -250, -503, 307, 308, 87, 160, -257, -322, 19, - 159, 121, -6, -147, -149, -390, -6, -390, 629, 384, - 630, 92, 102, 102, -533, 459, 454, 456, 113, -399, - -520, -519, 62, -184, -211, -512, -555, -518, -363, 665, - 665, 665, 665, 92, 62, -184, -512, -223, -525, -205, - -204, 45, -363, 102, 17, -427, -422, 147, 147, -363, - 395, -438, 92, 417, 92, 246, 665, 92, -346, -385, - -390, 87, -265, 182, 181, -265, 36, 87, 87, -489, - -489, -488, -491, -488, -265, -265, 87, 86, -203, 87, - 24, 87, 87, 87, -390, 87, 87, 160, -508, 515, - -509, 589, -459, -459, -459, -459, -459, -459, -459, -459, - -459, -459, -459, -459, -459, -459, -459, -459, -459, -401, - -400, 269, 460, 642, 642, 460, 642, 642, 87, 160, - -558, 160, -354, 322, -354, -345, 92, 250, 92, 170, - -363, 92, 645, 92, -363, -363, -363, 314, -363, 314, - -363, -363, 92, 92, 87, 160, -339, 87, 36, -243, - -244, -245, -254, -246, -248, 36, -585, 96, -580, 92, - -363, 93, -586, 158, 369, 42, 420, 421, 436, 364, - 102, 102, 426, -578, -363, -182, 246, 365, -588, 53, - 128, 92, -250, -407, -351, 155, 288, -242, 338, -317, - -316, -363, 92, -243, -184, -250, -250, -243, -243, -184, - -483, 337, 21, 102, 146, -216, 84, 159, -202, -251, - -363, 147, 87, -320, -242, -320, -320, -375, -483, -184, - -468, 318, 86, -466, 86, -466, 113, 346, -475, -473, - 269, -308, 46, 48, -257, -547, -363, -545, -547, -363, - -545, -545, -410, -390, -308, -254, 250, 32, 239, -311, - 343, 344, 349, 351, -439, 313, 118, -439, 160, -203, - 160, -363, -274, -274, 32, 92, 92, -252, 87, 160, - 128, 92, -585, -580, 128, -444, 92, 92, -586, 92, - 92, -590, 128, -253, 246, -352, 160, -219, -219, -320, - 160, 128, -221, -220, 83, 84, -222, 83, -220, -220, - 69, -213, 92, 69, 69, -320, -598, -597, 24, -550, - -550, -550, 87, 87, 15, -228, 42, -321, 20, 21, - 147, 125, 123, 125, 125, -363, 87, 87, -495, 620, - -529, -531, 454, 21, 21, 15, 251, 87, -512, 665, - -512, -533, 46, 47, -422, -438, 439, -250, 160, 665, - -255, -293, 92, -390, 87, -390, 87, 92, 87, 92, - -208, 21, 87, 160, 87, 87, 87, 160, 87, 87, - -390, 87, -558, -355, 192, 92, -355, 365, -364, -363, - 17, -363, 92, -363, -471, 314, -471, 314, 246, -363, - -232, -415, 555, -239, -257, 244, -184, 87, 160, -184, - 92, -583, 430, 102, 42, 102, 158, 422, -506, -174, - 96, -252, 33, -219, -587, 96, 128, 664, 86, -359, - -359, -359, 250, -363, 87, 160, -359, -359, 87, 250, - 87, 87, -272, 556, -484, 268, 102, 146, 102, 146, - 102, -361, -202, -363, -320, -576, 159, -320, -484, -458, - 319, 102, -386, 86, -386, 86, -467, 316, 86, 87, - 160, -363, -339, -269, -268, -266, 107, 118, 42, 408, - -267, 96, 155, 302, 305, 304, 280, 303, -298, -379, - 83, 414, 343, 344, -411, 620, 544, 253, 112, 113, - 396, -380, 86, 86, 84, 322, 86, 86, -547, 87, - -308, -339, 42, -311, 42, 357, 313, -309, -363, 155, - -274, 87, -553, 92, -583, 92, -446, -588, 92, -174, - -252, -577, -208, -433, -518, -390, 86, -390, 87, 86, - 69, 11, 19, -383, -390, -398, 649, 651, 652, 252, - -6, 630, 384, -289, 621, 92, 21, 92, -527, 92, - -434, -495, -142, -286, -351, 285, 87, -292, 138, 556, - 87, 87, -459, -459, -462, -461, -465, 460, 314, 468, - -398, 92, 92, 87, 87, 92, -363, 170, 92, 664, - 92, -471, 92, -471, -363, 314, 92, 92, -230, -257, - -178, 556, -272, -245, -178, 21, 556, 368, 42, 102, - 42, 423, 92, -182, 128, 108, 109, -347, -348, 92, - -417, -274, -276, 92, 365, -316, -383, -383, -270, -184, - 36, -271, -314, -411, 365, -141, -140, -270, 86, -485, - 164, 102, 146, 102, 102, -320, -320, -485, -474, 21, - 87, -453, 87, -453, 86, 128, -386, -473, -476, 62, - -266, 107, -386, 92, -276, -277, 42, 301, 297, 128, - 128, -278, 42, 281, 282, -288, 86, 312, 15, 198, - 86, 113, 113, -250, -417, -417, -548, 345, 346, 347, - 352, 349, 350, 348, 351, -548, -417, -417, 86, -440, - -439, -386, -359, -359, 155, -587, -209, -214, -546, -363, - 253, 21, 21, -504, 556, 650, 86, 86, -363, -363, - -343, 622, 102, 92, 456, -289, -496, 623, -523, -466, - -274, 128, 87, 76, 554, 557, 87, -464, 120, 422, - 426, -384, -387, 102, 104, 190, 158, 87, 87, -363, - -350, -349, 92, -232, 92, -232, 92, 314, -471, 555, - -179, 61, 502, 92, 93, 417, 92, 93, 368, -174, - 92, 665, 160, 128, 87, -363, -454, 269, -184, 160, - -314, -351, -363, -142, -454, -273, -315, -363, 92, -502, - 173, 336, 556, 102, 146, 102, -208, -486, 173, 336, - -457, 87, 87, 87, -453, 102, 87, -480, -477, 86, - -314, 271, 138, 92, 92, 102, 86, -513, 32, 92, - -418, 86, 87, 87, 87, 87, -417, 102, -274, -359, - 87, 87, 160, 652, 86, -398, -398, 86, 21, -343, - -497, 624, 92, -532, 459, -526, -524, 454, 455, 456, - 457, 92, 555, 66, 558, -463, -464, 426, -384, -387, - 618, 466, 466, 466, 665, 160, 128, -232, -232, -471, - 92, -233, -363, 312, 439, -348, 92, -420, -455, 321, - 21, -314, -359, -455, 87, 160, -359, -359, 336, 102, - 146, 102, -209, 336, -469, 320, 87, -480, -314, -479, - -478, 319, 272, 86, 87, -390, -402, -359, 87, -291, - -290, 552, -417, -420, 84, -420, 84, -420, 84, -420, - 84, 87, -274, -363, 253, -137, 86, 87, 87, -344, - -363, -527, 92, -534, 251, -530, -531, 458, -524, 21, - 456, 21, 21, -143, 160, 66, 117, 467, 467, 467, - -349, 92, 92, -232, -231, 36, 461, 395, -421, 259, - 357, 358, 96, 556, 343, 344, 362, 361, 360, 363, - 21, -456, -274, -315, -383, -383, 102, 102, 87, 160, - -363, 268, 86, -397, -391, -390, 268, 87, -363, -297, - -295, -296, 83, 473, 310, 311, 87, -548, -548, -548, - -548, -298, 87, 160, -396, 87, 160, -541, 86, 102, - -529, -528, -530, 21, -527, 21, -527, -527, 463, 556, - -463, -232, 92, -359, -359, 92, 92, 342, -359, -359, - -359, -359, -339, 86, -468, -478, -477, -397, 87, 160, - -439, -296, 83, -295, 83, 16, 15, -420, -420, -420, - -420, 86, 87, -363, -544, 32, 87, -540, -539, -340, - -535, -363, 459, 460, 92, -527, 128, 557, -618, -617, - 641, 102, 102, -363, 102, 102, 102, 92, -453, -458, - 87, -391, -294, 307, 308, 32, 173, -294, -396, -543, - -542, -341, 87, 160, 159, 92, 558, 92, 87, -474, - 107, 42, 309, 87, 160, 128, -539, -363, -542, 42, - -390, 159, -363, + -386, -394, -404, -481, 86, 138, 136, 140, 137, 120, + -388, -388, -386, -386, -276, -362, 156, 87, 160, -390, + -561, -560, 122, -390, -390, -390, -390, -417, -419, -339, + 86, -363, -558, -559, 521, 522, 523, 524, 525, 526, + 527, 528, 529, 530, 531, 381, 376, 382, 380, 369, + 388, 383, 384, 194, 538, 539, 532, 533, 534, 535, + 536, 537, -396, -396, -390, -558, -396, -332, 34, 33, + -398, -398, -398, 87, -390, -571, 354, 353, 355, -211, + -363, -396, 87, 87, 87, 102, -398, -398, -396, -386, + -396, -396, -396, -396, -559, -332, -332, -332, -332, 147, + -398, -398, -332, -332, -332, -332, 147, -332, -332, -332, + -332, -332, -332, -332, -332, -332, -332, -332, 87, 87, + 87, 147, -398, -209, -138, -519, -518, -390, 42, -139, + -210, -614, 638, 86, -339, -602, 92, 92, 665, 170, + 646, 17, 507, -363, 17, 246, -363, 102, -363, 102, + 497, 498, 169, 173, 172, -363, 171, -363, -363, 118, + -363, -363, 36, -236, -225, -410, -410, -410, -579, -363, + 93, -432, -429, -426, -363, -363, -422, -363, -352, -250, + -410, -410, -410, -410, -250, -285, 54, 55, 56, -426, + -177, 57, 58, -575, -563, 36, -214, -363, -320, -388, + -388, -390, 366, 507, 246, -426, 277, -621, -375, -375, + -353, -352, -377, -372, -377, -377, -320, -373, -375, -375, + -390, -377, -373, -320, -363, 471, -320, -320, -466, -375, + -374, -363, -374, -410, -352, -353, -353, -250, -250, -299, + -306, -300, -307, 269, 243, 374, 375, 240, 238, 11, + 239, -314, 316, -411, 515, -280, -281, 78, 43, -283, + 267, 416, 409, 279, 283, 96, 284, 449, 285, 248, + 287, 288, 289, 304, 306, 259, 290, 291, 292, 440, + 293, 164, 305, 294, 295, 296, 392, -275, 6, 341, + 42, 52, 53, 463, 462, 560, 557, 280, -363, -579, + -577, 32, -363, 32, -432, -426, -363, -363, 160, 250, + -200, -202, -199, -195, -196, -201, -323, -325, -198, 86, + -250, -187, -363, -443, 160, 495, 497, 498, -607, -444, + -607, -444, 250, 33, 439, -447, 439, 33, -422, -441, + 491, 493, -437, 92, 440, -427, -446, 83, 156, -518, + -444, -444, -446, -446, 155, 160, -605, 496, 497, 234, + -209, 102, -252, -250, -579, -431, -422, -363, -500, -252, + -252, -252, -365, -365, 86, 159, 37, -363, -363, -363, + -363, -319, 160, -318, 17, -364, -363, 36, 92, 159, + -147, -145, 124, -390, -6, 630, -390, -6, -6, -390, + -6, -390, -498, 413, 102, 102, -342, 92, -342, 102, + 102, 102, 563, 87, 92, -435, 83, -512, -399, -556, + 619, -218, 87, -211, -554, -555, -211, -217, -363, -510, + -242, 128, 128, 128, 25, -512, -218, 87, -554, -209, + 620, -139, -206, -205, -390, -363, 24, -118, -99, -566, + 159, 160, -214, -450, -430, -427, -452, 147, -363, -438, + 160, 557, 668, 90, 250, -592, -591, 431, 87, 160, + -522, 251, 514, 92, 665, 447, 228, 229, 107, 356, + 108, 109, -481, -398, -394, -388, -388, -386, -386, -392, + 264, -392, 117, -390, 666, -389, -560, 124, -390, 36, + 160, 36, 160, 84, 160, 87, -488, -390, 159, 87, + 87, 17, 17, 87, -390, 87, 87, 87, 87, 17, + 17, -390, 87, 159, 87, 87, 87, 87, 84, 87, + 160, 87, 87, 87, 87, 160, -398, -398, -390, -398, + 87, 87, 87, -390, -390, -390, -398, 87, -390, -390, + -390, -390, -390, -390, -390, -390, -390, -390, -214, -460, + 466, -460, -460, 160, 160, 160, 87, -139, 86, 102, + 160, 661, -346, -345, 92, -363, -363, 170, 646, -363, + 92, 646, -363, 92, 170, 174, 174, 173, -363, 92, + 37, 24, 24, 314, -235, 86, 86, -250, -250, -250, + -581, 417, -593, 160, 42, -591, 507, -173, 327, -414, + 84, -180, 334, 17, 557, -250, -250, -250, -250, -264, + 36, 17, -194, -251, -363, 86, 87, 160, -363, -363, + -363, -423, 84, -363, -353, -320, -320, -377, -320, -320, + 160, 23, -375, -377, -377, -242, -373, -242, 159, -242, + -352, -487, 36, -215, 160, 21, 269, -249, -360, -246, + -248, 254, -380, -247, 257, -550, 255, 253, 112, 258, + 312, 113, 248, -360, -360, 254, -284, 250, 36, -360, + -302, 248, 359, 312, 255, 21, 269, -301, 248, 113, + -363, 254, 258, 255, 253, -359, 128, -351, 155, 250, + 44, 392, -359, 561, 269, -359, -359, -359, -359, -359, + -359, -359, 286, 286, -359, -359, -359, -359, -359, -359, + -359, -359, -359, -359, -359, 165, -359, -359, -359, -359, + -359, -359, 86, 281, 282, 314, -582, 417, 32, 372, + 372, 373, -593, 368, 43, 32, -181, 366, -305, -303, + -374, 32, -326, -327, -328, -329, -331, -330, 69, 73, + 75, 79, 70, 71, 72, 76, 81, 74, 32, 160, + -361, -366, 36, -363, 92, -361, -187, -202, -200, -361, + 86, -444, -606, -608, 499, 496, 502, -446, -446, 102, + 250, 86, 128, -446, -446, 42, -362, -603, 503, 497, + -139, 160, 83, -252, -226, -227, -228, -229, -257, -339, + 196, 199, 201, 202, 203, 204, 206, 207, 208, 209, + 210, 213, 214, 211, 212, 263, 191, 192, 193, 194, + 215, 177, 197, 555, 178, 179, 180, 181, 182, 183, + 186, 187, 188, 189, 185, -363, -236, -232, 648, -320, + -190, -202, -363, 92, -363, 147, 125, -6, 123, -151, + -150, -149, 126, 628, 634, 125, 125, 125, 87, 87, + 87, 160, 87, 87, 87, 160, 87, 160, 102, -525, + 476, 41, 160, 86, 87, 160, 62, 160, 128, 87, + 160, -390, -363, 92, -390, 192, 87, 62, -139, 92, + 160, -203, 38, 39, 159, 449, -363, -536, 87, -452, + 160, 250, 159, 159, -428, 395, -362, -430, 21, 557, + -339, 40, -346, 128, 665, -363, 87, -392, -392, 117, + -388, -385, 87, 125, -390, 123, -255, -257, 411, 412, + -390, -255, -256, -262, 156, 195, 263, 194, 193, 191, + 411, 412, -274, -419, 554, -203, 87, -363, -390, -390, + 87, -390, -390, 17, -363, -274, -386, -390, -208, -208, + 87, 87, -459, -460, -459, -459, 87, 87, 87, 87, + -459, 87, 87, 87, 87, 87, 87, 87, 87, 87, + 87, 87, 86, 102, 104, 102, 104, -518, -615, 64, + 636, 63, 439, 107, 317, 160, 102, 92, 666, 160, + 128, 92, -363, -363, 17, 246, -363, 17, 174, 92, + -594, 321, 366, 507, 246, 366, 321, 507, 246, -471, + 102, 403, -237, -238, -239, -240, -241, 138, 161, 162, + -226, -215, 86, -215, -584, 478, 419, 429, -359, -382, + -381, 368, 43, -505, 440, 425, 426, -429, 277, -352, + -590, 99, 128, 83, 345, 349, 351, 350, 346, 347, + 348, -408, -409, -407, -411, -352, -577, 86, 86, -184, + 36, 136, -180, 334, 86, 86, 36, -482, 335, -257, + -250, -194, -363, 17, 160, -576, 159, -1, -363, -363, + -422, -375, -320, -390, -390, -320, -375, -375, -377, -363, + -242, -482, -257, 36, -300, 243, 239, -456, 314, 315, + -457, -472, 317, -474, 86, -254, -339, -247, -549, -550, + -410, -363, 113, -549, 113, 86, -254, -339, -339, -303, + -339, -363, -363, -363, -363, -310, -309, -339, -312, 33, + -313, -363, -363, -363, -363, 113, -363, 113, -279, 42, + 49, 50, 51, 334, -359, -359, 198, -282, 42, 439, + 441, 442, -312, 102, 102, 102, 102, 92, 92, 92, + -359, -359, 102, 92, -366, 92, -551, 173, 46, 47, + 102, 102, 102, 102, 42, 92, -287, 42, 297, 301, + 298, 299, 300, 92, 102, 42, 102, 42, 102, 42, + -363, 86, -552, -553, 92, -471, -584, -359, 372, -443, + 128, 128, -382, -586, 96, 420, -586, -589, 327, -183, + 507, 33, -219, 243, 239, -577, -434, -433, -339, -199, + -199, -199, -199, -199, -199, 69, 80, 69, -212, 86, + 69, 74, 69, 74, 69, -328, 69, 80, -434, -201, + -215, -366, 87, -600, -599, -598, -596, 77, 251, 78, + -396, -446, 496, 500, 501, -430, -378, 92, -437, -223, + 24, -250, -250, -503, 307, 308, 87, 160, -257, -322, + 19, 159, 121, -6, -147, -149, -390, -6, -390, 630, + 385, 631, 92, 102, 102, -533, 460, 455, 457, 113, + -399, -520, -519, 62, -184, -211, -512, -555, -518, -363, + 666, 666, 666, 666, 92, 62, -184, -512, -223, -525, + -205, -204, 45, -363, 102, 17, -427, -422, 147, 147, + -363, 396, -438, 92, 418, 92, 246, 666, 92, -346, + -385, -390, 87, -265, 182, 181, -265, 36, 87, 87, + -489, -489, -488, -491, -488, -265, -265, 87, 86, -203, + 87, 24, 87, 87, 87, -390, 87, 87, 160, -508, + 516, -509, 590, -459, -459, -459, -459, -459, -459, -459, + -459, -459, -459, -459, -459, -459, -459, -459, -459, -459, + -401, -400, 269, 461, 643, 643, 461, 643, 643, 87, + 160, -558, 160, -354, 322, -354, -345, 92, 250, 92, + 170, -363, 92, 646, 92, -363, -363, -363, 314, -363, + 314, -363, -363, 92, 92, 87, 160, -339, 87, 36, + -243, -244, -245, -254, -246, -248, 36, -585, 96, -580, + 92, -363, 93, -586, 158, 370, 42, 421, 422, 437, + 365, 102, 102, 427, -578, -363, -182, 246, 366, -588, + 53, 128, 92, -250, -407, -351, 155, 288, -242, 338, + -317, -316, -363, 92, -243, -184, -250, -250, -243, -243, + -184, -483, 337, 21, 102, 146, -216, 84, 159, -202, + -251, -363, 147, 87, -320, -242, -320, -320, -375, -483, + -184, -468, 318, 86, -466, 86, -466, 113, 346, -475, + -473, 269, -308, 46, 48, -257, -547, -363, -545, -547, + -363, -545, -545, -410, -390, -308, -254, 250, 32, 239, + -311, 343, 344, 349, 351, -439, 313, 118, -439, 160, + -203, 160, -363, -274, -274, 32, 92, 92, -252, 87, + 160, 128, 92, -585, -580, 128, -444, 92, 92, -586, + 92, 92, -590, 128, -253, 246, -352, 160, -219, -219, + -320, 160, 128, -221, -220, 83, 84, -222, 83, -220, + -220, 69, -213, 92, 69, 69, -320, -598, -597, 24, + -550, -550, -550, 87, 87, 15, -228, 42, -321, 20, + 21, 147, 125, 123, 125, 125, -363, 87, 87, -495, + 621, -529, -531, 455, 21, 21, 15, 251, 87, -512, + 666, -512, -533, 46, 47, -422, -438, 440, -250, 160, + 666, -255, -293, 92, -390, 87, -390, 87, 92, 87, + 92, -208, 21, 87, 160, 87, 87, 87, 160, 87, + 87, -390, 87, -558, -355, 192, 92, -355, 366, -364, + -363, 17, -363, 92, -363, -471, 314, -471, 314, 246, + -363, -232, -415, 556, -239, -257, 244, -184, 87, 160, + -184, 92, -583, 431, 102, 42, 102, 158, 423, -506, + -174, 96, -252, 33, -219, -587, 96, 128, 665, 86, + -359, -359, -359, 250, -363, 87, 160, -359, -359, 87, + 250, 87, 87, -272, 557, -484, 268, 102, 146, 102, + 146, 102, -361, -202, -363, -320, -576, 159, -320, -484, + -458, 319, 102, -386, 86, -386, 86, -467, 316, 86, + 87, 160, -363, -339, -269, -268, -266, 107, 118, 42, + 409, -267, 96, 155, 302, 305, 304, 280, 303, -298, + -379, 83, 415, 343, 344, -411, 621, 545, 253, 112, + 113, 397, -380, 86, 86, 84, 322, 86, 86, -547, + 87, -308, -339, 42, -311, 42, 357, 313, -309, -363, + 155, -274, 87, -553, 92, -583, 92, -446, -588, 92, + -174, -252, -577, -208, -433, -518, -390, 86, -390, 87, + 86, 69, 11, 19, -383, -390, -398, 650, 652, 653, + 252, -6, 631, 385, -289, 622, 92, 21, 92, -527, + 92, -434, -495, -142, -286, -351, 285, 87, -292, 138, + 557, 87, 87, -459, -459, -462, -461, -465, 461, 314, + 469, -398, 92, 92, 87, 87, 92, -363, 170, 92, + 665, 92, -471, 92, -471, -363, 314, 92, 92, -230, + -257, -178, 557, -272, -245, -178, 21, 557, 369, 42, + 102, 42, 424, 92, -182, 128, 108, 109, -347, -348, + 92, -417, -274, -276, 92, 366, -316, -383, -383, -270, + -184, 36, -271, -314, -411, 366, -141, -140, -270, 86, + -485, 164, 102, 146, 102, 102, -320, -320, -485, -474, + 21, 87, -453, 87, -453, 86, 128, -386, -473, -476, + 62, -266, 107, -386, 92, -276, -277, 42, 301, 297, + 128, 128, -278, 42, 281, 282, -288, 86, 312, 15, + 198, 86, 113, 113, -250, -417, -417, -548, 345, 346, + 347, 352, 349, 350, 348, 351, -548, -417, -417, 86, + -440, -439, -386, -359, -359, 155, -587, -209, -214, -546, + -363, 253, 21, 21, -504, 557, 651, 86, 86, -363, + -363, -343, 623, 102, 92, 457, -289, -496, 624, -523, + -466, -274, 128, 87, 76, 555, 558, 87, -464, 120, + 423, 427, -384, -387, 102, 104, 190, 158, 87, 87, + -363, -350, -349, 92, -232, 92, -232, 92, 314, -471, + 556, -179, 61, 503, 92, 93, 418, 92, 93, 369, + -174, 92, 666, 160, 128, 87, -363, -454, 269, -184, + 160, -314, -351, -363, -142, -454, -273, -315, -363, 92, + -502, 173, 336, 557, 102, 146, 102, -208, -486, 173, + 336, -457, 87, 87, 87, -453, 102, 87, -480, -477, + 86, -314, 271, 138, 92, 92, 102, 86, -513, 32, + 92, -418, 86, 87, 87, 87, 87, -417, 102, -274, + -359, 87, 87, 160, 653, 86, -398, -398, 86, 21, + -343, -497, 625, 92, -532, 460, -526, -524, 455, 456, + 457, 458, 92, 556, 66, 559, -463, -464, 427, -384, + -387, 619, 467, 467, 467, 666, 160, 128, -232, -232, + -471, 92, -233, -363, 312, 440, -348, 92, -420, -455, + 321, 21, -314, -359, -455, 87, 160, -359, -359, 336, + 102, 146, 102, -209, 336, -469, 320, 87, -480, -314, + -479, -478, 319, 272, 86, 87, -390, -402, -359, 87, + -291, -290, 553, -417, -420, 84, -420, 84, -420, 84, + -420, 84, 87, -274, -363, 253, -137, 86, 87, 87, + -344, -363, -527, 92, -534, 251, -530, -531, 459, -524, + 21, 457, 21, 21, -143, 160, 66, 117, 468, 468, + 468, -349, 92, 92, -232, -231, 36, 462, 396, -421, + 259, 357, 358, 96, 557, 343, 344, 362, 361, 360, + 363, 364, 21, -456, -274, -315, -383, -383, 102, 102, + 87, 160, -363, 268, 86, -397, -391, -390, 268, 87, + -363, -297, -295, -296, 83, 474, 310, 311, 87, -548, + -548, -548, -548, -298, 87, 160, -396, 87, 160, -541, + 86, 102, -529, -528, -530, 21, -527, 21, -527, -527, + 464, 557, -463, -232, 92, -359, -359, 92, 92, 342, + -359, -359, -359, -359, -339, 86, -468, -478, -477, -397, + 87, 160, -439, -296, 83, -295, 83, 16, 15, -420, + -420, -420, -420, 86, 87, -363, -544, 32, 87, -540, + -539, -340, -535, -363, 460, 461, 92, -527, 128, 558, + -618, -617, 642, 102, 102, -363, 102, 102, 102, 92, + -453, -458, 87, -391, -294, 307, 308, 32, 173, -294, + -396, -543, -542, -341, 87, 160, 159, 92, 559, 92, + 87, -474, 107, 42, 309, 87, 160, 128, -539, -363, + -542, 42, -390, 159, -363, } var yyDef = [...]int{ @@ -9738,399 +9766,399 @@ var yyDef = [...]int{ 411, 412, 414, 413, -2, 0, 0, 736, 0, 0, 0, 814, 0, 0, 0, 857, 875, 23, 0, 7, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, - 0, 0, 19, 0, 19, 0, 0, 0, 1424, 1425, - 1426, 1427, 2230, 2200, -2, 1962, 1936, 2124, 2125, 2019, - 2032, 2268, 2269, 2270, 2271, 2272, 2273, 2274, 2275, 2276, - 2277, 2278, 2279, 2280, 2281, 2282, 2283, 2284, 2285, 2286, - 2287, 2288, 2289, 2290, 2291, 2292, 2293, 2294, 2295, 2296, - 2297, 2298, 2299, 2300, 2301, 2302, 2303, 2304, 2305, 2306, - 2307, 2308, 2309, 2310, 2311, 2312, 2313, 2314, 2315, 2316, - 2317, 1893, 1894, 1895, 1896, 1897, 1898, 1899, 1900, 1901, - 1902, 1903, 1904, 1905, 1906, 1907, 1908, 1909, 1910, 1911, - 1912, 1913, 1914, 1915, 1916, 1917, 1918, 1919, 1920, 1921, - 1922, 1923, 1924, 1925, 1926, 1927, 1928, 1929, 1930, 1931, - 1932, 1933, 1934, 1935, 1937, 1938, 1939, 1940, 1941, 1942, - 1943, 1944, 1945, 1946, 1947, 1948, 1949, 1950, 1951, 1952, - 1953, 1954, 1955, 1956, 1957, 1958, 1959, 1960, 1961, 1963, - 1964, 1965, 1966, 1967, 1968, 1969, 1970, 1971, 1972, 1973, - 1974, 1975, 1976, 1977, 1978, 1979, 1980, 1981, 1982, 1983, - 1984, 1985, 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, - 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, - 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013, - 2014, 2015, 2016, 2017, 2018, 2020, 2021, 2022, 2023, 2024, - 2025, 2026, 2027, 2028, 2029, 2030, 2031, 2034, 2035, 2036, - 2037, 2038, 2039, 2040, 2041, 2042, 2043, 2044, 2045, 2046, - 2047, 2048, 2049, 2050, 2051, 2052, 2053, 2054, 2055, 2056, - 2057, 2058, 2059, 2060, 2061, 2062, 2063, 2064, 2065, 2066, - 2067, 2068, 2069, 2070, 2071, 2072, 2073, 2074, 2075, 2076, - 2077, 2078, 2079, 2080, 2081, 2082, 2083, 2084, 2085, 2086, - 2087, 2088, 2089, 2090, 2091, 2092, 2093, 2094, 2095, 2096, - 2097, 2098, 2099, 2100, 2101, 2102, 2103, 2104, 2105, 2106, - 2107, 2108, 2109, 2110, 2111, 2112, 2113, 2114, 2115, 2116, - 2117, 2118, 2119, 2120, 2121, 2122, 2123, 2126, 2127, 2128, - 2129, 2130, 2131, 2132, 2133, 2134, 2135, 2136, 2137, 2138, - 2139, 2140, 2141, 2142, 2143, 2144, 2145, 2146, 2147, 2148, - 2149, 2150, 2151, 2152, 2153, 2154, 2155, 2156, -2, 2158, - 2159, 2160, 2161, 2162, 2163, 2164, 2165, 2166, 2167, 2168, - 2169, 2170, 2171, 2172, 2173, 2174, 2175, 2176, 2177, 2178, - 2179, 2180, 2181, 2182, 2183, 2184, 2185, 2186, 2187, 2188, - 2189, 2190, 2191, 2192, 2193, 2194, 2195, 2196, 2197, 2198, - 2199, 2201, 2202, 2203, 2204, 2205, 2206, 2207, 2208, 2209, - 2210, 2211, 2212, 2213, 2214, 2215, -2, -2, -2, 2219, - 2220, 2221, 2222, 2223, 2224, 2225, 2226, 2227, 2228, 2229, - 2231, 2232, 2233, 2234, 2235, 2236, 2237, 2238, 2239, 2240, - 2241, 2242, 2243, 2244, 2245, 2246, 2247, 2248, 2249, 2250, - 2251, 2252, 2253, 2254, 2255, 2256, 2257, 0, 314, 312, - 1906, 1936, 1962, 2019, 2032, 2033, 2072, 2124, 2125, 2157, - 2200, 2216, 2217, 2218, 2230, 0, 0, 1012, 0, 784, - 0, 0, 789, 1371, 784, 351, 725, 726, 814, 840, - 685, 0, 389, 0, 1952, 393, 2207, 0, 0, 0, - 0, 682, 383, 384, 385, 386, 387, 388, 0, 0, - 985, 0, 0, 379, 0, 345, 2022, 2229, 1428, 0, - 0, 0, 0, 0, 201, 1138, 203, 1140, 207, 215, - 0, 0, 0, 220, 221, 224, 225, 226, 227, 228, - 0, 232, 0, 234, 237, 0, 239, 240, 0, 243, - 244, 245, 0, 255, 256, 257, 1141, 1142, 1143, -2, - 130, 1010, 1864, 1750, 0, 1757, 1770, 1781, 1510, 1511, - 1512, 1513, 0, 0, 0, 0, 0, 0, 1521, 1522, - 0, 1552, 2272, 2313, 2314, 0, 1530, 1531, 1532, 1533, - 1534, 1535, 0, 141, 153, 154, 1803, 1804, 1805, 1806, - 1807, 1808, 1809, 0, 1811, 1812, 1813, 1721, 1497, 1424, - 0, 2281, 0, 2303, 2308, 2309, 2310, 2311, 2302, 0, - 0, 1705, 0, 1695, 0, 0, -2, -2, 0, 0, - 2097, -2, 2315, 2316, 2317, 2278, 2299, 2307, 2282, 2283, - 2306, 2274, 2275, 2276, 2269, 2270, 2271, 2273, 2285, 2287, - 2298, 0, 2294, 2304, 2305, 2205, 0, 0, 2252, 0, - 0, 0, 2247, 155, 156, -2, -2, -2, -2, -2, + 0, 0, 19, 0, 19, 0, 0, 0, 1425, 1426, + 1427, 1428, 2232, 2202, -2, 1964, 1938, 2126, 2127, 2021, + 2034, 2270, 2271, 2272, 2273, 2274, 2275, 2276, 2277, 2278, + 2279, 2280, 2281, 2282, 2283, 2284, 2285, 2286, 2287, 2288, + 2289, 2290, 2291, 2292, 2293, 2294, 2295, 2296, 2297, 2298, + 2299, 2300, 2301, 2302, 2303, 2304, 2305, 2306, 2307, 2308, + 2309, 2310, 2311, 2312, 2313, 2314, 2315, 2316, 2317, 2318, + 2319, 1894, 1895, 1896, 1897, 1898, 1899, 1900, 1901, 1902, + 1903, 1904, 1905, 1906, 1907, 1908, 1909, 1910, 1911, 1912, + 1913, 1914, 1915, 1916, 1917, 1918, 1919, 1920, 1921, 1922, + 1923, 1924, 1925, 1926, 1927, 1928, 1929, 1930, 1931, 1932, + 1933, 1934, 1935, 1936, 1937, 1939, 1940, 1941, 1942, 1943, + 1944, 1945, 1946, 1947, 1948, 1949, 1950, 1951, 1952, 1953, + 1954, 1955, 1956, 1957, 1958, 1959, 1960, 1961, 1962, 1963, + 1965, 1966, 1967, 1968, 1969, 1970, 1971, 1972, 1973, 1974, + 1975, 1976, 1977, 1978, 1979, 1980, 1981, 1982, 1983, 1984, + 1985, 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1994, + 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, + 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, + 2015, 2016, 2017, 2018, 2019, 2020, 2022, 2023, 2024, 2025, + 2026, 2027, 2028, 2029, 2030, 2031, 2032, 2033, 2036, 2037, + 2038, 2039, 2040, 2041, 2042, 2043, 2044, 2045, 2046, 2047, + 2048, 2049, 2050, 2051, 2052, 2053, 2054, 2055, 2056, 2057, + 2058, 2059, 2060, 2061, 2062, 2063, 2064, 2065, 2066, 2067, + 2068, 2069, 2070, 2071, 2072, 2073, 2074, 2075, 2076, 2077, + 2078, 2079, 2080, 2081, 2082, 2083, 2084, 2085, 2086, 2087, + 2088, 2089, 2090, 2091, 2092, 2093, 2094, 2095, 2096, 2097, + 2098, 2099, 2100, 2101, 2102, 2103, 2104, 2105, 2106, 2107, + 2108, 2109, 2110, 2111, 2112, 2113, 2114, 2115, 2116, 2117, + 2118, 2119, 2120, 2121, 2122, 2123, 2124, 2125, 2128, 2129, + 2130, 2131, 2132, 2133, 2134, 2135, 2136, 2137, 2138, 2139, + 2140, 2141, 2142, 2143, 2144, 2145, 2146, 2147, 2148, 2149, + 2150, 2151, 2152, 2153, 2154, 2155, 2156, 2157, 2158, -2, + 2160, 2161, 2162, 2163, 2164, 2165, 2166, 2167, 2168, 2169, + 2170, 2171, 2172, 2173, 2174, 2175, 2176, 2177, 2178, 2179, + 2180, 2181, 2182, 2183, 2184, 2185, 2186, 2187, 2188, 2189, + 2190, 2191, 2192, 2193, 2194, 2195, 2196, 2197, 2198, 2199, + 2200, 2201, 2203, 2204, 2205, 2206, 2207, 2208, 2209, 2210, + 2211, 2212, 2213, 2214, 2215, 2216, 2217, -2, -2, -2, + 2221, 2222, 2223, 2224, 2225, 2226, 2227, 2228, 2229, 2230, + 2231, 2233, 2234, 2235, 2236, 2237, 2238, 2239, 2240, 2241, + 2242, 2243, 2244, 2245, 2246, 2247, 2248, 2249, 2250, 2251, + 2252, 2253, 2254, 2255, 2256, 2257, 2258, 2259, 0, 314, + 312, 1908, 1938, 1964, 2021, 2034, 2035, 2074, 2126, 2127, + 2159, 2202, 2218, 2219, 2220, 2232, 0, 0, 1012, 0, + 784, 0, 0, 789, 1372, 784, 351, 725, 726, 814, + 840, 685, 0, 389, 0, 1954, 393, 2209, 0, 0, + 0, 0, 682, 383, 384, 385, 386, 387, 388, 0, + 0, 985, 0, 0, 379, 0, 345, 2024, 2231, 1429, + 0, 0, 0, 0, 0, 201, 1138, 203, 1140, 207, + 215, 0, 0, 0, 220, 221, 224, 225, 226, 227, + 228, 0, 232, 0, 234, 237, 0, 239, 240, 0, + 243, 244, 245, 0, 255, 256, 257, 1141, 1142, 1143, + -2, 130, 1010, 1865, 1751, 0, 1758, 1771, 1782, 1511, + 1512, 1513, 1514, 0, 0, 0, 0, 0, 0, 1522, + 1523, 0, 1553, 2274, 2315, 2316, 0, 1531, 1532, 1533, + 1534, 1535, 1536, 0, 141, 153, 154, 1804, 1805, 1806, + 1807, 1808, 1809, 1810, 0, 1812, 1813, 1814, 1722, 1498, + 1425, 0, 2283, 0, 2305, 2310, 2311, 2312, 2313, 2304, + 0, 0, 1706, 0, 1696, 0, 0, -2, -2, 0, + 0, 2099, -2, 2317, 2318, 2319, 2280, 2301, 2309, 2284, + 2285, 2308, 2276, 2277, 2278, 2271, 2272, 2273, 2275, 2287, + 2289, 2300, 0, 2296, 2306, 2307, 2207, 0, 0, 2254, + 0, 0, 0, 2249, 155, 156, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, - -2, -2, 1716, -2, 1718, -2, 1720, -2, 1723, -2, - -2, -2, -2, 1728, 1729, -2, 1731, -2, -2, -2, - -2, -2, -2, -2, 1707, 1708, 1709, 1710, 1699, 1700, - 1701, 1702, 1703, 1704, -2, -2, -2, 840, 933, 0, - 840, 0, 815, 862, 865, 868, 871, 818, 0, 0, - 103, 104, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 340, 341, 329, 331, 0, 335, 0, 0, 331, - 328, 322, 0, 1181, 1181, 1181, 0, 0, 0, 1181, - 1181, 1181, 1181, 1181, 0, 1181, 0, 0, 0, 0, - 0, 1181, 0, 1047, 1145, 1146, 1147, 1179, 1180, 1257, - 0, 0, 0, 741, 737, 738, 739, 740, 828, 0, - 830, 833, 0, 0, 662, 662, 900, 900, 0, 608, - 0, 0, 0, 662, 0, 622, 614, 0, 0, 0, - 662, 0, 0, 835, 835, 0, 665, 672, 662, 662, - -2, 662, 662, 659, 662, 0, 0, 1195, 628, 629, - 630, 614, 614, 633, 634, 635, 645, 646, 673, 1888, - 0, 0, 536, 536, 0, 536, 536, 0, 536, 536, - 536, 0, 743, 1978, 2067, 1959, 2038, 1916, 2022, 2229, - 0, 287, 2097, 292, 0, 1961, 1981, 0, 0, 2000, - 0, -2, 0, 367, 840, 0, 0, 814, 0, 0, - 0, 0, 536, 536, 536, 536, 536, 1256, 536, 536, - 536, 536, 536, 0, 0, 0, 536, 536, 536, 536, - 0, 876, 877, 879, 880, 881, 882, 883, 884, 885, - 886, 887, 888, 5, 6, 19, 0, 0, 0, 0, - 0, 0, 109, 108, 0, 1865, 1883, 1816, 1817, 1818, - 1870, 1820, 1874, 1874, 1874, 1874, 1849, 1850, 1851, 1852, - 1853, 1854, 1855, 1856, 1857, 1858, 1874, 1874, 0, 0, - 1863, 1840, 1872, 1872, 1872, 1870, 1867, 1821, 1822, 1823, + -2, -2, -2, 1717, -2, 1719, -2, 1721, -2, 1724, + -2, -2, -2, -2, 1729, 1730, -2, 1732, -2, -2, + -2, -2, -2, -2, -2, 1708, 1709, 1710, 1711, 1700, + 1701, 1702, 1703, 1704, 1705, -2, -2, -2, 840, 933, + 0, 840, 0, 815, 862, 865, 868, 871, 818, 0, + 0, 103, 104, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 340, 341, 329, 331, 0, 335, 0, 0, + 331, 328, 322, 0, 1182, 1182, 1182, 0, 0, 0, + 1182, 1182, 1182, 1182, 1182, 0, 1182, 0, 0, 0, + 0, 0, 1182, 0, 1047, 1145, 1146, 1147, 1180, 1181, + 1258, 0, 0, 0, 741, 737, 738, 739, 740, 828, + 0, 830, 833, 0, 0, 662, 662, 900, 900, 0, + 608, 0, 0, 0, 662, 0, 622, 614, 0, 0, + 0, 662, 0, 0, 835, 835, 0, 665, 672, 662, + 662, -2, 662, 662, 659, 662, 0, 0, 1196, 628, + 629, 630, 614, 614, 633, 634, 635, 645, 646, 673, + 1889, 0, 0, 536, 536, 0, 536, 536, 0, 536, + 536, 536, 0, 743, 1980, 2069, 1961, 2040, 1918, 2024, + 2231, 0, 287, 2099, 292, 0, 1963, 1983, 0, 0, + 2002, 0, -2, 0, 367, 840, 0, 0, 814, 0, + 0, 0, 0, 536, 536, 536, 536, 536, 1257, 536, + 536, 536, 536, 536, 0, 0, 0, 536, 536, 536, + 536, 0, 876, 877, 879, 880, 881, 882, 883, 884, + 885, 886, 887, 888, 5, 6, 19, 0, 0, 0, + 0, 0, 0, 109, 108, 0, 1866, 1884, 1817, 1818, + 1819, 1871, 1821, 1875, 1875, 1875, 1875, 1850, 1851, 1852, + 1853, 1854, 1855, 1856, 1857, 1858, 1859, 1875, 1875, 0, + 0, 1864, 1841, 1873, 1873, 1873, 1871, 1868, 1822, 1823, 1824, 1825, 1826, 1827, 1828, 1829, 1830, 1831, 1832, 1833, - 1834, 1877, 1877, 1880, 1880, 1877, 0, 429, 427, 428, - 1746, 0, 0, 0, 0, 784, 788, 1369, 0, 0, - 0, 840, -2, 0, 0, 686, 390, 1429, 0, 0, - 394, 0, 395, 0, 0, 397, 0, 0, 0, 418, - 0, 421, 405, 406, 407, 408, 401, 0, 181, 0, - 381, 382, 0, 0, 347, 0, 0, 0, 537, 0, - 0, 0, 0, 0, 0, 212, 208, 216, 219, 229, - 236, 0, 248, 250, 253, 209, 217, 222, 223, 230, - 251, 210, 213, 214, 218, 252, 254, 211, 231, 235, - 249, 233, 238, 241, 242, 247, 0, 182, 0, 0, - 0, 0, 0, 1756, 0, 0, 1789, 1790, 1791, 1792, - 1793, 1794, 1795, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, -2, 1750, 0, 0, 1516, 1517, 1518, 1519, - 0, 1523, 0, 1553, 0, 0, 0, 0, 0, 0, - 1810, 1814, 0, 1746, 1746, 0, 1746, 1742, 0, 0, - 0, 0, 0, 0, 1746, 1678, 0, 0, 1680, 1696, - 0, 0, 1682, 1683, 0, 1686, 1687, 1746, 0, 1746, - 1691, 1746, 1746, 1746, 1674, 1675, 0, 1742, 1742, 1742, - 1742, 0, 0, 1742, 1742, 1742, 1742, 1742, 1742, 1742, - 1742, 1742, 1742, 1742, 1742, 1742, 1742, 1742, 0, 0, - 0, 0, 835, 0, 841, 0, -2, 0, 859, 861, - 863, 864, 866, 867, 869, 870, 872, 873, 820, 0, - 0, 105, 0, 0, 0, 0, 0, 0, 71, 73, - 0, 0, 0, 0, 0, 0, 333, 0, 338, 324, - 2059, 0, 323, 0, 0, 0, 0, 0, 1009, 0, - 0, 1181, 1181, 1181, 1048, 0, 0, 0, 0, 0, - 0, 0, 0, 1181, 1181, 1181, 1181, 0, 1201, 0, - 0, 0, 743, 742, 0, 829, 0, 0, 70, 597, - 598, 599, 900, 0, 0, 601, 602, 0, 603, 0, - 0, 614, 662, 662, 620, 621, 616, 615, 668, 669, - 665, 0, 665, 665, 900, 0, 639, 640, 641, 662, - 662, 647, 836, 0, 648, 649, 665, 0, 670, 671, - 900, 0, 0, 900, 900, 0, 657, 658, 660, 662, - 0, 0, 1181, 0, 678, 616, 616, 1889, 1890, 0, - 0, 1192, 0, 0, 0, 0, 681, 0, 0, 0, - 445, 446, 0, 0, 744, 0, 266, 270, 0, 273, - 0, 2067, 0, 2067, 0, 0, 280, 0, 0, 0, - 0, 0, 0, 310, 311, 0, 0, 0, 0, 301, - 304, 1363, 1364, 1135, 1136, 305, 306, 359, 360, 0, - 835, 858, 860, 854, 855, 856, 0, 72, 0, 0, - 0, 0, 0, 536, 0, 0, 0, 0, 0, 719, - 0, 1027, 721, 0, 0, 0, 0, 0, 908, 902, - 904, 980, 141, 878, 8, 126, 123, 0, 19, 0, - 0, 19, 19, 0, 19, 315, 0, 1886, 1884, 1885, - 1819, 1871, 0, 1845, 0, 1846, 1847, 1848, 1859, 1860, - 0, 0, 1841, 0, 1842, 1843, 1844, 1835, 0, 1836, - 1837, 0, 1838, 1839, 313, 426, 0, 0, 1747, 1013, - 0, 762, 776, 757, 0, 765, 0, 0, 1371, 0, - 0, 0, 0, 745, 776, 747, 0, 765, 835, 812, - 0, 790, 0, 0, 391, 0, 402, 396, 0, 403, - 398, 399, 0, 0, 420, 422, 423, 424, 409, 410, - 683, 376, 377, 378, 368, 369, 370, 371, 372, 373, - 374, 375, 0, 0, 380, 151, 0, 348, 349, 0, - 0, 0, 195, 196, 197, 198, 199, 200, 202, 186, - 708, 710, 1127, 1139, 0, 1130, 0, 205, 246, 178, - 0, 0, 0, 1751, 1752, 1753, 1754, 1755, 1760, 0, - 1762, 1764, 1766, 1768, 0, 1786, -2, -2, 1498, 1499, + 1834, 1835, 1878, 1878, 1881, 1881, 1878, 0, 429, 427, + 428, 1747, 0, 0, 0, 0, 784, 788, 1370, 0, + 0, 0, 840, -2, 0, 0, 686, 390, 1430, 0, + 0, 394, 0, 395, 0, 0, 397, 0, 0, 0, + 418, 0, 421, 405, 406, 407, 408, 401, 0, 181, + 0, 381, 382, 0, 0, 347, 0, 0, 0, 537, + 0, 0, 0, 0, 0, 0, 212, 208, 216, 219, + 229, 236, 0, 248, 250, 253, 209, 217, 222, 223, + 230, 251, 210, 213, 214, 218, 252, 254, 211, 231, + 235, 249, 233, 238, 241, 242, 247, 0, 182, 0, + 0, 0, 0, 0, 1757, 0, 0, 1790, 1791, 1792, + 1793, 1794, 1795, 1796, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, -2, 1751, 0, 0, 1517, 1518, 1519, + 1520, 0, 1524, 0, 1554, 0, 0, 0, 0, 0, + 0, 1811, 1815, 0, 1747, 1747, 0, 1747, 1743, 0, + 0, 0, 0, 0, 0, 1747, 1679, 0, 0, 1681, + 1697, 0, 0, 1683, 1684, 0, 1687, 1688, 1747, 0, + 1747, 1692, 1747, 1747, 1747, 1675, 1676, 0, 1743, 1743, + 1743, 1743, 0, 0, 1743, 1743, 1743, 1743, 1743, 1743, + 1743, 1743, 1743, 1743, 1743, 1743, 1743, 1743, 1743, 0, + 0, 0, 0, 835, 0, 841, 0, -2, 0, 859, + 861, 863, 864, 866, 867, 869, 870, 872, 873, 820, + 0, 0, 105, 0, 0, 0, 0, 0, 0, 71, + 73, 0, 0, 0, 0, 0, 0, 333, 0, 338, + 324, 2061, 0, 323, 0, 0, 0, 0, 0, 1009, + 0, 0, 1182, 1182, 1182, 1048, 0, 0, 0, 0, + 0, 0, 0, 0, 1182, 1182, 1182, 1182, 0, 1202, + 0, 0, 0, 743, 742, 0, 829, 0, 0, 70, + 597, 598, 599, 900, 0, 0, 601, 602, 0, 603, + 0, 0, 614, 662, 662, 620, 621, 616, 615, 668, + 669, 665, 0, 665, 665, 900, 0, 639, 640, 641, + 662, 662, 647, 836, 0, 648, 649, 665, 0, 670, + 671, 900, 0, 0, 900, 900, 0, 657, 658, 660, + 662, 0, 0, 1182, 0, 678, 616, 616, 1890, 1891, + 0, 0, 1193, 0, 0, 0, 0, 681, 0, 0, + 0, 445, 446, 0, 0, 744, 0, 266, 270, 0, + 273, 0, 2069, 0, 2069, 0, 0, 280, 0, 0, + 0, 0, 0, 0, 310, 311, 0, 0, 0, 0, + 301, 304, 1364, 1365, 1135, 1136, 305, 306, 359, 360, + 0, 835, 858, 860, 854, 855, 856, 0, 72, 0, + 0, 0, 0, 0, 536, 0, 0, 0, 0, 0, + 719, 0, 1027, 721, 0, 0, 0, 0, 0, 908, + 902, 904, 980, 141, 878, 8, 126, 123, 0, 19, + 0, 0, 19, 19, 0, 19, 315, 0, 1887, 1885, + 1886, 1820, 1872, 0, 1846, 0, 1847, 1848, 1849, 1860, + 1861, 0, 0, 1842, 0, 1843, 1844, 1845, 1836, 0, + 1837, 1838, 0, 1839, 1840, 313, 426, 0, 0, 1748, + 1013, 0, 762, 776, 757, 0, 765, 0, 0, 1372, + 0, 0, 0, 0, 745, 776, 747, 0, 765, 835, + 812, 0, 790, 0, 0, 391, 0, 402, 396, 0, + 403, 398, 399, 0, 0, 420, 422, 423, 424, 409, + 410, 683, 376, 377, 378, 368, 369, 370, 371, 372, + 373, 374, 375, 0, 0, 380, 151, 0, 348, 349, + 0, 0, 0, 195, 196, 197, 198, 199, 200, 202, + 186, 708, 710, 1127, 1139, 0, 1130, 0, 205, 246, + 178, 0, 0, 0, 1752, 1753, 1754, 1755, 1756, 1761, + 0, 1763, 1765, 1767, 1769, 0, 1787, -2, -2, 1499, 1500, 1501, 1502, 1503, 1504, 1505, 1506, 1507, 1508, 1509, - 1771, 1784, 1785, 0, 0, 0, 0, 0, 0, 1782, - 1782, 1777, 0, 1536, 1365, 1366, 1514, 0, 0, 1550, - 1554, 0, 0, 0, 0, 0, 0, 1162, 1870, 0, - 142, 1741, 1645, 1646, 1647, 1648, 1649, 1650, 1651, 1652, + 1510, 1772, 1785, 1786, 0, 0, 0, 0, 0, 0, + 1783, 1783, 1778, 0, 1537, 1366, 1367, 1515, 0, 0, + 1551, 1555, 0, 0, 0, 0, 0, 0, 1163, 1871, + 0, 142, 1742, 1646, 1647, 1648, 1649, 1650, 1651, 1652, 1653, 1654, 1655, 1656, 1657, 1658, 1659, 1660, 1661, 1662, 1663, 1664, 1665, 1666, 1667, 1668, 1669, 1670, 1671, 1672, - 1673, 0, 0, 1750, 0, 0, 0, 1743, 1744, 0, - 0, 0, 1633, 0, 0, 1639, 1640, 1641, 0, 771, - 0, 1706, 1679, 1697, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 932, 934, 0, 780, 782, 783, 809, 790, - 816, 0, 0, 0, 101, 106, 0, 1224, 0, 0, - 0, 0, 0, 0, 0, 74, 1196, 75, 1198, 342, - 343, 0, 0, 337, 325, 2059, 327, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 1063, 1064, - 534, 1121, 0, 0, 0, 1137, 1166, 1177, 0, 0, - 0, 0, 0, 1230, 1049, 1054, 1055, 1056, 1050, 1051, - 1057, 1058, 0, 831, 0, 0, 949, 600, 663, 664, - 901, 604, 0, 0, 611, 2022, 616, 900, 900, 623, - 617, 624, 667, 625, 626, 627, 665, 900, 900, 837, - 662, 665, 650, 666, 665, 1371, 654, 0, 661, 1371, - 679, 1371, 0, 677, 631, 632, 1232, 833, 443, 444, - 449, 451, 0, 501, 501, 501, 483, 501, 0, 0, - 471, 1891, 0, 0, 0, 0, 480, 1891, 0, 0, - 1891, 1891, 1891, 1891, 1891, 1891, 1891, 0, 0, 1891, - 1891, 1891, 1891, 1891, 1891, 1891, 1891, 1891, 1891, 1891, - 0, 1891, 1891, 1891, 1891, 1891, 1349, 1891, 0, 1193, - 491, 492, 493, 494, 499, 500, 0, 0, 529, 0, - 0, 1062, 0, 534, 0, 0, 1104, 0, 0, 913, - 0, 914, 915, 916, 911, 951, 975, 975, 0, 975, - 955, 1371, 0, 0, 0, 278, 279, 267, 0, 268, - 0, 0, 281, 282, 0, 284, 285, 286, 293, 1959, - 2038, 288, 290, 0, 0, 294, 307, 308, 309, 0, - 0, 299, 300, 0, 0, 362, 363, 365, 0, 790, - 1197, 705, 1367, 706, 707, 711, 0, 0, 714, 715, - 716, 717, 718, 1029, 0, 0, 1113, 1114, 1115, 1183, - 900, 0, 909, 0, 905, 981, 0, 983, 0, 0, - 124, 19, 0, 117, 114, 0, 0, 0, 0, 0, - 1866, 1815, 1887, 0, 0, 0, 1868, 0, 0, 0, - 0, 0, 107, 792, 752, 0, 756, 773, 0, 777, - 0, 0, 769, 761, 766, 0, 0, 786, 753, 1370, - 0, 0, 0, 0, 746, 0, 0, 751, 790, 0, - 813, 842, 843, 846, 1430, 0, 404, 400, 419, 0, - 0, 0, 0, 189, 1124, 0, 190, 194, 184, 0, - 0, 0, 1129, 0, 1126, 1131, 0, 204, 0, 0, - 179, 180, 1215, 1224, 0, 0, 0, 1761, 1763, 1765, - 1767, 1769, 0, 1772, 1782, 1782, 1778, 0, 1773, 0, - 1775, 0, 1751, 1520, 0, 1555, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 846, 0, 0, 1623, 1624, - 0, 0, 1628, 0, 1630, 1631, 1632, 1634, 0, 0, - 0, 1638, 0, 1677, 1698, 1681, 1684, 0, 1688, 0, - 1690, 1692, 1693, 1694, 0, 840, 840, 0, 0, 1594, - 1594, 1594, 0, 0, 0, 0, 1594, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 1539, 0, - 1540, 1541, 0, 0, 0, 935, 810, 0, 0, 0, - 0, 0, 1222, 0, 91, 0, 0, 0, 0, 96, - 0, 0, 76, 344, 332, 334, 0, 326, 0, 1182, - 0, 0, 0, 0, -2, 1029, 833, 0, 833, 1074, - 1891, 538, 0, 0, 1123, 0, 1093, 0, 0, 0, - -2, 0, 0, 0, 1177, 0, 0, 0, 1234, 0, - 0, 0, 730, 734, 23, 834, 0, 607, 605, 0, - 609, 0, 610, 662, 618, 619, 900, 642, 643, 0, - 0, 900, 662, 662, 653, 665, 674, 0, 675, 1371, - 1234, 0, 0, 1192, 1300, 1268, 461, 0, 1384, 1385, - 502, 0, 1391, 1400, 1181, 1462, 0, 1400, 0, 0, - 1402, 1403, 0, 0, 0, 0, 484, 485, 0, 470, - 0, 0, 0, 0, 0, 0, 469, 0, 0, 512, - 0, 0, 0, 0, 0, 1892, 1891, 1891, 0, 478, - 479, 0, 482, 0, 0, 0, 0, 0, 0, 0, - 0, 1891, 1891, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1340, 0, 0, 0, 0, 0, - 0, 0, 1355, 1356, 0, 1074, 1891, 0, 0, 0, - 0, 538, 1118, 1118, 1091, 1109, 0, 447, 448, 509, - 0, 0, 0, 0, 0, 0, 0, 941, 0, 0, - 0, 940, 0, 0, 0, 0, 0, 0, 0, 833, - 976, 0, 978, 979, 953, -2, 0, 913, 958, 1746, - 0, 271, 272, 0, 0, 277, 295, 297, 269, 0, - 0, 0, 296, 298, 302, 303, 361, 364, 366, 852, - 0, 0, 1258, 0, 1030, 1031, 1033, 1034, 0, -2, + 1673, 1674, 0, 0, 1751, 0, 0, 0, 1744, 1745, + 0, 0, 0, 1634, 0, 0, 1640, 1641, 1642, 0, + 771, 0, 1707, 1680, 1698, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 932, 934, 0, 780, 782, 783, 809, + 790, 816, 0, 0, 0, 101, 106, 0, 1225, 0, + 0, 0, 0, 0, 0, 0, 74, 1197, 75, 1199, + 342, 343, 0, 0, 337, 325, 2061, 327, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 1063, + 1064, 534, 1121, 0, 0, 0, 1137, 1167, 1178, 0, + 0, 0, 0, 0, 1231, 1049, 1054, 1055, 1056, 1050, + 1051, 1057, 1058, 0, 831, 0, 0, 949, 600, 663, + 664, 901, 604, 0, 0, 611, 2024, 616, 900, 900, + 623, 617, 624, 667, 625, 626, 627, 665, 900, 900, + 837, 662, 665, 650, 666, 665, 1372, 654, 0, 661, + 1372, 679, 1372, 0, 677, 631, 632, 1233, 833, 443, + 444, 449, 451, 0, 501, 501, 501, 483, 501, 0, + 0, 471, 1892, 0, 0, 0, 0, 480, 1892, 0, + 0, 1892, 1892, 1892, 1892, 1892, 1892, 1892, 0, 0, + 1892, 1892, 1892, 1892, 1892, 1892, 1892, 1892, 1892, 1892, + 1892, 0, 1892, 1892, 1892, 1892, 1892, 1350, 1892, 0, + 1194, 491, 492, 493, 494, 499, 500, 0, 0, 529, + 0, 0, 1062, 0, 534, 0, 0, 1104, 0, 0, + 913, 0, 914, 915, 916, 911, 951, 975, 975, 0, + 975, 955, 1372, 0, 0, 0, 278, 279, 267, 0, + 268, 0, 0, 281, 282, 0, 284, 285, 286, 293, + 1961, 2040, 288, 290, 0, 0, 294, 307, 308, 309, + 0, 0, 299, 300, 0, 0, 362, 363, 365, 0, + 790, 1198, 705, 1368, 706, 707, 711, 0, 0, 714, + 715, 716, 717, 718, 1029, 0, 0, 1113, 1114, 1115, + 1184, 900, 0, 909, 0, 905, 981, 0, 983, 0, + 0, 124, 19, 0, 117, 114, 0, 0, 0, 0, + 0, 1867, 1816, 1888, 0, 0, 0, 1869, 0, 0, + 0, 0, 0, 107, 792, 752, 0, 756, 773, 0, + 777, 0, 0, 769, 761, 766, 0, 0, 786, 753, + 1371, 0, 0, 0, 0, 746, 0, 0, 751, 790, + 0, 813, 842, 843, 846, 1431, 0, 404, 400, 419, + 0, 0, 0, 0, 189, 1124, 0, 190, 194, 184, + 0, 0, 0, 1129, 0, 1126, 1131, 0, 204, 0, + 0, 179, 180, 1216, 1225, 0, 0, 0, 1762, 1764, + 1766, 1768, 1770, 0, 1773, 1783, 1783, 1779, 0, 1774, + 0, 1776, 0, 1752, 1521, 0, 1556, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 846, 0, 0, 1624, + 1625, 0, 0, 1629, 0, 1631, 1632, 1633, 1635, 0, + 0, 0, 1639, 0, 1678, 1699, 1682, 1685, 0, 1689, + 0, 1691, 1693, 1694, 1695, 0, 840, 840, 0, 0, + 1595, 1595, 1595, 0, 0, 0, 0, 1595, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 1540, + 0, 1541, 1542, 0, 0, 0, 935, 810, 0, 0, + 0, 0, 0, 1223, 0, 91, 0, 0, 0, 0, + 96, 0, 0, 76, 344, 332, 334, 0, 326, 0, + 1183, 0, 0, 0, 0, -2, 1029, 833, 0, 833, + 1074, 1892, 538, 0, 0, 1123, 0, 1093, 0, 0, + 0, -2, 0, 0, 0, 1178, 0, 0, 0, 1235, + 0, 0, 0, 730, 734, 23, 834, 0, 607, 605, + 0, 609, 0, 610, 662, 618, 619, 900, 642, 643, + 0, 0, 900, 662, 662, 653, 665, 674, 0, 675, + 1372, 1235, 0, 0, 1193, 1301, 1269, 461, 0, 1385, + 1386, 502, 0, 1392, 1401, 1182, 1463, 0, 1401, 0, + 0, 1403, 1404, 0, 0, 0, 0, 484, 485, 0, + 470, 0, 0, 0, 0, 0, 0, 469, 0, 0, + 512, 0, 0, 0, 0, 0, 1893, 1892, 1892, 0, + 478, 479, 0, 482, 0, 0, 0, 0, 0, 0, + 0, 0, 1892, 1892, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 1341, 0, 0, 0, 0, + 0, 0, 0, 1356, 1357, 0, 1074, 1892, 0, 0, + 0, 0, 538, 1118, 1118, 1091, 1109, 0, 447, 448, + 509, 0, 0, 0, 0, 0, 0, 0, 941, 0, + 0, 0, 940, 0, 0, 0, 0, 0, 0, 0, + 833, 976, 0, 978, 979, 953, -2, 0, 913, 958, + 1747, 0, 271, 272, 0, 0, 277, 295, 297, 269, + 0, 0, 0, 296, 298, 302, 303, 361, 364, 366, + 852, 0, 0, 1259, 0, 1030, 1031, 1033, 1034, 0, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, - -2, -2, 1943, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, 1945, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, - -2, -2, -2, -2, 1028, 722, 1116, 1184, 891, 903, - 910, 982, 984, 142, 906, 0, 127, 19, 126, 118, - 119, 0, 19, 0, 0, 0, 0, 1876, 1875, 1861, - 0, 1862, 1873, 1878, 0, 1881, 0, 430, 796, 0, - 0, 776, 778, 0, 0, 776, 0, 0, 785, 0, - 0, 0, 0, 0, 0, 0, 776, 852, 792, 0, - 849, 847, 848, 0, 0, 684, 152, 425, 0, 0, - 0, 0, 0, 709, 0, 1128, 186, 0, 0, 206, - 0, 0, 0, 1224, 1219, 1745, 1774, 1776, 0, 1783, - 1779, 1515, 1524, 1551, 0, 0, 1557, 1569, 1569, 0, - 0, 0, 1560, 1874, 1874, 1563, 1870, 1872, 1870, 1569, - 1569, 0, 1163, 0, 1164, 846, 143, 0, 0, 1629, - 0, 0, 0, 772, 0, 0, 0, 1590, 1592, 1594, - 1594, 1601, 1595, 1602, 1603, 1594, 1594, 1594, 1594, 1608, - 1594, 1594, 1594, 1594, 1594, 1594, 1594, 1594, 1594, 1594, - 1594, 1588, 0, 0, 1804, 1805, 781, 0, 0, 823, - 824, 825, 826, 827, 0, 0, 61, 61, 1224, 0, - 100, 92, 0, 0, 0, 0, 0, 336, 0, 77, - 78, 80, 0, 0, 0, 0, 0, 0, 0, 90, - 0, 0, 1015, 1016, 1018, 0, 1021, 1022, 1023, 0, - 0, 1377, 0, 1078, 1075, 1076, 1077, 0, 1118, 539, - 540, 541, 542, 0, 0, 0, 1122, 0, 0, 1086, - 0, 0, 0, 1167, 1168, 1169, 1170, 1171, 1172, 1173, - 1174, -2, 1187, 0, 1371, 0, 0, 1377, 1206, 0, - 0, 1211, 0, 1377, 1377, 0, 1242, 0, 1231, 784, - 0, -2, 0, 0, 732, 0, 0, 950, 606, 612, - 900, 636, 838, 839, 1371, 900, 900, 662, 680, 676, - 1242, 1233, 0, 450, 501, 0, 1288, 0, 0, 1294, - 0, 1301, 454, 0, 503, 0, 1390, 1418, 1401, 1418, - 1463, 1418, 1418, 1181, 0, 503, 0, 0, 472, 0, - 0, 0, 0, 0, 468, 506, 846, 455, 457, 458, - 459, 510, 511, 513, 0, 515, 516, 474, 486, 487, - 488, 489, 490, 0, 0, 0, 481, 495, 496, 497, - 498, 456, 1317, 1318, 1319, 1322, 1323, 1324, 1325, 0, - 0, 1328, 1329, 1330, 1331, 1332, 1415, 1416, 1417, 1333, - 1334, 1335, 1336, 1337, 1338, 1339, 1357, 1358, 1359, 1360, - 1361, 1362, 1341, 1342, 1343, 1344, 1345, 1346, 1347, 1348, - 0, 0, 1352, 0, 0, 1078, 0, 0, 0, 0, - 0, 1118, 532, 0, 0, 533, 1093, 0, 1111, 0, - 1105, 1106, 0, 0, 754, 900, 354, 0, 945, 936, - 0, 920, 0, 922, 942, 923, 943, 0, 0, 927, - 0, 929, 0, 925, 926, 931, 924, 900, 912, 952, - 977, 954, 957, 959, 960, 966, 0, 0, 0, 0, - 265, 274, 275, 276, 283, 0, 558, 289, 808, 0, - 1368, 712, 713, 1259, 1260, 720, 0, 1035, 889, 0, - 0, 122, 125, 0, 120, 0, 0, 0, 0, 112, - 110, 1869, 0, 0, 798, 166, 0, 0, 0, 774, - 0, 779, 776, 760, 770, 759, 767, 768, 787, 1372, - 1373, 1374, 1375, 0, 776, 750, 749, 811, 796, 844, - 845, 0, 1431, 392, 0, 1125, 186, 191, 192, 193, - 187, 185, 1132, 0, 1134, 0, 1217, 0, 0, 1780, - 1556, 1525, 1558, 1570, 1571, 1559, 0, 1527, 1528, 1561, - 1562, 1564, 1565, 1566, 1567, 1568, 1529, 0, 1165, 1625, - 0, 1627, 1635, 1636, 0, 1685, 1689, 0, 0, 0, - 0, 0, 1599, 1600, 1604, 1605, 1606, 1607, 1609, 1610, - 1611, 1612, 1613, 1614, 1615, 1616, 1617, 1618, 1619, 840, - 1589, 0, 0, 0, 0, 0, 0, 0, 821, 0, - 0, 0, 63, 0, 63, 1223, 1225, 0, 980, 0, - 0, 97, 0, 0, 79, 81, 0, 2023, 0, 0, - 0, 0, 1183, 1008, 1024, 1020, 0, 0, 0, 0, - 1378, 1379, 1381, 1382, 1383, 0, 1046, 0, 0, 1066, - 1067, 1068, 1080, 0, 544, 545, 0, 0, 0, 557, - 553, 554, 555, 535, 1117, 1100, 0, 0, 1089, 0, - 0, 1099, 0, 1188, 1891, 1891, 1891, 1175, 0, 0, - 1302, 1891, 1891, 0, 1208, 1210, 1212, 0, 0, 1306, - 1245, 0, 0, 1236, 0, 975, 0, 0, 900, 731, - 734, 735, 832, 613, 651, 655, 652, 900, 1245, 442, - 1266, 0, 0, 0, 0, 0, 1298, 0, 0, 1270, - 0, 473, 504, 0, -2, 0, 1419, 0, 1404, 1419, - 0, 0, 1418, 0, 462, 503, 0, 0, 0, 517, - 522, 523, 0, 519, 520, 1458, 0, 521, 0, 508, - 0, 514, 1320, 1321, 0, 1326, 1327, 0, 1351, 0, - 0, 453, 524, 0, 0, 0, 525, 526, 531, 1119, - 1120, 1086, 0, 1100, 0, 1110, 0, 1107, 1108, 840, - 0, 0, 917, 946, 0, 0, 918, 0, 919, 921, - 944, 0, 938, 928, 930, 353, 961, 0, 0, 963, - 964, 965, 956, 291, 853, 1032, 0, 874, 0, 0, - 907, 0, 19, 0, 0, 115, 1879, 1882, 800, 0, - 797, 167, 0, 0, 0, 0, 764, 775, 758, 1376, - 748, 798, 850, 851, 188, 183, 1133, 1227, 0, 1218, - 0, 1482, 1538, 0, 1637, 0, 1594, 1591, 1594, 1593, - 1585, 0, 1542, 0, 1544, 1545, 1546, 0, 1548, 1549, - 0, 819, 0, 59, 0, 62, 60, 0, 99, 93, - 0, 0, 0, 82, 0, 0, 0, 0, 0, 0, - 88, 0, 0, 1017, 1019, 0, 1052, 1306, 0, 1052, - 1079, 1065, 0, 0, 546, 547, 0, 550, 556, 1081, - 0, 0, 1083, 1084, 1085, 0, 0, 1097, 0, 0, - 0, 0, 0, 1178, 1194, 0, 0, 0, -2, 0, - 0, -2, 1205, 0, 1251, 0, 1243, 0, 1235, 0, - 1238, 900, 900, -2, 728, 733, 0, 656, 1251, 1268, - 0, 1289, 0, 0, 0, 0, 0, 0, 0, 1269, - 0, 1282, 505, 1420, -2, 1434, 1436, 0, 1193, 1439, - 1440, 0, 0, 0, 0, 0, 0, 1489, 1448, 0, - 0, 1452, 1453, 1454, 0, 0, 1457, 0, 1798, 1799, - 0, 1461, 0, 0, 0, 0, 0, 0, 0, 1398, - 463, 464, 0, 466, 467, 1891, 1459, 507, 460, 1891, - 476, 1350, 1353, 1354, 530, 527, 528, 1089, 1092, 1103, - 1112, 755, 835, 355, 356, 947, 0, 937, 939, 970, - 967, 0, 0, 1036, 890, 898, 2252, 2254, 2251, 116, - 121, 0, 0, 802, 0, 799, 0, 793, 795, 177, - 763, 800, 137, 169, 0, 0, 1526, 0, 0, 0, - 1626, 1676, 1597, 1598, 0, 1586, 0, 1580, 1581, 1582, - 1587, 0, 0, 822, 817, 64, 95, 0, 98, 68, - 1183, 0, 1183, 0, 0, 0, 1011, 1025, 0, 1038, - 1045, 1059, 1199, 1380, 1044, 0, 0, 543, 548, 0, - 551, 552, 1101, 1100, 0, 1087, 1088, 0, 1095, 0, - 0, 1189, 1190, 1191, 0, 1303, 1304, 1305, 1261, 1207, - 0, -2, 1314, 0, 0, 1203, 1227, 1261, 0, 1239, - 0, 1246, 0, 1244, 1237, 840, 729, 1248, 452, 1300, - 1290, 0, 1292, 0, 0, 0, 0, 1271, -2, 0, - 1435, 1437, 1438, 1441, 1442, 1443, 1494, 1495, 1496, 0, - 0, 1446, 1491, 1492, 1493, 1447, 0, 0, 0, 0, - 0, 1796, 1797, 1487, 0, 0, 1405, 1407, 1408, 1409, - 1410, 1411, 1412, 1413, 1414, 1406, 0, 0, 0, 1397, - 1399, 465, 0, 0, 1891, 1102, 352, 0, 0, 971, - 973, 968, 969, 892, 0, 0, 0, 0, 111, 113, - 128, 0, 801, 168, 0, 802, 139, 0, 160, 0, - 1228, 0, 1537, 0, 0, 0, 1596, 1583, 0, 0, - 0, 0, 0, 1800, 1801, 1802, 0, 1543, 1547, 94, - 0, 66, 0, 83, 1183, 84, 1183, 0, 0, 0, - 0, 1060, 1061, 1069, 1070, 0, 1072, 1073, 549, 1082, - 1090, 1094, 1097, 0, 1149, 1176, 1263, 0, 1209, 1192, - 1316, 1891, 1213, 1214, 1263, 0, 1308, 1891, 1891, 1229, - 0, 1241, 0, 1253, 0, 1247, 835, 441, 0, 1250, - 1286, 1291, 1293, 1295, 0, 1299, 1297, 1272, -2, 0, - 1280, 0, 0, 1444, 1445, 0, 0, 1695, 1891, 0, - 1477, 0, 1149, 1149, 1149, 1149, 0, 518, 475, 0, - 948, 962, 0, 899, 0, 0, 0, 0, 0, 791, - 129, 0, 138, 157, 0, 170, 171, 0, 0, 0, - 0, 1220, 0, 1485, 1486, 0, 1572, 0, 0, 0, - 1576, 1577, 1578, 1579, 65, 68, 0, 85, 86, 0, - 1183, 0, 1037, 0, 1071, 1096, 1098, 1148, 1202, 0, - 1300, 1315, 0, 1204, 1307, 0, 0, 0, 1240, 1252, - 0, 1255, 727, 1249, 1267, 0, 1296, 1273, 1281, 0, - 1276, 0, 0, 0, 1490, 0, 1451, 0, 1456, 1465, - 1478, 0, 0, 1386, 0, 1388, 0, 1392, 0, 1394, - 0, 0, 477, 972, 974, 0, 1746, 894, 895, 0, - 804, 794, 140, 144, 0, 166, 163, 0, 172, 0, - 0, 0, 0, 1216, 0, 1483, 0, 1573, 1574, 1575, - 67, 69, 1183, 87, 0, 1039, 1040, 1053, 1150, 1891, - 1891, 0, 0, 0, 1156, 1157, 1891, 1891, 1891, 1891, - 0, 1288, 1320, 1309, 1310, 1311, 1254, 1287, 1275, 0, - -2, 1283, 0, 0, 1748, 1758, 1759, 1449, 1455, 1464, - 1466, 1467, 0, 1479, 1480, 1481, 1488, 1149, 1149, 1149, - 1149, 1396, 893, 0, 0, 803, 0, 131, 0, 0, - 161, 162, 164, 0, 173, 0, 175, 176, 0, 0, - 1584, 89, 1041, 0, 0, 1153, 1154, 0, 0, 0, - 0, 0, 1264, 0, 1266, 1277, -2, 0, 1285, 0, - 1450, 1468, 0, 1469, 0, 0, 0, 1387, 1389, 1393, - 1395, 1746, 896, 805, 1226, 0, 145, 0, 147, 149, - 150, 1421, 158, 159, 165, 174, 0, 0, 1026, 1042, - 0, 1151, 1152, 1155, 1158, 1159, 1160, 1161, 0, 1268, - 1284, 1749, 1470, 1472, 1473, 0, 0, 1471, 0, 132, - 133, 0, 146, 0, 0, 1221, 1484, 1043, 1265, 1262, - 1474, 1476, 1475, 897, 0, 0, 148, 1422, 134, 135, - 136, 0, 1423, + -2, -2, -2, -2, -2, 1028, 722, 1116, 1185, 891, + 903, 910, 982, 984, 142, 906, 0, 127, 19, 126, + 118, 119, 0, 19, 0, 0, 0, 0, 1877, 1876, + 1862, 0, 1863, 1874, 1879, 0, 1882, 0, 430, 796, + 0, 0, 776, 778, 0, 0, 776, 0, 0, 785, + 0, 0, 0, 0, 0, 0, 0, 776, 852, 792, + 0, 849, 847, 848, 0, 0, 684, 152, 425, 0, + 0, 0, 0, 0, 709, 0, 1128, 186, 0, 0, + 206, 0, 0, 0, 1225, 1220, 1746, 1775, 1777, 0, + 1784, 1780, 1516, 1525, 1552, 0, 0, 1558, 1570, 1570, + 0, 0, 0, 1561, 1875, 1875, 1564, 1871, 1873, 1871, + 1570, 1570, 0, 1164, 0, 1165, 846, 143, 0, 0, + 1630, 0, 0, 0, 772, 0, 0, 0, 1591, 1593, + 1595, 1595, 1602, 1596, 1603, 1604, 1595, 1595, 1595, 1595, + 1609, 1595, 1595, 1595, 1595, 1595, 1595, 1595, 1595, 1595, + 1595, 1595, 1589, 0, 0, 1805, 1806, 781, 0, 0, + 823, 824, 825, 826, 827, 0, 0, 61, 61, 1225, + 0, 100, 92, 0, 0, 0, 0, 0, 336, 0, + 77, 78, 80, 0, 0, 0, 0, 0, 0, 0, + 90, 0, 0, 1015, 1016, 1018, 0, 1021, 1022, 1023, + 0, 0, 1378, 0, 1078, 1075, 1076, 1077, 0, 1118, + 539, 540, 541, 542, 0, 0, 0, 1122, 0, 0, + 1086, 0, 0, 0, 1168, 1169, 1170, 1171, 1172, 1173, + 1174, 1175, -2, 1188, 0, 1372, 0, 0, 1378, 1207, + 0, 0, 1212, 0, 1378, 1378, 0, 1243, 0, 1232, + 784, 0, -2, 0, 0, 732, 0, 0, 950, 606, + 612, 900, 636, 838, 839, 1372, 900, 900, 662, 680, + 676, 1243, 1234, 0, 450, 501, 0, 1289, 0, 0, + 1295, 0, 1302, 454, 0, 503, 0, 1391, 1419, 1402, + 1419, 1464, 1419, 1419, 1182, 0, 503, 0, 0, 472, + 0, 0, 0, 0, 0, 468, 506, 846, 455, 457, + 458, 459, 510, 511, 513, 0, 515, 516, 474, 486, + 487, 488, 489, 490, 0, 0, 0, 481, 495, 496, + 497, 498, 456, 1318, 1319, 1320, 1323, 1324, 1325, 1326, + 0, 0, 1329, 1330, 1331, 1332, 1333, 1416, 1417, 1418, + 1334, 1335, 1336, 1337, 1338, 1339, 1340, 1358, 1359, 1360, + 1361, 1362, 1363, 1342, 1343, 1344, 1345, 1346, 1347, 1348, + 1349, 0, 0, 1353, 0, 0, 1078, 0, 0, 0, + 0, 0, 1118, 532, 0, 0, 533, 1093, 0, 1111, + 0, 1105, 1106, 0, 0, 754, 900, 354, 0, 945, + 936, 0, 920, 0, 922, 942, 923, 943, 0, 0, + 927, 0, 929, 0, 925, 926, 931, 924, 900, 912, + 952, 977, 954, 957, 959, 960, 966, 0, 0, 0, + 0, 265, 274, 275, 276, 283, 0, 558, 289, 808, + 0, 1369, 712, 713, 1260, 1261, 720, 0, 1035, 889, + 0, 0, 122, 125, 0, 120, 0, 0, 0, 0, + 112, 110, 1870, 0, 0, 798, 166, 0, 0, 0, + 774, 0, 779, 776, 760, 770, 759, 767, 768, 787, + 1373, 1374, 1375, 1376, 0, 776, 750, 749, 811, 796, + 844, 845, 0, 1432, 392, 0, 1125, 186, 191, 192, + 193, 187, 185, 1132, 0, 1134, 0, 1218, 0, 0, + 1781, 1557, 1526, 1559, 1571, 1572, 1560, 0, 1528, 1529, + 1562, 1563, 1565, 1566, 1567, 1568, 1569, 1530, 0, 1166, + 1626, 0, 1628, 1636, 1637, 0, 1686, 1690, 0, 0, + 0, 0, 0, 1600, 1601, 1605, 1606, 1607, 1608, 1610, + 1611, 1612, 1613, 1614, 1615, 1616, 1617, 1618, 1619, 1620, + 840, 1590, 0, 0, 0, 0, 0, 0, 0, 821, + 0, 0, 0, 63, 0, 63, 1224, 1226, 0, 980, + 0, 0, 97, 0, 0, 79, 81, 0, 2025, 0, + 0, 0, 0, 1184, 1008, 1024, 1020, 0, 0, 0, + 0, 1379, 1380, 1382, 1383, 1384, 0, 1046, 0, 0, + 1066, 1067, 1068, 1080, 0, 544, 545, 0, 0, 0, + 557, 553, 554, 555, 535, 1117, 1100, 0, 0, 1089, + 0, 0, 1099, 0, 1189, 1892, 1892, 1892, 1176, 0, + 0, 1303, 1892, 1892, 0, 1209, 1211, 1213, 0, 0, + 1307, 1246, 0, 0, 1237, 0, 975, 0, 0, 900, + 731, 734, 735, 832, 613, 651, 655, 652, 900, 1246, + 442, 1267, 0, 0, 0, 0, 0, 1299, 0, 0, + 1271, 0, 473, 504, 0, -2, 0, 1420, 0, 1405, + 1420, 0, 0, 1419, 0, 462, 503, 0, 0, 0, + 517, 522, 523, 0, 519, 520, 1459, 0, 521, 0, + 508, 0, 514, 1321, 1322, 0, 1327, 1328, 0, 1352, + 0, 0, 453, 524, 0, 0, 0, 525, 526, 531, + 1119, 1120, 1086, 0, 1100, 0, 1110, 0, 1107, 1108, + 840, 0, 0, 917, 946, 0, 0, 918, 0, 919, + 921, 944, 0, 938, 928, 930, 353, 961, 0, 0, + 963, 964, 965, 956, 291, 853, 1032, 0, 874, 0, + 0, 907, 0, 19, 0, 0, 115, 1880, 1883, 800, + 0, 797, 167, 0, 0, 0, 0, 764, 775, 758, + 1377, 748, 798, 850, 851, 188, 183, 1133, 1228, 0, + 1219, 0, 1483, 1539, 0, 1638, 0, 1595, 1592, 1595, + 1594, 1586, 0, 1543, 0, 1545, 1546, 1547, 0, 1549, + 1550, 0, 819, 0, 59, 0, 62, 60, 0, 99, + 93, 0, 0, 0, 82, 0, 0, 0, 0, 0, + 0, 88, 0, 0, 1017, 1019, 0, 1052, 1307, 0, + 1052, 1079, 1065, 0, 0, 546, 547, 0, 550, 556, + 1081, 0, 0, 1083, 1084, 1085, 0, 0, 1097, 0, + 0, 0, 0, 0, 1179, 1195, 0, 0, 0, -2, + 0, 0, -2, 1206, 0, 1252, 0, 1244, 0, 1236, + 0, 1239, 900, 900, -2, 728, 733, 0, 656, 1252, + 1269, 0, 1290, 0, 0, 0, 0, 0, 0, 0, + 1270, 0, 1283, 505, 1421, -2, 1435, 1437, 0, 1194, + 1440, 1441, 0, 0, 0, 0, 0, 0, 1490, 1449, + 0, 0, 1453, 1454, 1455, 0, 0, 1458, 0, 1799, + 1800, 0, 1462, 0, 0, 0, 0, 0, 0, 0, + 1399, 463, 464, 0, 466, 467, 1892, 1460, 507, 460, + 1892, 476, 1351, 1354, 1355, 530, 527, 528, 1089, 1092, + 1103, 1112, 755, 835, 355, 356, 947, 0, 937, 939, + 970, 967, 0, 0, 1036, 890, 898, 2254, 2256, 2253, + 116, 121, 0, 0, 802, 0, 799, 0, 793, 795, + 177, 763, 800, 137, 169, 0, 0, 1527, 0, 0, + 0, 1627, 1677, 1598, 1599, 0, 1587, 0, 1581, 1582, + 1583, 1588, 0, 0, 822, 817, 64, 95, 0, 98, + 68, 1184, 0, 1184, 0, 0, 0, 1011, 1025, 0, + 1038, 1045, 1059, 1200, 1381, 1044, 0, 0, 543, 548, + 0, 551, 552, 1101, 1100, 0, 1087, 1088, 0, 1095, + 0, 0, 1190, 1191, 1192, 0, 1304, 1305, 1306, 1262, + 1208, 0, -2, 1315, 0, 0, 1204, 1228, 1262, 0, + 1240, 0, 1247, 0, 1245, 1238, 840, 729, 1249, 452, + 1301, 1291, 0, 1293, 0, 0, 0, 0, 1272, -2, + 0, 1436, 1438, 1439, 1442, 1443, 1444, 1495, 1496, 1497, + 0, 0, 1447, 1492, 1493, 1494, 1448, 0, 0, 0, + 0, 0, 1797, 1798, 1488, 0, 0, 1406, 1408, 1409, + 1410, 1411, 1412, 1413, 1414, 1415, 1407, 0, 0, 0, + 1398, 1400, 465, 0, 0, 1892, 1102, 352, 0, 0, + 971, 973, 968, 969, 892, 0, 0, 0, 0, 111, + 113, 128, 0, 801, 168, 0, 802, 139, 0, 160, + 0, 1229, 0, 1538, 0, 0, 0, 1597, 1584, 0, + 0, 0, 0, 0, 1801, 1802, 1803, 0, 1544, 1548, + 94, 0, 66, 0, 83, 1184, 84, 1184, 0, 0, + 0, 0, 1060, 1061, 1069, 1070, 0, 1072, 1073, 549, + 1082, 1090, 1094, 1097, 0, 1149, 1177, 1264, 0, 1210, + 1193, 1317, 1892, 1214, 1215, 1264, 0, 1309, 1892, 1892, + 1230, 0, 1242, 0, 1254, 0, 1248, 835, 441, 0, + 1251, 1287, 1292, 1294, 1296, 0, 1300, 1298, 1273, -2, + 0, 1281, 0, 0, 1445, 1446, 0, 0, 1696, 1892, + 0, 1478, 0, 1149, 1149, 1149, 1149, 0, 518, 475, + 0, 948, 962, 0, 899, 0, 0, 0, 0, 0, + 791, 129, 0, 138, 157, 0, 170, 171, 0, 0, + 0, 0, 1221, 0, 1486, 1487, 0, 1573, 0, 0, + 0, 1577, 1578, 1579, 1580, 65, 68, 0, 85, 86, + 0, 1184, 0, 1037, 0, 1071, 1096, 1098, 1148, 1203, + 0, 1301, 1316, 0, 1205, 1308, 0, 0, 0, 1241, + 1253, 0, 1256, 727, 1250, 1268, 0, 1297, 1274, 1282, + 0, 1277, 0, 0, 0, 1491, 0, 1452, 0, 1457, + 1466, 1479, 0, 0, 1387, 0, 1389, 0, 1393, 0, + 1395, 0, 0, 477, 972, 974, 0, 1747, 894, 895, + 0, 804, 794, 140, 144, 0, 166, 163, 0, 172, + 0, 0, 0, 0, 1217, 0, 1484, 0, 1574, 1575, + 1576, 67, 69, 1184, 87, 0, 1039, 1040, 1053, 1150, + 1892, 1892, 0, 0, 0, 1156, 1157, 1892, 1892, 1892, + 1892, 1162, 0, 1289, 1321, 1310, 1311, 1312, 1255, 1288, + 1276, 0, -2, 1284, 0, 0, 1749, 1759, 1760, 1450, + 1456, 1465, 1467, 1468, 0, 1480, 1481, 1482, 1489, 1149, + 1149, 1149, 1149, 1397, 893, 0, 0, 803, 0, 131, + 0, 0, 161, 162, 164, 0, 173, 0, 175, 176, + 0, 0, 1585, 89, 1041, 0, 0, 1153, 1154, 0, + 0, 0, 0, 0, 1265, 0, 1267, 1278, -2, 0, + 1286, 0, 1451, 1469, 0, 1470, 0, 0, 0, 1388, + 1390, 1394, 1396, 1747, 896, 805, 1227, 0, 145, 0, + 147, 149, 150, 1422, 158, 159, 165, 174, 0, 0, + 1026, 1042, 0, 1151, 1152, 1155, 1158, 1159, 1160, 1161, + 0, 1269, 1285, 1750, 1471, 1473, 1474, 0, 0, 1472, + 0, 132, 133, 0, 146, 0, 0, 1222, 1485, 1043, + 1266, 1263, 1475, 1477, 1476, 897, 0, 0, 148, 1423, + 134, 135, 136, 0, 1424, } var yyTok1 = [...]int{ @@ -10139,14 +10167,14 @@ var yyTok1 = [...]int{ 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 119, 3, 3, 3, 150, 142, 3, 86, 87, 147, 145, 160, 146, 159, 148, 3, 3, - 3, 3, 3, 3, 3, 3, 3, 3, 666, 663, - 129, 128, 130, 3, 667, 3, 3, 3, 3, 3, + 3, 3, 3, 3, 3, 3, 3, 3, 667, 664, + 129, 128, 130, 3, 668, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 152, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 3, 3, 3, 664, 141, 665, 153, + 3, 3, 3, 665, 141, 666, 153, } var yyTok2 = [...]int{ @@ -10256,7 +10284,7 @@ var yyTok3 = [...]int{ 57970, 645, 57971, 646, 57972, 647, 57973, 648, 57974, 649, 57975, 650, 57976, 651, 57977, 652, 57978, 653, 57979, 654, 57980, 655, 57981, 656, 57982, 657, 57983, 658, 57984, 659, - 57985, 660, 57986, 661, 57987, 662, 0, + 57985, 660, 57986, 661, 57987, 662, 57988, 663, 0, } var yyErrorMessages = [...]struct { @@ -19646,6 +19674,8 @@ yydefault: opt1.HnswQuantization = opt2.HnswQuantization } else if opt2.HnswEfSearch > 0 { opt1.HnswEfSearch = opt2.HnswEfSearch + } else if opt2.Async { + opt1.Async = opt2.Async } yyLOCAL = opt1 } @@ -19654,7 +19684,7 @@ yydefault: case 1151: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.IndexOption -//line mysql_sql.y:7572 +//line mysql_sql.y:7574 { io := tree.NewIndexOption() io.KeyBlockSize = uint64(yyDollar[3].item.(int64)) @@ -19664,7 +19694,7 @@ yydefault: case 1152: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.IndexOption -//line mysql_sql.y:7578 +//line mysql_sql.y:7580 { val := int64(yyDollar[3].item.(int64)) if val <= 0 { @@ -19680,7 +19710,7 @@ yydefault: case 1153: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.IndexOption -//line mysql_sql.y:7590 +//line mysql_sql.y:7592 { io := tree.NewIndexOption() io.AlgoParamVectorOpType = yyDollar[2].str @@ -19690,7 +19720,7 @@ yydefault: case 1154: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.IndexOption -//line mysql_sql.y:7596 +//line mysql_sql.y:7598 { io := tree.NewIndexOption() io.Comment = yyDollar[2].str @@ -19700,7 +19730,7 @@ yydefault: case 1155: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.IndexOption -//line mysql_sql.y:7602 +//line mysql_sql.y:7604 { io := tree.NewIndexOption() io.ParserName = yyDollar[3].cstrUnion().Compare() @@ -19710,7 +19740,7 @@ yydefault: case 1156: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.IndexOption -//line mysql_sql.y:7608 +//line mysql_sql.y:7610 { io := tree.NewIndexOption() io.Visible = tree.VISIBLE_TYPE_VISIBLE @@ -19720,7 +19750,7 @@ yydefault: case 1157: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.IndexOption -//line mysql_sql.y:7614 +//line mysql_sql.y:7616 { io := tree.NewIndexOption() io.Visible = tree.VISIBLE_TYPE_INVISIBLE @@ -19730,7 +19760,7 @@ yydefault: case 1158: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.IndexOption -//line mysql_sql.y:7620 +//line mysql_sql.y:7622 { val := int64(yyDollar[3].item.(int64)) if val <= 0 { @@ -19745,7 +19775,7 @@ yydefault: case 1159: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.IndexOption -//line mysql_sql.y:7631 +//line mysql_sql.y:7633 { val := int64(yyDollar[3].item.(int64)) if val <= 0 { @@ -19760,7 +19790,7 @@ yydefault: case 1160: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.IndexOption -//line mysql_sql.y:7642 +//line mysql_sql.y:7644 { val := int64(yyDollar[3].item.(int64)) if val <= 0 { @@ -19775,7 +19805,7 @@ yydefault: case 1161: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.IndexOption -//line mysql_sql.y:7653 +//line mysql_sql.y:7655 { io := tree.NewIndexOption() io.HnswQuantization = yyDollar[3].str @@ -19783,25 +19813,35 @@ yydefault: } yyVAL.union = yyLOCAL case 1162: + yyDollar = yyS[yypt-1 : yypt+1] + var yyLOCAL *tree.IndexOption +//line mysql_sql.y:7661 + { + io := tree.NewIndexOption() + io.Async = true + yyLOCAL = io + } + yyVAL.union = yyLOCAL + case 1163: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []*tree.KeyPart -//line mysql_sql.y:7662 +//line mysql_sql.y:7670 { yyLOCAL = []*tree.KeyPart{yyDollar[1].keyPartUnion()} } yyVAL.union = yyLOCAL - case 1163: + case 1164: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []*tree.KeyPart -//line mysql_sql.y:7666 +//line mysql_sql.y:7674 { yyLOCAL = append(yyDollar[1].keyPartsUnion(), yyDollar[3].keyPartUnion()) } yyVAL.union = yyLOCAL - case 1164: + case 1165: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.KeyPart -//line mysql_sql.y:7672 +//line mysql_sql.y:7680 { // Order is parsed but just ignored as MySQL dtree. var ColName = yyDollar[1].unresolvedNameUnion() @@ -19816,10 +19856,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1165: + case 1166: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.KeyPart -//line mysql_sql.y:7686 +//line mysql_sql.y:7694 { var ColName *tree.UnresolvedName var Length int @@ -19833,74 +19873,74 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1166: + case 1167: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.IndexType -//line mysql_sql.y:7700 +//line mysql_sql.y:7708 { yyLOCAL = tree.INDEX_TYPE_INVALID } yyVAL.union = yyLOCAL - case 1167: + case 1168: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.IndexType -//line mysql_sql.y:7704 +//line mysql_sql.y:7712 { yyLOCAL = tree.INDEX_TYPE_BTREE } yyVAL.union = yyLOCAL - case 1168: + case 1169: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.IndexType -//line mysql_sql.y:7708 +//line mysql_sql.y:7716 { yyLOCAL = tree.INDEX_TYPE_IVFFLAT } yyVAL.union = yyLOCAL - case 1169: + case 1170: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.IndexType -//line mysql_sql.y:7712 +//line mysql_sql.y:7720 { yyLOCAL = tree.INDEX_TYPE_HNSW } yyVAL.union = yyLOCAL - case 1170: + case 1171: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.IndexType -//line mysql_sql.y:7716 +//line mysql_sql.y:7724 { yyLOCAL = tree.INDEX_TYPE_MASTER } yyVAL.union = yyLOCAL - case 1171: + case 1172: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.IndexType -//line mysql_sql.y:7720 +//line mysql_sql.y:7728 { yyLOCAL = tree.INDEX_TYPE_HASH } yyVAL.union = yyLOCAL - case 1172: + case 1173: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.IndexType -//line mysql_sql.y:7724 +//line mysql_sql.y:7732 { yyLOCAL = tree.INDEX_TYPE_RTREE } yyVAL.union = yyLOCAL - case 1173: + case 1174: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.IndexType -//line mysql_sql.y:7728 +//line mysql_sql.y:7736 { yyLOCAL = tree.INDEX_TYPE_BSI } yyVAL.union = yyLOCAL - case 1174: + case 1175: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7734 +//line mysql_sql.y:7742 { var IfNotExists = yyDollar[3].ifNotExistsUnion() var Name = tree.Identifier(yyDollar[4].str) @@ -19914,10 +19954,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1175: + case 1176: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7748 +//line mysql_sql.y:7756 { var t = tree.NewCloneDatabase() t.DstDatabase = tree.Identifier(yyDollar[4].str) @@ -19926,10 +19966,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1176: + case 1177: yyDollar = yyS[yypt-10 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7756 +//line mysql_sql.y:7764 { var t = tree.NewCloneDatabase() t.DstDatabase = tree.Identifier(yyDollar[4].str) @@ -19939,92 +19979,92 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1177: + case 1178: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.SubscriptionOption -//line mysql_sql.y:7766 +//line mysql_sql.y:7774 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1178: + case 1179: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.SubscriptionOption -//line mysql_sql.y:7770 +//line mysql_sql.y:7778 { var From = tree.Identifier(yyDollar[2].str) var Publication = tree.Identifier(yyDollar[4].cstrUnion().Compare()) yyLOCAL = tree.NewSubscriptionOption(From, Publication) } yyVAL.union = yyLOCAL - case 1181: + case 1182: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:7781 +//line mysql_sql.y:7789 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1182: + case 1183: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:7785 +//line mysql_sql.y:7793 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1183: + case 1184: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:7790 +//line mysql_sql.y:7798 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1184: + case 1185: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:7794 +//line mysql_sql.y:7802 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1185: + case 1186: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL []tree.CreateOption -//line mysql_sql.y:7799 +//line mysql_sql.y:7807 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1186: + case 1187: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []tree.CreateOption -//line mysql_sql.y:7803 +//line mysql_sql.y:7811 { yyLOCAL = yyDollar[1].createOptionsUnion() } yyVAL.union = yyLOCAL - case 1187: + case 1188: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []tree.CreateOption -//line mysql_sql.y:7809 +//line mysql_sql.y:7817 { yyLOCAL = []tree.CreateOption{yyDollar[1].createOptionUnion()} } yyVAL.union = yyLOCAL - case 1188: + case 1189: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL []tree.CreateOption -//line mysql_sql.y:7813 +//line mysql_sql.y:7821 { yyLOCAL = append(yyDollar[1].createOptionsUnion(), yyDollar[2].createOptionUnion()) } yyVAL.union = yyLOCAL - case 1189: + case 1190: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.CreateOption -//line mysql_sql.y:7819 +//line mysql_sql.y:7827 { var IsDefault = yyDollar[1].defaultOptionalUnion() var Charset = yyDollar[4].str @@ -20034,10 +20074,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1190: + case 1191: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.CreateOption -//line mysql_sql.y:7828 +//line mysql_sql.y:7836 { var IsDefault = yyDollar[1].defaultOptionalUnion() var Collate = yyDollar[4].str @@ -20047,35 +20087,35 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1191: + case 1192: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.CreateOption -//line mysql_sql.y:7837 +//line mysql_sql.y:7845 { var Encrypt = yyDollar[4].str yyLOCAL = tree.NewCreateOptionEncryption(Encrypt) } yyVAL.union = yyLOCAL - case 1192: + case 1193: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:7843 +//line mysql_sql.y:7851 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1193: + case 1194: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:7847 +//line mysql_sql.y:7855 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1194: + case 1195: yyDollar = yyS[yypt-8 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7853 +//line mysql_sql.y:7861 { var TableName = yyDollar[4].tableNameUnion() var Options = yyDollar[7].connectorOptionsUnion() @@ -20085,18 +20125,18 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1195: + case 1196: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7864 +//line mysql_sql.y:7872 { yyLOCAL = &tree.ShowConnectors{} } yyVAL.union = yyLOCAL - case 1196: + case 1197: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7870 +//line mysql_sql.y:7878 { var taskID uint64 switch v := yyDollar[4].item.(type) { @@ -20113,10 +20153,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1197: + case 1198: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7888 +//line mysql_sql.y:7896 { var taskID uint64 switch v := yyDollar[4].item.(type) { @@ -20133,10 +20173,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1198: + case 1199: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7906 +//line mysql_sql.y:7914 { var taskID uint64 switch v := yyDollar[4].item.(type) { @@ -20153,10 +20193,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1199: + case 1200: yyDollar = yyS[yypt-9 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7924 +//line mysql_sql.y:7932 { var Replace = yyDollar[2].sourceOptionalUnion() var IfNotExists = yyDollar[4].ifNotExistsUnion() @@ -20172,26 +20212,26 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1200: + case 1201: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:7940 +//line mysql_sql.y:7948 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1201: + case 1202: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:7944 +//line mysql_sql.y:7952 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1202: + case 1203: yyDollar = yyS[yypt-11 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7953 +//line mysql_sql.y:7961 { t := tree.NewCreateTable() t.Temporary = yyDollar[2].boolValUnion() @@ -20204,10 +20244,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1203: + case 1204: yyDollar = yyS[yypt-9 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7965 +//line mysql_sql.y:7973 { t := tree.NewCreateTable() t.IfNotExists = yyDollar[4].ifNotExistsUnion() @@ -20217,10 +20257,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1204: + case 1205: yyDollar = yyS[yypt-11 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7974 +//line mysql_sql.y:7982 { t := tree.NewCreateTable() t.IsClusterTable = true @@ -20233,10 +20273,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1205: + case 1206: yyDollar = yyS[yypt-8 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7986 +//line mysql_sql.y:7994 { t := tree.NewCreateTable() t.IsDynamicTable = true @@ -20247,10 +20287,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1206: + case 1207: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:7996 +//line mysql_sql.y:8004 { t := tree.NewCreateTable() t.IsAsSelect = true @@ -20261,10 +20301,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1207: + case 1208: yyDollar = yyS[yypt-9 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:8006 +//line mysql_sql.y:8014 { t := tree.NewCreateTable() t.IsAsSelect = true @@ -20276,10 +20316,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1208: + case 1209: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:8017 +//line mysql_sql.y:8025 { t := tree.NewCreateTable() t.IsAsSelect = true @@ -20290,10 +20330,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1209: + case 1210: yyDollar = yyS[yypt-10 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:8027 +//line mysql_sql.y:8035 { t := tree.NewCreateTable() t.IsAsSelect = true @@ -20305,10 +20345,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1210: + case 1211: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:8038 +//line mysql_sql.y:8046 { t := tree.NewCreateTable() t.IsAsLike = true @@ -20317,10 +20357,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1211: + case 1212: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:8046 +//line mysql_sql.y:8054 { t := tree.NewCreateTable() t.Temporary = yyDollar[2].boolValUnion() @@ -20330,10 +20370,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1212: + case 1213: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:8055 +//line mysql_sql.y:8063 { t := tree.NewCloneTable() t.CreateTable.Table = *yyDollar[5].tableNameUnion() @@ -20343,10 +20383,10 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1213: + case 1214: yyDollar = yyS[yypt-10 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:8064 +//line mysql_sql.y:8072 { t := tree.NewCloneTable() t.CreateTable.Table = *yyDollar[5].tableNameUnion() @@ -20357,19 +20397,19 @@ yydefault: yyLOCAL = t } yyVAL.union = yyLOCAL - case 1214: + case 1215: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.ExternParam -//line mysql_sql.y:8076 +//line mysql_sql.y:8084 { yyLOCAL = yyDollar[1].loadParamUnion() yyLOCAL.Tail = yyDollar[2].tailParamUnion() } yyVAL.union = yyLOCAL - case 1215: + case 1216: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.ExternParam -//line mysql_sql.y:8083 +//line mysql_sql.y:8091 { yyLOCAL = &tree.ExternParam{ ExParamConst: tree.ExParamConst{ @@ -20380,10 +20420,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1216: + case 1217: yyDollar = yyS[yypt-9 : yypt+1] var yyLOCAL *tree.ExternParam -//line mysql_sql.y:8093 +//line mysql_sql.y:8101 { yyLOCAL = &tree.ExternParam{ ExParamConst: tree.ExParamConst{ @@ -20397,10 +20437,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1217: + case 1218: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.ExternParam -//line mysql_sql.y:8106 +//line mysql_sql.y:8114 { yyLOCAL = &tree.ExternParam{ ExParamConst: tree.ExParamConst{ @@ -20409,10 +20449,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1218: + case 1219: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.ExternParam -//line mysql_sql.y:8114 +//line mysql_sql.y:8122 { yyLOCAL = &tree.ExternParam{ ExParamConst: tree.ExParamConst{ @@ -20422,10 +20462,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1219: + case 1220: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.ExternParam -//line mysql_sql.y:8123 +//line mysql_sql.y:8131 { yyLOCAL = &tree.ExternParam{ ExParamConst: tree.ExParamConst{ @@ -20434,55 +20474,55 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1220: + case 1221: yyDollar = yyS[yypt-0 : yypt+1] -//line mysql_sql.y:8132 +//line mysql_sql.y:8140 { yyVAL.str = "" } - case 1221: + case 1222: yyDollar = yyS[yypt-4 : yypt+1] -//line mysql_sql.y:8136 +//line mysql_sql.y:8144 { yyVAL.str = yyDollar[4].str } - case 1222: + case 1223: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []string -//line mysql_sql.y:8142 +//line mysql_sql.y:8150 { yyLOCAL = yyDollar[1].strsUnion() } yyVAL.union = yyLOCAL - case 1223: + case 1224: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []string -//line mysql_sql.y:8146 +//line mysql_sql.y:8154 { yyLOCAL = append(yyDollar[1].strsUnion(), yyDollar[3].strsUnion()...) } yyVAL.union = yyLOCAL - case 1224: + case 1225: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL []string -//line mysql_sql.y:8151 +//line mysql_sql.y:8159 { yyLOCAL = []string{} } yyVAL.union = yyLOCAL - case 1225: + case 1226: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []string -//line mysql_sql.y:8155 +//line mysql_sql.y:8163 { yyLOCAL = append(yyLOCAL, yyDollar[1].str) yyLOCAL = append(yyLOCAL, yyDollar[3].str) } yyVAL.union = yyLOCAL - case 1226: + case 1227: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.TailParameter -//line mysql_sql.y:8162 +//line mysql_sql.y:8170 { yyLOCAL = &tree.TailParameter{ Charset: yyDollar[1].str, @@ -20494,22 +20534,22 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1227: + case 1228: yyDollar = yyS[yypt-0 : yypt+1] -//line mysql_sql.y:8174 +//line mysql_sql.y:8182 { yyVAL.str = "" } - case 1228: + case 1229: yyDollar = yyS[yypt-2 : yypt+1] -//line mysql_sql.y:8178 +//line mysql_sql.y:8186 { yyVAL.str = yyDollar[2].str } - case 1229: + case 1230: yyDollar = yyS[yypt-10 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:8184 +//line mysql_sql.y:8192 { var Name = yyDollar[4].tableNameUnion() var Type = yyDollar[5].columnTypeUnion() @@ -20531,10 +20571,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1230: + case 1231: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:8205 +//line mysql_sql.y:8213 { locale := "" fstr := "bigint" @@ -20549,44 +20589,44 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1231: + case 1232: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:8219 +//line mysql_sql.y:8227 { yyLOCAL = yyDollar[2].columnTypeUnion() } yyVAL.union = yyLOCAL - case 1232: + case 1233: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.TypeOption -//line mysql_sql.y:8223 +//line mysql_sql.y:8231 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1233: + case 1234: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.TypeOption -//line mysql_sql.y:8227 +//line mysql_sql.y:8235 { yyLOCAL = &tree.TypeOption{ Type: yyDollar[2].columnTypeUnion(), } } yyVAL.union = yyLOCAL - case 1234: + case 1235: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.IncrementByOption -//line mysql_sql.y:8233 +//line mysql_sql.y:8241 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1235: + case 1236: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.IncrementByOption -//line mysql_sql.y:8237 +//line mysql_sql.y:8245 { yyLOCAL = &tree.IncrementByOption{ Minus: false, @@ -20594,10 +20634,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1236: + case 1237: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.IncrementByOption -//line mysql_sql.y:8244 +//line mysql_sql.y:8252 { yyLOCAL = &tree.IncrementByOption{ Minus: false, @@ -20605,10 +20645,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1237: + case 1238: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.IncrementByOption -//line mysql_sql.y:8251 +//line mysql_sql.y:8259 { yyLOCAL = &tree.IncrementByOption{ Minus: true, @@ -20616,10 +20656,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1238: + case 1239: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.IncrementByOption -//line mysql_sql.y:8258 +//line mysql_sql.y:8266 { yyLOCAL = &tree.IncrementByOption{ Minus: true, @@ -20627,42 +20667,42 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1239: + case 1240: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:8265 +//line mysql_sql.y:8273 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1240: + case 1241: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:8269 +//line mysql_sql.y:8277 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1241: + case 1242: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:8273 +//line mysql_sql.y:8281 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1242: + case 1243: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.MinValueOption -//line mysql_sql.y:8277 +//line mysql_sql.y:8285 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1243: + case 1244: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.MinValueOption -//line mysql_sql.y:8281 +//line mysql_sql.y:8289 { yyLOCAL = &tree.MinValueOption{ Minus: false, @@ -20670,10 +20710,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1244: + case 1245: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.MinValueOption -//line mysql_sql.y:8288 +//line mysql_sql.y:8296 { yyLOCAL = &tree.MinValueOption{ Minus: true, @@ -20681,18 +20721,18 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1245: + case 1246: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.MaxValueOption -//line mysql_sql.y:8295 +//line mysql_sql.y:8303 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1246: + case 1247: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.MaxValueOption -//line mysql_sql.y:8299 +//line mysql_sql.y:8307 { yyLOCAL = &tree.MaxValueOption{ Minus: false, @@ -20700,10 +20740,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1247: + case 1248: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.MaxValueOption -//line mysql_sql.y:8306 +//line mysql_sql.y:8314 { yyLOCAL = &tree.MaxValueOption{ Minus: true, @@ -20711,46 +20751,46 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1248: + case 1249: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.CycleOption -//line mysql_sql.y:8313 +//line mysql_sql.y:8321 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1249: + case 1250: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.CycleOption -//line mysql_sql.y:8317 +//line mysql_sql.y:8325 { yyLOCAL = &tree.CycleOption{ Cycle: false, } } yyVAL.union = yyLOCAL - case 1250: + case 1251: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.CycleOption -//line mysql_sql.y:8323 +//line mysql_sql.y:8331 { yyLOCAL = &tree.CycleOption{ Cycle: true, } } yyVAL.union = yyLOCAL - case 1251: + case 1252: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.StartWithOption -//line mysql_sql.y:8329 +//line mysql_sql.y:8337 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1252: + case 1253: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.StartWithOption -//line mysql_sql.y:8333 +//line mysql_sql.y:8341 { yyLOCAL = &tree.StartWithOption{ Minus: false, @@ -20758,10 +20798,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1253: + case 1254: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.StartWithOption -//line mysql_sql.y:8340 +//line mysql_sql.y:8348 { yyLOCAL = &tree.StartWithOption{ Minus: false, @@ -20769,10 +20809,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1254: + case 1255: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.StartWithOption -//line mysql_sql.y:8347 +//line mysql_sql.y:8355 { yyLOCAL = &tree.StartWithOption{ Minus: true, @@ -20780,10 +20820,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1255: + case 1256: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.StartWithOption -//line mysql_sql.y:8354 +//line mysql_sql.y:8362 { yyLOCAL = &tree.StartWithOption{ Minus: true, @@ -20791,58 +20831,58 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1256: + case 1257: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:8361 +//line mysql_sql.y:8369 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1257: + case 1258: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:8365 +//line mysql_sql.y:8373 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1258: + case 1259: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:8370 +//line mysql_sql.y:8378 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1259: + case 1260: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:8374 +//line mysql_sql.y:8382 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1260: + case 1261: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:8378 +//line mysql_sql.y:8386 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1261: + case 1262: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.PartitionOption -//line mysql_sql.y:8383 +//line mysql_sql.y:8391 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1262: + case 1263: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.PartitionOption -//line mysql_sql.y:8387 +//line mysql_sql.y:8395 { yyDollar[3].partitionByUnion().Num = uint64(yyDollar[4].int64ValUnion()) var PartBy = yyDollar[3].partitionByUnion() @@ -20855,18 +20895,18 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1263: + case 1264: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.ClusterByOption -//line mysql_sql.y:8400 +//line mysql_sql.y:8408 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1264: + case 1265: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.ClusterByOption -//line mysql_sql.y:8404 +//line mysql_sql.y:8412 { var ColumnList = []*tree.UnresolvedName{yyDollar[3].unresolvedNameUnion()} yyLOCAL = tree.NewClusterByOption( @@ -20875,10 +20915,10 @@ yydefault: } yyVAL.union = yyLOCAL - case 1265: + case 1266: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.ClusterByOption -//line mysql_sql.y:8412 +//line mysql_sql.y:8420 { var ColumnList = yyDollar[4].unresolveNamesUnion() yyLOCAL = tree.NewClusterByOption( @@ -20886,18 +20926,18 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1266: + case 1267: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.PartitionBy -//line mysql_sql.y:8420 +//line mysql_sql.y:8428 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1267: + case 1268: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.PartitionBy -//line mysql_sql.y:8424 +//line mysql_sql.y:8432 { var IsSubPartition = true var PType = yyDollar[3].partitionByUnion() @@ -20909,42 +20949,42 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1268: + case 1269: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL []*tree.Partition -//line mysql_sql.y:8436 +//line mysql_sql.y:8444 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1269: + case 1270: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []*tree.Partition -//line mysql_sql.y:8440 +//line mysql_sql.y:8448 { yyLOCAL = yyDollar[2].partitionsUnion() } yyVAL.union = yyLOCAL - case 1270: + case 1271: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []*tree.Partition -//line mysql_sql.y:8446 +//line mysql_sql.y:8454 { yyLOCAL = []*tree.Partition{yyDollar[1].partitionUnion()} } yyVAL.union = yyLOCAL - case 1271: + case 1272: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []*tree.Partition -//line mysql_sql.y:8450 +//line mysql_sql.y:8458 { yyLOCAL = append(yyDollar[1].partitionsUnion(), yyDollar[3].partitionUnion()) } yyVAL.union = yyLOCAL - case 1272: + case 1273: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.Partition -//line mysql_sql.y:8456 +//line mysql_sql.y:8464 { var Name = tree.Identifier(yyDollar[2].cstrUnion().Compare()) var Values = yyDollar[3].valuesUnion() @@ -20958,10 +20998,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1273: + case 1274: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.Partition -//line mysql_sql.y:8469 +//line mysql_sql.y:8477 { var Name = tree.Identifier(yyDollar[2].cstrUnion().Compare()) var Values = yyDollar[3].valuesUnion() @@ -20975,42 +21015,42 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1274: + case 1275: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL []*tree.SubPartition -//line mysql_sql.y:8483 +//line mysql_sql.y:8491 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1275: + case 1276: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []*tree.SubPartition -//line mysql_sql.y:8487 +//line mysql_sql.y:8495 { yyLOCAL = yyDollar[2].subPartitionsUnion() } yyVAL.union = yyLOCAL - case 1276: + case 1277: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []*tree.SubPartition -//line mysql_sql.y:8493 +//line mysql_sql.y:8501 { yyLOCAL = []*tree.SubPartition{yyDollar[1].subPartitionUnion()} } yyVAL.union = yyLOCAL - case 1277: + case 1278: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []*tree.SubPartition -//line mysql_sql.y:8497 +//line mysql_sql.y:8505 { yyLOCAL = append(yyDollar[1].subPartitionsUnion(), yyDollar[3].subPartitionUnion()) } yyVAL.union = yyLOCAL - case 1278: + case 1279: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.SubPartition -//line mysql_sql.y:8503 +//line mysql_sql.y:8511 { var Name = tree.Identifier(yyDollar[2].cstrUnion().Compare()) var Options []tree.TableOption @@ -21020,10 +21060,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1279: + case 1280: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.SubPartition -//line mysql_sql.y:8512 +//line mysql_sql.y:8520 { var Name = tree.Identifier(yyDollar[2].cstrUnion().Compare()) var Options = yyDollar[3].tableOptionsUnion() @@ -21033,53 +21073,53 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1280: + case 1281: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []tree.TableOption -//line mysql_sql.y:8523 +//line mysql_sql.y:8531 { yyLOCAL = []tree.TableOption{yyDollar[1].tableOptionUnion()} } yyVAL.union = yyLOCAL - case 1281: + case 1282: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL []tree.TableOption -//line mysql_sql.y:8527 +//line mysql_sql.y:8535 { yyLOCAL = append(yyDollar[1].tableOptionsUnion(), yyDollar[2].tableOptionUnion()) } yyVAL.union = yyLOCAL - case 1282: + case 1283: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.Values -//line mysql_sql.y:8532 +//line mysql_sql.y:8540 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1283: + case 1284: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Values -//line mysql_sql.y:8536 +//line mysql_sql.y:8544 { expr := tree.NewMaxValue() var valueList = tree.Exprs{expr} yyLOCAL = tree.NewValuesLessThan(valueList) } yyVAL.union = yyLOCAL - case 1284: + case 1285: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL tree.Values -//line mysql_sql.y:8542 +//line mysql_sql.y:8550 { var valueList = yyDollar[5].exprsUnion() yyLOCAL = tree.NewValuesLessThan(valueList) } yyVAL.union = yyLOCAL - case 1285: + case 1286: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.Values -//line mysql_sql.y:8547 +//line mysql_sql.y:8555 { var valueList = yyDollar[4].exprsUnion() yyLOCAL = tree.NewValuesIn( @@ -21087,18 +21127,18 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1286: + case 1287: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL int64 -//line mysql_sql.y:8555 +//line mysql_sql.y:8563 { yyLOCAL = 0 } yyVAL.union = yyLOCAL - case 1287: + case 1288: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL int64 -//line mysql_sql.y:8559 +//line mysql_sql.y:8567 { res := yyDollar[2].item.(int64) if res == 0 { @@ -21108,18 +21148,18 @@ yydefault: yyLOCAL = res } yyVAL.union = yyLOCAL - case 1288: + case 1289: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL int64 -//line mysql_sql.y:8569 +//line mysql_sql.y:8577 { yyLOCAL = 0 } yyVAL.union = yyLOCAL - case 1289: + case 1290: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL int64 -//line mysql_sql.y:8573 +//line mysql_sql.y:8581 { res := yyDollar[2].item.(int64) if res == 0 { @@ -21129,10 +21169,10 @@ yydefault: yyLOCAL = res } yyVAL.union = yyLOCAL - case 1290: + case 1291: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.PartitionBy -//line mysql_sql.y:8584 +//line mysql_sql.y:8592 { rangeTyp := tree.NewRangeType() rangeTyp.Expr = yyDollar[3].exprUnion() @@ -21141,10 +21181,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1291: + case 1292: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.PartitionBy -//line mysql_sql.y:8592 +//line mysql_sql.y:8600 { rangeTyp := tree.NewRangeType() rangeTyp.ColumnList = yyDollar[4].unresolveNamesUnion() @@ -21153,10 +21193,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1292: + case 1293: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.PartitionBy -//line mysql_sql.y:8600 +//line mysql_sql.y:8608 { listTyp := tree.NewListType() listTyp.Expr = yyDollar[3].exprUnion() @@ -21165,10 +21205,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1293: + case 1294: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.PartitionBy -//line mysql_sql.y:8608 +//line mysql_sql.y:8616 { listTyp := tree.NewListType() listTyp.ColumnList = yyDollar[4].unresolveNamesUnion() @@ -21177,10 +21217,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1295: + case 1296: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.PartitionBy -//line mysql_sql.y:8619 +//line mysql_sql.y:8627 { keyTyp := tree.NewKeyType() keyTyp.Linear = yyDollar[1].boolValUnion() @@ -21190,10 +21230,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1296: + case 1297: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.PartitionBy -//line mysql_sql.y:8628 +//line mysql_sql.y:8636 { keyTyp := tree.NewKeyType() keyTyp.Linear = yyDollar[1].boolValUnion() @@ -21204,10 +21244,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1297: + case 1298: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.PartitionBy -//line mysql_sql.y:8638 +//line mysql_sql.y:8646 { Linear := yyDollar[1].boolValUnion() Expr := yyDollar[4].exprUnion() @@ -21217,58 +21257,58 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1298: + case 1299: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL int64 -//line mysql_sql.y:8648 +//line mysql_sql.y:8656 { yyLOCAL = 2 } yyVAL.union = yyLOCAL - case 1299: + case 1300: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL int64 -//line mysql_sql.y:8652 +//line mysql_sql.y:8660 { yyLOCAL = yyDollar[3].item.(int64) } yyVAL.union = yyLOCAL - case 1300: + case 1301: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:8657 +//line mysql_sql.y:8665 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1301: + case 1302: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:8661 +//line mysql_sql.y:8669 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1302: + case 1303: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []*tree.ConnectorOption -//line mysql_sql.y:8667 +//line mysql_sql.y:8675 { yyLOCAL = []*tree.ConnectorOption{yyDollar[1].connectorOptionUnion()} } yyVAL.union = yyLOCAL - case 1303: + case 1304: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []*tree.ConnectorOption -//line mysql_sql.y:8671 +//line mysql_sql.y:8679 { yyLOCAL = append(yyDollar[1].connectorOptionsUnion(), yyDollar[3].connectorOptionUnion()) } yyVAL.union = yyLOCAL - case 1304: + case 1305: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.ConnectorOption -//line mysql_sql.y:8677 +//line mysql_sql.y:8685 { var Key = tree.Identifier(yyDollar[1].cstrUnion().Compare()) var Val = yyDollar[3].exprUnion() @@ -21278,10 +21318,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1305: + case 1306: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.ConnectorOption -//line mysql_sql.y:8686 +//line mysql_sql.y:8694 { var Key = tree.Identifier(yyDollar[1].str) var Val = yyDollar[3].exprUnion() @@ -21291,42 +21331,42 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1306: + case 1307: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL []tree.TableOption -//line mysql_sql.y:8696 +//line mysql_sql.y:8704 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1307: + case 1308: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL []tree.TableOption -//line mysql_sql.y:8700 +//line mysql_sql.y:8708 { yyLOCAL = yyDollar[3].tableOptionsUnion() } yyVAL.union = yyLOCAL - case 1308: + case 1309: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []tree.TableOption -//line mysql_sql.y:8706 +//line mysql_sql.y:8714 { yyLOCAL = []tree.TableOption{yyDollar[1].tableOptionUnion()} } yyVAL.union = yyLOCAL - case 1309: + case 1310: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []tree.TableOption -//line mysql_sql.y:8710 +//line mysql_sql.y:8718 { yyLOCAL = append(yyDollar[1].tableOptionsUnion(), yyDollar[3].tableOptionUnion()) } yyVAL.union = yyLOCAL - case 1310: + case 1311: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8716 +//line mysql_sql.y:8724 { var Key = tree.Identifier(yyDollar[1].cstrUnion().Compare()) var Val = yyDollar[3].exprUnion() @@ -21336,10 +21376,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1311: + case 1312: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8725 +//line mysql_sql.y:8733 { var Key = tree.Identifier(yyDollar[1].str) var Val = yyDollar[3].exprUnion() @@ -21349,364 +21389,364 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1312: + case 1313: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL []tree.TableOption -//line mysql_sql.y:8735 +//line mysql_sql.y:8743 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1313: + case 1314: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []tree.TableOption -//line mysql_sql.y:8739 +//line mysql_sql.y:8747 { yyLOCAL = yyDollar[1].tableOptionsUnion() } yyVAL.union = yyLOCAL - case 1314: + case 1315: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []tree.TableOption -//line mysql_sql.y:8745 +//line mysql_sql.y:8753 { yyLOCAL = []tree.TableOption{yyDollar[1].tableOptionUnion()} } yyVAL.union = yyLOCAL - case 1315: + case 1316: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []tree.TableOption -//line mysql_sql.y:8749 +//line mysql_sql.y:8757 { yyLOCAL = append(yyDollar[1].tableOptionsUnion(), yyDollar[3].tableOptionUnion()) } yyVAL.union = yyLOCAL - case 1316: + case 1317: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL []tree.TableOption -//line mysql_sql.y:8753 +//line mysql_sql.y:8761 { yyLOCAL = append(yyDollar[1].tableOptionsUnion(), yyDollar[2].tableOptionUnion()) } yyVAL.union = yyLOCAL - case 1317: + case 1318: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8759 +//line mysql_sql.y:8767 { yyLOCAL = tree.NewTableOptionAUTOEXTEND_SIZE(uint64(yyDollar[3].item.(int64))) } yyVAL.union = yyLOCAL - case 1318: + case 1319: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8763 +//line mysql_sql.y:8771 { yyLOCAL = tree.NewTableOptionAutoIncrement(uint64(yyDollar[3].item.(int64))) } yyVAL.union = yyLOCAL - case 1319: + case 1320: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8767 +//line mysql_sql.y:8775 { yyLOCAL = tree.NewTableOptionAvgRowLength(uint64(yyDollar[3].item.(int64))) } yyVAL.union = yyLOCAL - case 1320: + case 1321: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8771 +//line mysql_sql.y:8779 { yyLOCAL = tree.NewTableOptionCharset(yyDollar[4].str) } yyVAL.union = yyLOCAL - case 1321: + case 1322: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8775 +//line mysql_sql.y:8783 { yyLOCAL = tree.NewTableOptionCollate(yyDollar[4].str) } yyVAL.union = yyLOCAL - case 1322: + case 1323: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8779 +//line mysql_sql.y:8787 { yyLOCAL = tree.NewTableOptionChecksum(uint64(yyDollar[3].item.(int64))) } yyVAL.union = yyLOCAL - case 1323: + case 1324: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8783 +//line mysql_sql.y:8791 { str := util.DealCommentString(yyDollar[3].str) yyLOCAL = tree.NewTableOptionComment(str) } yyVAL.union = yyLOCAL - case 1324: + case 1325: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8788 +//line mysql_sql.y:8796 { yyLOCAL = tree.NewTableOptionCompression(yyDollar[3].str) } yyVAL.union = yyLOCAL - case 1325: + case 1326: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8792 +//line mysql_sql.y:8800 { yyLOCAL = tree.NewTableOptionConnection(yyDollar[3].str) } yyVAL.union = yyLOCAL - case 1326: + case 1327: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8796 +//line mysql_sql.y:8804 { yyLOCAL = tree.NewTableOptionDataDirectory(yyDollar[4].str) } yyVAL.union = yyLOCAL - case 1327: + case 1328: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8800 +//line mysql_sql.y:8808 { yyLOCAL = tree.NewTableOptionIndexDirectory(yyDollar[4].str) } yyVAL.union = yyLOCAL - case 1328: + case 1329: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8804 +//line mysql_sql.y:8812 { yyLOCAL = tree.NewTableOptionDelayKeyWrite(uint64(yyDollar[3].item.(int64))) } yyVAL.union = yyLOCAL - case 1329: + case 1330: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8808 +//line mysql_sql.y:8816 { yyLOCAL = tree.NewTableOptionEncryption(yyDollar[3].str) } yyVAL.union = yyLOCAL - case 1330: + case 1331: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8812 +//line mysql_sql.y:8820 { yyLOCAL = tree.NewTableOptionEngine(yyDollar[3].str) } yyVAL.union = yyLOCAL - case 1331: + case 1332: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8816 +//line mysql_sql.y:8824 { yyLOCAL = tree.NewTableOptionEngineAttr(yyDollar[3].str) } yyVAL.union = yyLOCAL - case 1332: + case 1333: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8820 +//line mysql_sql.y:8828 { yyLOCAL = tree.NewTableOptionInsertMethod(yyDollar[3].str) } yyVAL.union = yyLOCAL - case 1333: + case 1334: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8824 +//line mysql_sql.y:8832 { yyLOCAL = tree.NewTableOptionKeyBlockSize(uint64(yyDollar[3].item.(int64))) } yyVAL.union = yyLOCAL - case 1334: + case 1335: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8828 +//line mysql_sql.y:8836 { yyLOCAL = tree.NewTableOptionMaxRows(uint64(yyDollar[3].item.(int64))) } yyVAL.union = yyLOCAL - case 1335: + case 1336: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8832 +//line mysql_sql.y:8840 { yyLOCAL = tree.NewTableOptionMinRows(uint64(yyDollar[3].item.(int64))) } yyVAL.union = yyLOCAL - case 1336: + case 1337: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8836 +//line mysql_sql.y:8844 { t := tree.NewTableOptionPackKeys() t.Value = yyDollar[3].item.(int64) yyLOCAL = t } yyVAL.union = yyLOCAL - case 1337: + case 1338: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8842 +//line mysql_sql.y:8850 { t := tree.NewTableOptionPackKeys() t.Default = true yyLOCAL = t } yyVAL.union = yyLOCAL - case 1338: + case 1339: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8848 +//line mysql_sql.y:8856 { yyLOCAL = tree.NewTableOptionPassword(yyDollar[3].str) } yyVAL.union = yyLOCAL - case 1339: + case 1340: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8852 +//line mysql_sql.y:8860 { yyLOCAL = tree.NewTableOptionRowFormat(yyDollar[3].rowFormatTypeUnion()) } yyVAL.union = yyLOCAL - case 1340: + case 1341: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8856 +//line mysql_sql.y:8864 { yyLOCAL = tree.NewTTableOptionStartTrans(true) } yyVAL.union = yyLOCAL - case 1341: + case 1342: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8860 +//line mysql_sql.y:8868 { yyLOCAL = tree.NewTTableOptionSecondaryEngineAttr(yyDollar[3].str) } yyVAL.union = yyLOCAL - case 1342: + case 1343: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8864 +//line mysql_sql.y:8872 { t := tree.NewTableOptionStatsAutoRecalc() t.Value = uint64(yyDollar[3].item.(int64)) yyLOCAL = t } yyVAL.union = yyLOCAL - case 1343: + case 1344: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8870 +//line mysql_sql.y:8878 { t := tree.NewTableOptionStatsAutoRecalc() t.Default = true yyLOCAL = t } yyVAL.union = yyLOCAL - case 1344: + case 1345: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8876 +//line mysql_sql.y:8884 { t := tree.NewTableOptionStatsPersistent() t.Value = uint64(yyDollar[3].item.(int64)) yyLOCAL = t } yyVAL.union = yyLOCAL - case 1345: + case 1346: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8882 +//line mysql_sql.y:8890 { t := tree.NewTableOptionStatsPersistent() t.Default = true yyLOCAL = t } yyVAL.union = yyLOCAL - case 1346: + case 1347: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8888 +//line mysql_sql.y:8896 { t := tree.NewTableOptionStatsSamplePages() t.Value = uint64(yyDollar[3].item.(int64)) yyLOCAL = t } yyVAL.union = yyLOCAL - case 1347: + case 1348: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8894 +//line mysql_sql.y:8902 { t := tree.NewTableOptionStatsSamplePages() t.Default = true yyLOCAL = t } yyVAL.union = yyLOCAL - case 1348: + case 1349: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8900 +//line mysql_sql.y:8908 { yyLOCAL = tree.NewTableOptionTablespace(yyDollar[3].cstrUnion().Compare(), "") } yyVAL.union = yyLOCAL - case 1349: + case 1350: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8904 +//line mysql_sql.y:8912 { yyLOCAL = tree.NewTableOptionTablespace("", yyDollar[1].str) } yyVAL.union = yyLOCAL - case 1350: + case 1351: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8908 +//line mysql_sql.y:8916 { yyLOCAL = tree.NewTableOptionUnion(yyDollar[4].tableNamesUnion()) } yyVAL.union = yyLOCAL - case 1351: + case 1352: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.TableOption -//line mysql_sql.y:8912 +//line mysql_sql.y:8920 { var Preperties = yyDollar[3].propertiesUnion() yyLOCAL = tree.NewTableOptionProperties(Preperties) } yyVAL.union = yyLOCAL - case 1352: + case 1353: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []tree.Property -//line mysql_sql.y:8919 +//line mysql_sql.y:8927 { yyLOCAL = []tree.Property{yyDollar[1].propertyUnion()} } yyVAL.union = yyLOCAL - case 1353: + case 1354: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []tree.Property -//line mysql_sql.y:8923 +//line mysql_sql.y:8931 { yyLOCAL = append(yyDollar[1].propertiesUnion(), yyDollar[3].propertyUnion()) } yyVAL.union = yyLOCAL - case 1354: + case 1355: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Property -//line mysql_sql.y:8929 +//line mysql_sql.y:8937 { var Key = yyDollar[1].str var Value = yyDollar[3].str @@ -21716,96 +21756,96 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1355: + case 1356: yyDollar = yyS[yypt-2 : yypt+1] -//line mysql_sql.y:8940 +//line mysql_sql.y:8948 { yyVAL.str = " " + yyDollar[1].str + " " + yyDollar[2].str } - case 1356: + case 1357: yyDollar = yyS[yypt-2 : yypt+1] -//line mysql_sql.y:8944 +//line mysql_sql.y:8952 { yyVAL.str = " " + yyDollar[1].str + " " + yyDollar[2].str } - case 1357: + case 1358: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.RowFormatType -//line mysql_sql.y:8950 +//line mysql_sql.y:8958 { yyLOCAL = tree.ROW_FORMAT_DEFAULT } yyVAL.union = yyLOCAL - case 1358: + case 1359: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.RowFormatType -//line mysql_sql.y:8954 +//line mysql_sql.y:8962 { yyLOCAL = tree.ROW_FORMAT_DYNAMIC } yyVAL.union = yyLOCAL - case 1359: + case 1360: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.RowFormatType -//line mysql_sql.y:8958 +//line mysql_sql.y:8966 { yyLOCAL = tree.ROW_FORMAT_FIXED } yyVAL.union = yyLOCAL - case 1360: + case 1361: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.RowFormatType -//line mysql_sql.y:8962 +//line mysql_sql.y:8970 { yyLOCAL = tree.ROW_FORMAT_COMPRESSED } yyVAL.union = yyLOCAL - case 1361: + case 1362: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.RowFormatType -//line mysql_sql.y:8966 +//line mysql_sql.y:8974 { yyLOCAL = tree.ROW_FORMAT_REDUNDANT } yyVAL.union = yyLOCAL - case 1362: + case 1363: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.RowFormatType -//line mysql_sql.y:8970 +//line mysql_sql.y:8978 { yyLOCAL = tree.ROW_FORMAT_COMPACT } yyVAL.union = yyLOCAL - case 1367: + case 1368: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.TableNames -//line mysql_sql.y:8984 +//line mysql_sql.y:8992 { yyLOCAL = tree.TableNames{yyDollar[1].tableNameUnion()} } yyVAL.union = yyLOCAL - case 1368: + case 1369: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableNames -//line mysql_sql.y:8988 +//line mysql_sql.y:8996 { yyLOCAL = append(yyDollar[1].tableNamesUnion(), yyDollar[3].tableNameUnion()) } yyVAL.union = yyLOCAL - case 1369: + case 1370: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.TableName -//line mysql_sql.y:8997 +//line mysql_sql.y:9005 { tblName := yylex.(*Lexer).GetDbOrTblName(yyDollar[1].cstrUnion().Origin()) prefix := tree.ObjectNamePrefix{ExplicitSchema: false} yyLOCAL = tree.NewTableName(tree.Identifier(tblName), prefix, yyDollar[2].atTimeStampUnion()) } yyVAL.union = yyLOCAL - case 1370: + case 1371: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.TableName -//line mysql_sql.y:9003 +//line mysql_sql.y:9011 { dbName := yylex.(*Lexer).GetDbOrTblName(yyDollar[1].cstrUnion().Origin()) tblName := yylex.(*Lexer).GetDbOrTblName(yyDollar[3].cstrUnion().Origin()) @@ -21813,18 +21853,18 @@ yydefault: yyLOCAL = tree.NewTableName(tree.Identifier(tblName), prefix, yyDollar[4].atTimeStampUnion()) } yyVAL.union = yyLOCAL - case 1371: + case 1372: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.AtTimeStamp -//line mysql_sql.y:9011 +//line mysql_sql.y:9019 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1372: + case 1373: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.AtTimeStamp -//line mysql_sql.y:9015 +//line mysql_sql.y:9023 { yyLOCAL = &tree.AtTimeStamp{ Type: tree.ATTIMESTAMPTIME, @@ -21832,10 +21872,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1373: + case 1374: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.AtTimeStamp -//line mysql_sql.y:9022 +//line mysql_sql.y:9030 { var str = yyDollar[4].cstrUnion().Compare() yyLOCAL = &tree.AtTimeStamp{ @@ -21845,10 +21885,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1374: + case 1375: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.AtTimeStamp -//line mysql_sql.y:9031 +//line mysql_sql.y:9039 { yyLOCAL = &tree.AtTimeStamp{ Type: tree.ATTIMESTAMPSNAPSHOT, @@ -21857,10 +21897,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1375: + case 1376: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.AtTimeStamp -//line mysql_sql.y:9039 +//line mysql_sql.y:9047 { yyLOCAL = &tree.AtTimeStamp{ Type: tree.ATMOTIMESTAMP, @@ -21868,10 +21908,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1376: + case 1377: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.AtTimeStamp -//line mysql_sql.y:9046 +//line mysql_sql.y:9054 { yyLOCAL = &tree.AtTimeStamp{ Type: tree.ASOFTIMESTAMP, @@ -21879,74 +21919,74 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1377: + case 1378: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.TableDefs -//line mysql_sql.y:9054 +//line mysql_sql.y:9062 { yyLOCAL = tree.TableDefs(nil) } yyVAL.union = yyLOCAL - case 1379: + case 1380: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.TableDefs -//line mysql_sql.y:9061 +//line mysql_sql.y:9069 { yyLOCAL = tree.TableDefs{yyDollar[1].tableDefUnion()} } yyVAL.union = yyLOCAL - case 1380: + case 1381: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.TableDefs -//line mysql_sql.y:9065 +//line mysql_sql.y:9073 { yyLOCAL = append(yyDollar[1].tableDefsUnion(), yyDollar[3].tableDefUnion()) } yyVAL.union = yyLOCAL - case 1381: + case 1382: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9071 +//line mysql_sql.y:9079 { yyLOCAL = tree.TableDef(yyDollar[1].columnTableDefUnion()) } yyVAL.union = yyLOCAL - case 1382: + case 1383: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9075 +//line mysql_sql.y:9083 { yyLOCAL = yyDollar[1].tableDefUnion() } yyVAL.union = yyLOCAL - case 1383: + case 1384: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9079 +//line mysql_sql.y:9087 { yyLOCAL = yyDollar[1].tableDefUnion() } yyVAL.union = yyLOCAL - case 1384: + case 1385: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9085 +//line mysql_sql.y:9093 { yyLOCAL = yyDollar[1].tableDefUnion() } yyVAL.union = yyLOCAL - case 1385: + case 1386: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9089 +//line mysql_sql.y:9097 { yyLOCAL = yyDollar[1].tableDefUnion() } yyVAL.union = yyLOCAL - case 1386: + case 1387: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9095 +//line mysql_sql.y:9103 { var KeyParts = yyDollar[5].keyPartsUnion() var Name = yyDollar[3].str @@ -21960,10 +22000,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1387: + case 1388: yyDollar = yyS[yypt-9 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9108 +//line mysql_sql.y:9116 { var KeyParts = yyDollar[5].keyPartsUnion() var Name = yyDollar[3].str @@ -21977,10 +22017,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1388: + case 1389: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9121 +//line mysql_sql.y:9129 { keyTyp := tree.INDEX_TYPE_INVALID if yyDollar[3].strsUnion()[1] != "" { @@ -22022,10 +22062,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1389: + case 1390: yyDollar = yyS[yypt-9 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9162 +//line mysql_sql.y:9170 { keyTyp := tree.INDEX_TYPE_INVALID if yyDollar[3].strsUnion()[1] != "" { @@ -22066,10 +22106,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1390: + case 1391: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9204 +//line mysql_sql.y:9212 { if yyDollar[1].str != "" { switch v := yyDollar[2].tableDefUnion().(type) { @@ -22084,18 +22124,18 @@ yydefault: yyLOCAL = yyDollar[2].tableDefUnion() } yyVAL.union = yyLOCAL - case 1391: + case 1392: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9218 +//line mysql_sql.y:9226 { yyLOCAL = yyDollar[1].tableDefUnion() } yyVAL.union = yyLOCAL - case 1392: + case 1393: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9224 +//line mysql_sql.y:9232 { var KeyParts = yyDollar[5].keyPartsUnion() var Name = yyDollar[3].strsUnion()[0] @@ -22109,10 +22149,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1393: + case 1394: yyDollar = yyS[yypt-9 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9237 +//line mysql_sql.y:9245 { var KeyParts = yyDollar[5].keyPartsUnion() var Name = yyDollar[3].strsUnion()[0] @@ -22126,10 +22166,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1394: + case 1395: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9250 +//line mysql_sql.y:9258 { var KeyParts = yyDollar[5].keyPartsUnion() var Name = yyDollar[3].strsUnion()[0] @@ -22143,10 +22183,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1395: + case 1396: yyDollar = yyS[yypt-9 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9263 +//line mysql_sql.y:9271 { var KeyParts = yyDollar[5].keyPartsUnion() var Name = yyDollar[3].strsUnion()[0] @@ -22160,10 +22200,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1396: + case 1397: yyDollar = yyS[yypt-8 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9276 +//line mysql_sql.y:9284 { var IfNotExists = yyDollar[3].ifNotExistsUnion() var KeyParts = yyDollar[6].keyPartsUnion() @@ -22179,10 +22219,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1397: + case 1398: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.TableDef -//line mysql_sql.y:9291 +//line mysql_sql.y:9299 { var Expr = yyDollar[3].exprUnion() var Enforced = yyDollar[5].boolValUnion() @@ -22192,327 +22232,327 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1398: + case 1399: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:9301 +//line mysql_sql.y:9309 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1400: + case 1401: yyDollar = yyS[yypt-0 : yypt+1] -//line mysql_sql.y:9307 +//line mysql_sql.y:9315 { yyVAL.str = "" } - case 1401: + case 1402: yyDollar = yyS[yypt-1 : yypt+1] -//line mysql_sql.y:9311 +//line mysql_sql.y:9319 { yyVAL.str = yyDollar[1].str } - case 1404: + case 1405: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []string -//line mysql_sql.y:9321 +//line mysql_sql.y:9329 { yyLOCAL = make([]string, 2) yyLOCAL[0] = yyDollar[1].str yyLOCAL[1] = "" } yyVAL.union = yyLOCAL - case 1405: + case 1406: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []string -//line mysql_sql.y:9327 +//line mysql_sql.y:9335 { yyLOCAL = make([]string, 2) yyLOCAL[0] = yyDollar[1].str yyLOCAL[1] = yyDollar[3].str } yyVAL.union = yyLOCAL - case 1406: + case 1407: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []string -//line mysql_sql.y:9333 +//line mysql_sql.y:9341 { yyLOCAL = make([]string, 2) yyLOCAL[0] = yyDollar[1].cstrUnion().Compare() yyLOCAL[1] = yyDollar[3].str } yyVAL.union = yyLOCAL - case 1418: + case 1419: yyDollar = yyS[yypt-0 : yypt+1] -//line mysql_sql.y:9355 +//line mysql_sql.y:9363 { yyVAL.str = "" } - case 1419: + case 1420: yyDollar = yyS[yypt-1 : yypt+1] -//line mysql_sql.y:9359 +//line mysql_sql.y:9367 { yyVAL.str = yyDollar[1].cstrUnion().Compare() } - case 1420: + case 1421: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.ColumnTableDef -//line mysql_sql.y:9365 +//line mysql_sql.y:9373 { yyLOCAL = tree.NewColumnTableDef(yyDollar[1].unresolvedNameUnion(), yyDollar[2].columnTypeUnion(), yyDollar[3].columnAttributesUnion()) } yyVAL.union = yyLOCAL - case 1421: + case 1422: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.UnresolvedName -//line mysql_sql.y:9371 +//line mysql_sql.y:9379 { yyLOCAL = tree.NewUnresolvedName(yyDollar[1].cstrUnion()) } yyVAL.union = yyLOCAL - case 1422: + case 1423: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.UnresolvedName -//line mysql_sql.y:9375 +//line mysql_sql.y:9383 { tblNameCStr := yylex.(*Lexer).GetDbOrTblNameCStr(yyDollar[1].cstrUnion().Origin()) yyLOCAL = tree.NewUnresolvedName(tblNameCStr, yyDollar[3].cstrUnion()) } yyVAL.union = yyLOCAL - case 1423: + case 1424: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.UnresolvedName -//line mysql_sql.y:9380 +//line mysql_sql.y:9388 { dbNameCStr := yylex.(*Lexer).GetDbOrTblNameCStr(yyDollar[1].cstrUnion().Origin()) tblNameCStr := yylex.(*Lexer).GetDbOrTblNameCStr(yyDollar[3].cstrUnion().Origin()) yyLOCAL = tree.NewUnresolvedName(dbNameCStr, tblNameCStr, yyDollar[5].cstrUnion()) } yyVAL.union = yyLOCAL - case 1424: + case 1425: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.CStr -//line mysql_sql.y:9388 +//line mysql_sql.y:9396 { yyLOCAL = tree.NewCStr(yyDollar[1].str, 1) } yyVAL.union = yyLOCAL - case 1425: + case 1426: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.CStr -//line mysql_sql.y:9392 +//line mysql_sql.y:9400 { yyLOCAL = tree.NewCStr(yyDollar[1].str, 1) } yyVAL.union = yyLOCAL - case 1426: + case 1427: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.CStr -//line mysql_sql.y:9396 +//line mysql_sql.y:9404 { yyLOCAL = tree.NewCStr(yyDollar[1].str, 1) } yyVAL.union = yyLOCAL - case 1427: + case 1428: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.CStr -//line mysql_sql.y:9400 +//line mysql_sql.y:9408 { yyLOCAL = tree.NewCStr(yyDollar[1].str, 1) } yyVAL.union = yyLOCAL - case 1428: + case 1429: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.CStr -//line mysql_sql.y:9406 +//line mysql_sql.y:9414 { yyLOCAL = yylex.(*Lexer).GetDbOrTblNameCStr(yyDollar[1].cstrUnion().Origin()) } yyVAL.union = yyLOCAL - case 1429: + case 1430: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.UnresolvedName -//line mysql_sql.y:9412 +//line mysql_sql.y:9420 { yyLOCAL = tree.NewUnresolvedName(yyDollar[1].cstrUnion()) } yyVAL.union = yyLOCAL - case 1430: + case 1431: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.UnresolvedName -//line mysql_sql.y:9416 +//line mysql_sql.y:9424 { tblNameCStr := yylex.(*Lexer).GetDbOrTblNameCStr(yyDollar[1].cstrUnion().Origin()) yyLOCAL = tree.NewUnresolvedName(tblNameCStr, yyDollar[3].cstrUnion()) } yyVAL.union = yyLOCAL - case 1431: + case 1432: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.UnresolvedName -//line mysql_sql.y:9421 +//line mysql_sql.y:9429 { dbNameCStr := yylex.(*Lexer).GetDbOrTblNameCStr(yyDollar[1].cstrUnion().Origin()) tblNameCStr := yylex.(*Lexer).GetDbOrTblNameCStr(yyDollar[3].cstrUnion().Origin()) yyLOCAL = tree.NewUnresolvedName(dbNameCStr, tblNameCStr, yyDollar[5].cstrUnion()) } yyVAL.union = yyLOCAL - case 1432: + case 1433: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL []tree.ColumnAttribute -//line mysql_sql.y:9428 +//line mysql_sql.y:9436 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1433: + case 1434: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []tree.ColumnAttribute -//line mysql_sql.y:9432 +//line mysql_sql.y:9440 { yyLOCAL = yyDollar[1].columnAttributesUnion() } yyVAL.union = yyLOCAL - case 1434: + case 1435: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []tree.ColumnAttribute -//line mysql_sql.y:9438 +//line mysql_sql.y:9446 { yyLOCAL = []tree.ColumnAttribute{yyDollar[1].columnAttributeUnion()} } yyVAL.union = yyLOCAL - case 1435: + case 1436: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL []tree.ColumnAttribute -//line mysql_sql.y:9442 +//line mysql_sql.y:9450 { yyLOCAL = append(yyDollar[1].columnAttributesUnion(), yyDollar[2].columnAttributeUnion()) } yyVAL.union = yyLOCAL - case 1436: + case 1437: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9448 +//line mysql_sql.y:9456 { yyLOCAL = tree.NewAttributeNull(true) } yyVAL.union = yyLOCAL - case 1437: + case 1438: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9452 +//line mysql_sql.y:9460 { yyLOCAL = tree.NewAttributeNull(false) } yyVAL.union = yyLOCAL - case 1438: + case 1439: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9456 +//line mysql_sql.y:9464 { yyLOCAL = tree.NewAttributeDefault(yyDollar[2].exprUnion()) } yyVAL.union = yyLOCAL - case 1439: + case 1440: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9460 +//line mysql_sql.y:9468 { yyLOCAL = tree.NewAttributeAutoIncrement() } yyVAL.union = yyLOCAL - case 1440: + case 1441: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9464 +//line mysql_sql.y:9472 { yyLOCAL = yyDollar[1].columnAttributeUnion() } yyVAL.union = yyLOCAL - case 1441: + case 1442: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9468 +//line mysql_sql.y:9476 { str := util.DealCommentString(yyDollar[2].str) yyLOCAL = tree.NewAttributeComment(tree.NewNumVal(str, str, false, tree.P_char)) } yyVAL.union = yyLOCAL - case 1442: + case 1443: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9473 +//line mysql_sql.y:9481 { yyLOCAL = tree.NewAttributeCollate(yyDollar[2].str) } yyVAL.union = yyLOCAL - case 1443: + case 1444: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9477 +//line mysql_sql.y:9485 { yyLOCAL = tree.NewAttributeColumnFormat(yyDollar[2].str) } yyVAL.union = yyLOCAL - case 1444: + case 1445: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9481 +//line mysql_sql.y:9489 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1445: + case 1446: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9485 +//line mysql_sql.y:9493 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1446: + case 1447: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9489 +//line mysql_sql.y:9497 { yyLOCAL = tree.NewAttributeStorage(yyDollar[2].str) } yyVAL.union = yyLOCAL - case 1447: + case 1448: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9493 +//line mysql_sql.y:9501 { yyLOCAL = tree.NewAttributeAutoRandom(int(yyDollar[2].int64ValUnion())) } yyVAL.union = yyLOCAL - case 1448: + case 1449: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9497 +//line mysql_sql.y:9505 { yyLOCAL = yyDollar[1].attributeReferenceUnion() } yyVAL.union = yyLOCAL - case 1449: + case 1450: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9501 +//line mysql_sql.y:9509 { yyLOCAL = tree.NewAttributeCheckConstraint(yyDollar[4].exprUnion(), false, yyDollar[1].str) } yyVAL.union = yyLOCAL - case 1450: + case 1451: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9505 +//line mysql_sql.y:9513 { yyLOCAL = tree.NewAttributeCheckConstraint(yyDollar[4].exprUnion(), yyDollar[6].boolValUnion(), yyDollar[1].str) } yyVAL.union = yyLOCAL - case 1451: + case 1452: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9509 +//line mysql_sql.y:9517 { name := tree.NewUnresolvedColName(yyDollar[3].str) var es tree.Exprs = nil @@ -22527,98 +22567,98 @@ yydefault: yyLOCAL = tree.NewAttributeOnUpdate(expr) } yyVAL.union = yyLOCAL - case 1452: + case 1453: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9523 +//line mysql_sql.y:9531 { yyLOCAL = tree.NewAttributeLowCardinality() } yyVAL.union = yyLOCAL - case 1453: + case 1454: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9527 +//line mysql_sql.y:9535 { yyLOCAL = tree.NewAttributeVisable(true) } yyVAL.union = yyLOCAL - case 1454: + case 1455: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9531 +//line mysql_sql.y:9539 { yyLOCAL = tree.NewAttributeVisable(false) } yyVAL.union = yyLOCAL - case 1455: + case 1456: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9535 +//line mysql_sql.y:9543 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1456: + case 1457: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9539 +//line mysql_sql.y:9547 { yyLOCAL = tree.NewAttributeHeader(yyDollar[3].str) } yyVAL.union = yyLOCAL - case 1457: + case 1458: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:9543 +//line mysql_sql.y:9551 { yyLOCAL = tree.NewAttributeHeaders() } yyVAL.union = yyLOCAL - case 1458: + case 1459: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:9549 +//line mysql_sql.y:9557 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1459: + case 1460: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:9553 +//line mysql_sql.y:9561 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1460: + case 1461: yyDollar = yyS[yypt-0 : yypt+1] -//line mysql_sql.y:9558 +//line mysql_sql.y:9566 { yyVAL.str = "" } - case 1461: + case 1462: yyDollar = yyS[yypt-1 : yypt+1] -//line mysql_sql.y:9562 +//line mysql_sql.y:9570 { yyVAL.str = yyDollar[1].str } - case 1462: + case 1463: yyDollar = yyS[yypt-1 : yypt+1] -//line mysql_sql.y:9568 +//line mysql_sql.y:9576 { yyVAL.str = "" } - case 1463: + case 1464: yyDollar = yyS[yypt-2 : yypt+1] -//line mysql_sql.y:9572 +//line mysql_sql.y:9580 { yyVAL.str = yyDollar[2].cstrUnion().Compare() } - case 1464: + case 1465: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.AttributeReference -//line mysql_sql.y:9578 +//line mysql_sql.y:9586 { var TableName = yyDollar[2].tableNameUnion() var KeyParts = yyDollar[3].keyPartsUnion() @@ -22634,10 +22674,10 @@ yydefault: ) } yyVAL.union = yyLOCAL - case 1465: + case 1466: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.ReferenceOnRecord -//line mysql_sql.y:9595 +//line mysql_sql.y:9603 { yyLOCAL = &tree.ReferenceOnRecord{ OnDelete: tree.REFERENCE_OPTION_INVALID, @@ -22645,10 +22685,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1466: + case 1467: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.ReferenceOnRecord -//line mysql_sql.y:9602 +//line mysql_sql.y:9610 { yyLOCAL = &tree.ReferenceOnRecord{ OnDelete: yyDollar[1].referenceOptionTypeUnion(), @@ -22656,10 +22696,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1467: + case 1468: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.ReferenceOnRecord -//line mysql_sql.y:9609 +//line mysql_sql.y:9617 { yyLOCAL = &tree.ReferenceOnRecord{ OnDelete: tree.REFERENCE_OPTION_INVALID, @@ -22667,10 +22707,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1468: + case 1469: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.ReferenceOnRecord -//line mysql_sql.y:9616 +//line mysql_sql.y:9624 { yyLOCAL = &tree.ReferenceOnRecord{ OnDelete: yyDollar[1].referenceOptionTypeUnion(), @@ -22678,10 +22718,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1469: + case 1470: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.ReferenceOnRecord -//line mysql_sql.y:9623 +//line mysql_sql.y:9631 { yyLOCAL = &tree.ReferenceOnRecord{ OnDelete: yyDollar[2].referenceOptionTypeUnion(), @@ -22689,354 +22729,354 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1470: + case 1471: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.ReferenceOptionType -//line mysql_sql.y:9632 +//line mysql_sql.y:9640 { yyLOCAL = yyDollar[3].referenceOptionTypeUnion() } yyVAL.union = yyLOCAL - case 1471: + case 1472: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.ReferenceOptionType -//line mysql_sql.y:9638 +//line mysql_sql.y:9646 { yyLOCAL = yyDollar[3].referenceOptionTypeUnion() } yyVAL.union = yyLOCAL - case 1472: + case 1473: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ReferenceOptionType -//line mysql_sql.y:9644 +//line mysql_sql.y:9652 { yyLOCAL = tree.REFERENCE_OPTION_RESTRICT } yyVAL.union = yyLOCAL - case 1473: + case 1474: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ReferenceOptionType -//line mysql_sql.y:9648 +//line mysql_sql.y:9656 { yyLOCAL = tree.REFERENCE_OPTION_CASCADE } yyVAL.union = yyLOCAL - case 1474: + case 1475: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ReferenceOptionType -//line mysql_sql.y:9652 +//line mysql_sql.y:9660 { yyLOCAL = tree.REFERENCE_OPTION_SET_NULL } yyVAL.union = yyLOCAL - case 1475: + case 1476: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ReferenceOptionType -//line mysql_sql.y:9656 +//line mysql_sql.y:9664 { yyLOCAL = tree.REFERENCE_OPTION_NO_ACTION } yyVAL.union = yyLOCAL - case 1476: + case 1477: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ReferenceOptionType -//line mysql_sql.y:9660 +//line mysql_sql.y:9668 { yyLOCAL = tree.REFERENCE_OPTION_SET_DEFAULT } yyVAL.union = yyLOCAL - case 1477: + case 1478: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.MatchType -//line mysql_sql.y:9665 +//line mysql_sql.y:9673 { yyLOCAL = tree.MATCH_INVALID } yyVAL.union = yyLOCAL - case 1479: + case 1480: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.MatchType -//line mysql_sql.y:9672 +//line mysql_sql.y:9680 { yyLOCAL = tree.MATCH_FULL } yyVAL.union = yyLOCAL - case 1480: + case 1481: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.MatchType -//line mysql_sql.y:9676 +//line mysql_sql.y:9684 { yyLOCAL = tree.MATCH_PARTIAL } yyVAL.union = yyLOCAL - case 1481: + case 1482: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.MatchType -//line mysql_sql.y:9680 +//line mysql_sql.y:9688 { yyLOCAL = tree.MATCH_SIMPLE } yyVAL.union = yyLOCAL - case 1482: + case 1483: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.FullTextSearchType -//line mysql_sql.y:9685 +//line mysql_sql.y:9693 { yyLOCAL = tree.FULLTEXT_DEFAULT } yyVAL.union = yyLOCAL - case 1483: + case 1484: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.FullTextSearchType -//line mysql_sql.y:9689 +//line mysql_sql.y:9697 { yyLOCAL = tree.FULLTEXT_NL } yyVAL.union = yyLOCAL - case 1484: + case 1485: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.FullTextSearchType -//line mysql_sql.y:9693 +//line mysql_sql.y:9701 { yyLOCAL = tree.FULLTEXT_NL_QUERY_EXPANSION } yyVAL.union = yyLOCAL - case 1485: + case 1486: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.FullTextSearchType -//line mysql_sql.y:9697 +//line mysql_sql.y:9705 { yyLOCAL = tree.FULLTEXT_BOOLEAN } yyVAL.union = yyLOCAL - case 1486: + case 1487: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.FullTextSearchType -//line mysql_sql.y:9701 +//line mysql_sql.y:9709 { yyLOCAL = tree.FULLTEXT_QUERY_EXPANSION } yyVAL.union = yyLOCAL - case 1487: + case 1488: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL []*tree.KeyPart -//line mysql_sql.y:9706 +//line mysql_sql.y:9714 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1488: + case 1489: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []*tree.KeyPart -//line mysql_sql.y:9710 +//line mysql_sql.y:9718 { yyLOCAL = yyDollar[2].keyPartsUnion() } yyVAL.union = yyLOCAL - case 1489: + case 1490: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL int64 -//line mysql_sql.y:9715 +//line mysql_sql.y:9723 { yyLOCAL = -1 } yyVAL.union = yyLOCAL - case 1490: + case 1491: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL int64 -//line mysql_sql.y:9719 +//line mysql_sql.y:9727 { yyLOCAL = yyDollar[2].item.(int64) } yyVAL.union = yyLOCAL - case 1497: + case 1498: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.Subquery -//line mysql_sql.y:9735 +//line mysql_sql.y:9743 { yyLOCAL = &tree.Subquery{Select: yyDollar[1].selectStatementUnion(), Exists: false} } yyVAL.union = yyLOCAL - case 1498: + case 1499: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9741 +//line mysql_sql.y:9749 { yyLOCAL = tree.NewBinaryExpr(tree.BIT_AND, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1499: + case 1500: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9745 +//line mysql_sql.y:9753 { yyLOCAL = tree.NewBinaryExpr(tree.BIT_OR, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1500: + case 1501: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9749 +//line mysql_sql.y:9757 { yyLOCAL = tree.NewBinaryExpr(tree.BIT_XOR, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1501: + case 1502: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9753 +//line mysql_sql.y:9761 { yyLOCAL = tree.NewBinaryExpr(tree.PLUS, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1502: + case 1503: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9757 +//line mysql_sql.y:9765 { yyLOCAL = tree.NewBinaryExpr(tree.MINUS, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1503: + case 1504: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9761 +//line mysql_sql.y:9769 { yyLOCAL = tree.NewBinaryExpr(tree.MULTI, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1504: + case 1505: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9765 +//line mysql_sql.y:9773 { yyLOCAL = tree.NewBinaryExpr(tree.DIV, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1505: + case 1506: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9769 +//line mysql_sql.y:9777 { yyLOCAL = tree.NewBinaryExpr(tree.INTEGER_DIV, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1506: + case 1507: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9773 +//line mysql_sql.y:9781 { yyLOCAL = tree.NewBinaryExpr(tree.MOD, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1507: + case 1508: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9777 +//line mysql_sql.y:9785 { yyLOCAL = tree.NewBinaryExpr(tree.MOD, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1508: + case 1509: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9781 +//line mysql_sql.y:9789 { yyLOCAL = tree.NewBinaryExpr(tree.LEFT_SHIFT, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1509: + case 1510: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9785 +//line mysql_sql.y:9793 { yyLOCAL = tree.NewBinaryExpr(tree.RIGHT_SHIFT, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1510: + case 1511: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9789 +//line mysql_sql.y:9797 { yyLOCAL = yyDollar[1].exprUnion() } yyVAL.union = yyLOCAL - case 1511: + case 1512: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9795 +//line mysql_sql.y:9803 { yyLOCAL = yyDollar[1].unresolvedNameUnion() } yyVAL.union = yyLOCAL - case 1512: + case 1513: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9799 +//line mysql_sql.y:9807 { yyLOCAL = yyDollar[1].varExprUnion() } yyVAL.union = yyLOCAL - case 1513: + case 1514: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9803 +//line mysql_sql.y:9811 { yyLOCAL = yyDollar[1].exprUnion() } yyVAL.union = yyLOCAL - case 1514: + case 1515: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9807 +//line mysql_sql.y:9815 { yyLOCAL = tree.NewParentExpr(yyDollar[2].exprUnion()) } yyVAL.union = yyLOCAL - case 1515: + case 1516: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9811 +//line mysql_sql.y:9819 { yyLOCAL = tree.NewTuple(append(yyDollar[2].exprsUnion(), yyDollar[4].exprUnion())) } yyVAL.union = yyLOCAL - case 1516: + case 1517: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9815 +//line mysql_sql.y:9823 { yyLOCAL = tree.NewUnaryExpr(tree.UNARY_PLUS, yyDollar[2].exprUnion()) } yyVAL.union = yyLOCAL - case 1517: + case 1518: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9819 +//line mysql_sql.y:9827 { yyLOCAL = tree.NewUnaryExpr(tree.UNARY_MINUS, yyDollar[2].exprUnion()) } yyVAL.union = yyLOCAL - case 1518: + case 1519: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9823 +//line mysql_sql.y:9831 { yyLOCAL = tree.NewUnaryExpr(tree.UNARY_TILDE, yyDollar[2].exprUnion()) } yyVAL.union = yyLOCAL - case 1519: + case 1520: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9827 +//line mysql_sql.y:9835 { yyLOCAL = tree.NewUnaryExpr(tree.UNARY_MARK, yyDollar[2].exprUnion()) } yyVAL.union = yyLOCAL - case 1520: + case 1521: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9831 +//line mysql_sql.y:9839 { hint := strings.ToLower(yyDollar[2].cstrUnion().Compare()) switch hint { @@ -23079,35 +23119,35 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1521: + case 1522: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9873 +//line mysql_sql.y:9881 { yyLOCAL = yyDollar[1].exprUnion() } yyVAL.union = yyLOCAL - case 1522: + case 1523: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9877 +//line mysql_sql.y:9885 { yyLOCAL = yyDollar[1].subqueryUnion() } yyVAL.union = yyLOCAL - case 1523: + case 1524: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9881 +//line mysql_sql.y:9889 { yyDollar[2].subqueryUnion().Exists = true yyLOCAL = yyDollar[2].subqueryUnion() } yyVAL.union = yyLOCAL - case 1524: + case 1525: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9886 +//line mysql_sql.y:9894 { yyLOCAL = &tree.CaseExpr{ Expr: yyDollar[2].exprUnion(), @@ -23116,42 +23156,42 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1525: + case 1526: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9894 +//line mysql_sql.y:9902 { yyLOCAL = tree.NewCastExpr(yyDollar[3].exprUnion(), yyDollar[5].columnTypeUnion()) } yyVAL.union = yyLOCAL - case 1526: + case 1527: yyDollar = yyS[yypt-8 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9898 +//line mysql_sql.y:9906 { yyLOCAL = tree.NewSerialExtractExpr(yyDollar[3].exprUnion(), yyDollar[5].exprUnion(), yyDollar[7].columnTypeUnion()) } yyVAL.union = yyLOCAL - case 1527: + case 1528: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9902 +//line mysql_sql.y:9910 { yyLOCAL = tree.NewBitCastExpr(yyDollar[3].exprUnion(), yyDollar[5].columnTypeUnion()) } yyVAL.union = yyLOCAL - case 1528: + case 1529: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9906 +//line mysql_sql.y:9914 { yyLOCAL = tree.NewCastExpr(yyDollar[3].exprUnion(), yyDollar[5].columnTypeUnion()) } yyVAL.union = yyLOCAL - case 1529: + case 1530: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9910 +//line mysql_sql.y:9918 { name := tree.NewUnresolvedColName(yyDollar[1].str) es := tree.NewNumVal(yyDollar[5].str, yyDollar[5].str, false, tree.P_char) @@ -23162,66 +23202,66 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1530: + case 1531: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9920 +//line mysql_sql.y:9928 { yyLOCAL = yyDollar[1].funcExprUnion() } yyVAL.union = yyLOCAL - case 1531: + case 1532: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9924 +//line mysql_sql.y:9932 { yyLOCAL = yyDollar[1].funcExprUnion() } yyVAL.union = yyLOCAL - case 1532: + case 1533: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9928 +//line mysql_sql.y:9936 { yyLOCAL = yyDollar[1].funcExprUnion() } yyVAL.union = yyLOCAL - case 1533: + case 1534: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9932 +//line mysql_sql.y:9940 { yyLOCAL = yyDollar[1].funcExprUnion() } yyVAL.union = yyLOCAL - case 1534: + case 1535: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9936 +//line mysql_sql.y:9944 { yyLOCAL = yyDollar[1].funcExprUnion() } yyVAL.union = yyLOCAL - case 1535: + case 1536: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9940 +//line mysql_sql.y:9948 { yyLOCAL = yyDollar[1].exprUnion() } yyVAL.union = yyLOCAL - case 1536: + case 1537: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9944 +//line mysql_sql.y:9952 { yyLOCAL = yyDollar[1].exprUnion() } yyVAL.union = yyLOCAL - case 1537: + case 1538: yyDollar = yyS[yypt-9 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9948 +//line mysql_sql.y:9956 { val, err := tree.NewFullTextMatchFuncExpression(yyDollar[3].keyPartsUnion(), yyDollar[7].str, yyDollar[8].fullTextSearchTypeUnion()) if err != nil { @@ -23231,16 +23271,16 @@ yydefault: yyLOCAL = val } yyVAL.union = yyLOCAL - case 1538: + case 1539: yyDollar = yyS[yypt-1 : yypt+1] -//line mysql_sql.y:9961 +//line mysql_sql.y:9969 { yyVAL.str = yyDollar[1].str } - case 1539: + case 1540: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:9967 +//line mysql_sql.y:9975 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -23250,10 +23290,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1540: + case 1541: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:9976 +//line mysql_sql.y:9984 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -23263,10 +23303,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1541: + case 1542: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:9985 +//line mysql_sql.y:9993 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -23276,10 +23316,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1542: + case 1543: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:9996 +//line mysql_sql.y:10004 { v := int(yyDollar[5].item.(int64)) val, err := tree.NewSampleRowsFuncExpression(v, true, nil, "block") @@ -23290,10 +23330,10 @@ yydefault: yyLOCAL = val } yyVAL.union = yyLOCAL - case 1543: + case 1544: yyDollar = yyS[yypt-9 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:10006 +//line mysql_sql.y:10014 { v := int(yyDollar[5].item.(int64)) val, err := tree.NewSampleRowsFuncExpression(v, true, nil, yyDollar[8].str) @@ -23304,10 +23344,10 @@ yydefault: yyLOCAL = val } yyVAL.union = yyLOCAL - case 1544: + case 1545: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:10016 +//line mysql_sql.y:10024 { val, err := tree.NewSamplePercentFuncExpression1(yyDollar[5].item.(int64), true, nil) if err != nil { @@ -23317,10 +23357,10 @@ yydefault: yyLOCAL = val } yyVAL.union = yyLOCAL - case 1545: + case 1546: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:10025 +//line mysql_sql.y:10033 { val, err := tree.NewSamplePercentFuncExpression2(yyDollar[5].item.(float64), true, nil) if err != nil { @@ -23330,10 +23370,10 @@ yydefault: yyLOCAL = val } yyVAL.union = yyLOCAL - case 1546: + case 1547: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:10035 +//line mysql_sql.y:10043 { v := int(yyDollar[5].item.(int64)) val, err := tree.NewSampleRowsFuncExpression(v, false, yyDollar[3].exprsUnion(), "block") @@ -23344,10 +23384,10 @@ yydefault: yyLOCAL = val } yyVAL.union = yyLOCAL - case 1547: + case 1548: yyDollar = yyS[yypt-9 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:10045 +//line mysql_sql.y:10053 { v := int(yyDollar[5].item.(int64)) val, err := tree.NewSampleRowsFuncExpression(v, false, yyDollar[3].exprsUnion(), yyDollar[8].str) @@ -23358,10 +23398,10 @@ yydefault: yyLOCAL = val } yyVAL.union = yyLOCAL - case 1548: + case 1549: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:10055 +//line mysql_sql.y:10063 { val, err := tree.NewSamplePercentFuncExpression1(yyDollar[5].item.(int64), false, yyDollar[3].exprsUnion()) if err != nil { @@ -23371,10 +23411,10 @@ yydefault: yyLOCAL = val } yyVAL.union = yyLOCAL - case 1549: + case 1550: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:10064 +//line mysql_sql.y:10072 { val, err := tree.NewSamplePercentFuncExpression2(yyDollar[5].item.(float64), false, yyDollar[3].exprsUnion()) if err != nil { @@ -23384,58 +23424,58 @@ yydefault: yyLOCAL = val } yyVAL.union = yyLOCAL - case 1550: + case 1551: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:10074 +//line mysql_sql.y:10082 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1551: + case 1552: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:10078 +//line mysql_sql.y:10086 { yyLOCAL = yyDollar[2].exprUnion() } yyVAL.union = yyLOCAL - case 1552: + case 1553: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:10083 +//line mysql_sql.y:10091 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1553: + case 1554: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:10087 +//line mysql_sql.y:10095 { yyLOCAL = yyDollar[1].exprUnion() } yyVAL.union = yyLOCAL - case 1554: + case 1555: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []*tree.When -//line mysql_sql.y:10093 +//line mysql_sql.y:10101 { yyLOCAL = []*tree.When{yyDollar[1].whenClauseUnion()} } yyVAL.union = yyLOCAL - case 1555: + case 1556: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL []*tree.When -//line mysql_sql.y:10097 +//line mysql_sql.y:10105 { yyLOCAL = append(yyDollar[1].whenClauseListUnion(), yyDollar[2].whenClauseUnion()) } yyVAL.union = yyLOCAL - case 1556: + case 1557: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.When -//line mysql_sql.y:10103 +//line mysql_sql.y:10111 { yyLOCAL = &tree.When{ Cond: yyDollar[2].exprUnion(), @@ -23443,9 +23483,9 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1557: + case 1558: yyDollar = yyS[yypt-1 : yypt+1] -//line mysql_sql.y:10112 +//line mysql_sql.y:10120 { t := yyVAL.columnTypeUnion() str := strings.ToLower(t.InternalType.FamilyString) @@ -23458,10 +23498,10 @@ yydefault: } } } - case 1558: + case 1559: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:10124 +//line mysql_sql.y:10132 { name := yyDollar[1].str if yyDollar[2].str != "" { @@ -23479,10 +23519,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1559: + case 1560: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:10141 +//line mysql_sql.y:10149 { locale := "" yyLOCAL = &tree.T{ @@ -23497,10 +23537,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1561: + case 1562: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:10158 +//line mysql_sql.y:10166 { locale := "" yyLOCAL = &tree.T{ @@ -23514,10 +23554,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1562: + case 1563: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:10171 +//line mysql_sql.y:10179 { locale := "" yyLOCAL = &tree.T{ @@ -23531,10 +23571,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1563: + case 1564: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:10184 +//line mysql_sql.y:10192 { locale := "" yyLOCAL = &tree.T{ @@ -23547,10 +23587,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1564: + case 1565: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:10196 +//line mysql_sql.y:10204 { locale := "" yyLOCAL = &tree.T{ @@ -23565,10 +23605,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1565: + case 1566: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:10210 +//line mysql_sql.y:10218 { locale := "" yyLOCAL = &tree.T{ @@ -23584,10 +23624,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1566: + case 1567: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:10225 +//line mysql_sql.y:10233 { locale := "" yyLOCAL = &tree.T{ @@ -23603,10 +23643,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1567: + case 1568: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:10240 +//line mysql_sql.y:10248 { name := yyDollar[1].str if yyDollar[2].str != "" { @@ -23624,10 +23664,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1568: + case 1569: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:10257 +//line mysql_sql.y:10265 { locale := "" yyLOCAL = &tree.T{ @@ -23642,95 +23682,95 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1569: + case 1570: yyDollar = yyS[yypt-0 : yypt+1] -//line mysql_sql.y:10272 +//line mysql_sql.y:10280 { } - case 1573: + case 1574: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FrameBound -//line mysql_sql.y:10279 +//line mysql_sql.y:10287 { yyLOCAL = &tree.FrameBound{Type: tree.Following, UnBounded: true} } yyVAL.union = yyLOCAL - case 1574: + case 1575: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FrameBound -//line mysql_sql.y:10283 +//line mysql_sql.y:10291 { yyLOCAL = &tree.FrameBound{Type: tree.Following, Expr: yyDollar[1].exprUnion()} } yyVAL.union = yyLOCAL - case 1575: + case 1576: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FrameBound -//line mysql_sql.y:10287 +//line mysql_sql.y:10295 { yyLOCAL = &tree.FrameBound{Type: tree.Following, Expr: yyDollar[1].exprUnion()} } yyVAL.union = yyLOCAL - case 1576: + case 1577: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FrameBound -//line mysql_sql.y:10293 +//line mysql_sql.y:10301 { yyLOCAL = &tree.FrameBound{Type: tree.CurrentRow} } yyVAL.union = yyLOCAL - case 1577: + case 1578: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FrameBound -//line mysql_sql.y:10297 +//line mysql_sql.y:10305 { yyLOCAL = &tree.FrameBound{Type: tree.Preceding, UnBounded: true} } yyVAL.union = yyLOCAL - case 1578: + case 1579: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FrameBound -//line mysql_sql.y:10301 +//line mysql_sql.y:10309 { yyLOCAL = &tree.FrameBound{Type: tree.Preceding, Expr: yyDollar[1].exprUnion()} } yyVAL.union = yyLOCAL - case 1579: + case 1580: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FrameBound -//line mysql_sql.y:10305 +//line mysql_sql.y:10313 { yyLOCAL = &tree.FrameBound{Type: tree.Preceding, Expr: yyDollar[1].exprUnion()} } yyVAL.union = yyLOCAL - case 1580: + case 1581: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.FrameType -//line mysql_sql.y:10311 +//line mysql_sql.y:10319 { yyLOCAL = tree.Rows } yyVAL.union = yyLOCAL - case 1581: + case 1582: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.FrameType -//line mysql_sql.y:10315 +//line mysql_sql.y:10323 { yyLOCAL = tree.Range } yyVAL.union = yyLOCAL - case 1582: + case 1583: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.FrameType -//line mysql_sql.y:10319 +//line mysql_sql.y:10327 { yyLOCAL = tree.Groups } yyVAL.union = yyLOCAL - case 1583: + case 1584: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FrameClause -//line mysql_sql.y:10325 +//line mysql_sql.y:10333 { yyLOCAL = &tree.FrameClause{ Type: yyDollar[1].frameTypeUnion(), @@ -23739,10 +23779,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1584: + case 1585: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.FrameClause -//line mysql_sql.y:10333 +//line mysql_sql.y:10341 { yyLOCAL = &tree.FrameClause{ Type: yyDollar[1].frameTypeUnion(), @@ -23752,82 +23792,82 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1585: + case 1586: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.FrameClause -//line mysql_sql.y:10343 +//line mysql_sql.y:10351 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1586: + case 1587: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.FrameClause -//line mysql_sql.y:10347 +//line mysql_sql.y:10355 { yyLOCAL = yyDollar[1].frameClauseUnion() } yyVAL.union = yyLOCAL - case 1587: + case 1588: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Exprs -//line mysql_sql.y:10354 +//line mysql_sql.y:10362 { yyLOCAL = yyDollar[3].exprsUnion() } yyVAL.union = yyLOCAL - case 1588: + case 1589: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.Exprs -//line mysql_sql.y:10359 +//line mysql_sql.y:10367 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1589: + case 1590: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Exprs -//line mysql_sql.y:10363 +//line mysql_sql.y:10371 { yyLOCAL = yyDollar[1].exprsUnion() } yyVAL.union = yyLOCAL - case 1590: + case 1591: yyDollar = yyS[yypt-0 : yypt+1] -//line mysql_sql.y:10368 +//line mysql_sql.y:10376 { yyVAL.str = "," } - case 1591: + case 1592: yyDollar = yyS[yypt-2 : yypt+1] -//line mysql_sql.y:10372 +//line mysql_sql.y:10380 { yyVAL.str = yyDollar[2].str } - case 1592: + case 1593: yyDollar = yyS[yypt-0 : yypt+1] -//line mysql_sql.y:10377 +//line mysql_sql.y:10385 { yyVAL.str = "1,vector_l2_ops,random,false" } - case 1593: + case 1594: yyDollar = yyS[yypt-2 : yypt+1] -//line mysql_sql.y:10381 +//line mysql_sql.y:10389 { yyVAL.str = yyDollar[2].str } - case 1594: + case 1595: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL *tree.WindowSpec -//line mysql_sql.y:10386 +//line mysql_sql.y:10394 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1596: + case 1597: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.WindowSpec -//line mysql_sql.y:10393 +//line mysql_sql.y:10401 { hasFrame := true var f *tree.FrameClause @@ -23852,10 +23892,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1597: + case 1598: yyDollar = yyS[yypt-8 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10419 +//line mysql_sql.y:10427 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -23868,10 +23908,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1598: + case 1599: yyDollar = yyS[yypt-8 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10431 +//line mysql_sql.y:10439 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -23884,10 +23924,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1599: + case 1600: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10443 +//line mysql_sql.y:10451 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -23899,10 +23939,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1600: + case 1601: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10454 +//line mysql_sql.y:10462 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -23914,10 +23954,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1601: + case 1602: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10465 +//line mysql_sql.y:10473 { name := tree.NewUnresolvedColName(yyDollar[1].str) es := tree.NewNumVal("*", "*", false, tree.P_char) @@ -23929,10 +23969,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1602: + case 1603: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10476 +//line mysql_sql.y:10484 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -23943,10 +23983,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1603: + case 1604: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10486 +//line mysql_sql.y:10494 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -23957,10 +23997,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1604: + case 1605: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10496 +//line mysql_sql.y:10504 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -23972,10 +24012,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1605: + case 1606: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10507 +//line mysql_sql.y:10515 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -23987,10 +24027,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1606: + case 1607: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10518 +//line mysql_sql.y:10526 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24002,10 +24042,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1607: + case 1608: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10529 +//line mysql_sql.y:10537 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24017,10 +24057,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1608: + case 1609: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10540 +//line mysql_sql.y:10548 { name := tree.NewUnresolvedColName(yyDollar[1].str) es := tree.NewNumVal("*", "*", false, tree.P_char) @@ -24032,10 +24072,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1609: + case 1610: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10551 +//line mysql_sql.y:10559 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24047,10 +24087,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1610: + case 1611: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10562 +//line mysql_sql.y:10570 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24062,10 +24102,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1611: + case 1612: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10573 +//line mysql_sql.y:10581 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24077,10 +24117,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1612: + case 1613: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10584 +//line mysql_sql.y:10592 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24092,10 +24132,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1613: + case 1614: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10595 +//line mysql_sql.y:10603 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24107,10 +24147,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1614: + case 1615: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10606 +//line mysql_sql.y:10614 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24122,10 +24162,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1615: + case 1616: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10617 +//line mysql_sql.y:10625 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24137,10 +24177,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1616: + case 1617: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10628 +//line mysql_sql.y:10636 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24152,10 +24192,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1617: + case 1618: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10639 +//line mysql_sql.y:10647 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24167,10 +24207,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1618: + case 1619: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10650 +//line mysql_sql.y:10658 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24182,10 +24222,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1619: + case 1620: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10661 +//line mysql_sql.y:10669 { name := tree.NewUnresolvedColName(yyDollar[1].str) var columnList tree.Exprs @@ -24203,10 +24243,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1623: + case 1624: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10685 +//line mysql_sql.y:10693 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24216,10 +24256,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1624: + case 1625: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10694 +//line mysql_sql.y:10702 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24229,10 +24269,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1625: + case 1626: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10703 +//line mysql_sql.y:10711 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24242,10 +24282,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1626: + case 1627: yyDollar = yyS[yypt-8 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10712 +//line mysql_sql.y:10720 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24255,10 +24295,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1627: + case 1628: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10721 +//line mysql_sql.y:10729 { name := tree.NewUnresolvedColName(yyDollar[1].str) str := strings.ToLower(yyDollar[3].str) @@ -24270,10 +24310,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1628: + case 1629: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10732 +//line mysql_sql.y:10740 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24283,10 +24323,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1629: + case 1630: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10741 +//line mysql_sql.y:10749 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24297,10 +24337,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1630: + case 1631: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10751 +//line mysql_sql.y:10759 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24310,10 +24350,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1631: + case 1632: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10760 +//line mysql_sql.y:10768 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24323,10 +24363,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1632: + case 1633: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10769 +//line mysql_sql.y:10777 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24336,10 +24376,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1633: + case 1634: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10778 +//line mysql_sql.y:10786 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24349,10 +24389,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1634: + case 1635: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10787 +//line mysql_sql.y:10795 { name := tree.NewUnresolvedColName(yyDollar[1].str) arg0 := tree.NewNumVal(int64(0), "0", false, tree.P_int64) @@ -24365,10 +24405,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1635: + case 1636: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10799 +//line mysql_sql.y:10807 { name := tree.NewUnresolvedColName(yyDollar[1].str) arg0 := tree.NewNumVal(int64(1), "1", false, tree.P_int64) @@ -24380,10 +24420,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1636: + case 1637: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10810 +//line mysql_sql.y:10818 { name := tree.NewUnresolvedColName(yyDollar[1].str) arg0 := tree.NewNumVal(int64(2), "2", false, tree.P_int64) @@ -24397,10 +24437,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1637: + case 1638: yyDollar = yyS[yypt-7 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10823 +//line mysql_sql.y:10831 { name := tree.NewUnresolvedColName(yyDollar[1].str) arg0 := tree.NewNumVal(int64(3), "3", false, tree.P_int64) @@ -24413,10 +24453,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1638: + case 1639: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10835 +//line mysql_sql.y:10843 { column := tree.NewUnresolvedColName(yyDollar[3].str) name := tree.NewUnresolvedColName(yyDollar[1].str) @@ -24427,16 +24467,16 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1645: + case 1646: yyDollar = yyS[yypt-1 : yypt+1] -//line mysql_sql.y:10858 +//line mysql_sql.y:10866 { yyVAL.str = yyDollar[1].str } - case 1674: + case 1675: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10894 +//line mysql_sql.y:10902 { name := tree.NewUnresolvedColName(yyDollar[1].str) var es tree.Exprs = nil @@ -24450,10 +24490,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1675: + case 1676: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10907 +//line mysql_sql.y:10915 { name := tree.NewUnresolvedColName(yyDollar[1].str) var es tree.Exprs = nil @@ -24467,10 +24507,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1676: + case 1677: yyDollar = yyS[yypt-8 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10920 +//line mysql_sql.y:10928 { name := tree.NewUnresolvedColName(yyDollar[1].str) str := strings.ToLower(yyDollar[3].str) @@ -24482,10 +24522,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1677: + case 1678: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10932 +//line mysql_sql.y:10940 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24495,10 +24535,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1678: + case 1679: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10941 +//line mysql_sql.y:10949 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24507,10 +24547,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1679: + case 1680: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10949 +//line mysql_sql.y:10957 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24519,10 +24559,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1680: + case 1681: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10957 +//line mysql_sql.y:10965 { name := tree.NewUnresolvedColName(yyDollar[1].str) var es tree.Exprs = nil @@ -24536,10 +24576,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1681: + case 1682: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10970 +//line mysql_sql.y:10978 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24549,10 +24589,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1682: + case 1683: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10979 +//line mysql_sql.y:10987 { name := tree.NewUnresolvedColName(yyDollar[1].str) exprs := make([]tree.Expr, 1) @@ -24564,10 +24604,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1683: + case 1684: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:10990 +//line mysql_sql.y:10998 { name := tree.NewUnresolvedColName(yyDollar[1].str) exprs := make([]tree.Expr, 1) @@ -24579,10 +24619,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1684: + case 1685: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:11001 +//line mysql_sql.y:11009 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24592,10 +24632,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1685: + case 1686: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:11010 +//line mysql_sql.y:11018 { cn := tree.NewNumVal(yyDollar[5].str, yyDollar[5].str, false, tree.P_char) es := yyDollar[3].exprsUnion() @@ -24608,10 +24648,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1686: + case 1687: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:11022 +//line mysql_sql.y:11030 { val := tree.NewNumVal(yyDollar[2].str, yyDollar[2].str, false, tree.P_char) name := tree.NewUnresolvedColName(yyDollar[1].str) @@ -24622,10 +24662,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1687: + case 1688: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:11032 +//line mysql_sql.y:11040 { val := tree.NewNumVal(yyDollar[2].str, yyDollar[2].str, false, tree.P_char) name := tree.NewUnresolvedColName(yyDollar[1].str) @@ -24636,10 +24676,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1688: + case 1689: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:11042 +//line mysql_sql.y:11050 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24649,10 +24689,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1689: + case 1690: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:11051 +//line mysql_sql.y:11059 { es := tree.Exprs{yyDollar[3].exprUnion()} es = append(es, yyDollar[5].exprUnion()) @@ -24664,10 +24704,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1690: + case 1691: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:11062 +//line mysql_sql.y:11070 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24677,10 +24717,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1691: + case 1692: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:11071 +//line mysql_sql.y:11079 { val := tree.NewNumVal(yyDollar[2].str, yyDollar[2].str, false, tree.P_char) name := tree.NewUnresolvedColName(yyDollar[1].str) @@ -24691,10 +24731,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1692: + case 1693: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:11081 +//line mysql_sql.y:11089 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24704,10 +24744,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1693: + case 1694: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:11090 +//line mysql_sql.y:11098 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24717,10 +24757,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1694: + case 1695: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.FuncExpr -//line mysql_sql.y:11099 +//line mysql_sql.y:11107 { name := tree.NewUnresolvedColName(yyDollar[1].str) yyLOCAL = &tree.FuncExpr{ @@ -24730,34 +24770,34 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1695: + case 1696: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11109 +//line mysql_sql.y:11117 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1696: + case 1697: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11113 +//line mysql_sql.y:11121 { yyLOCAL = yyDollar[1].exprUnion() } yyVAL.union = yyLOCAL - case 1697: + case 1698: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11119 +//line mysql_sql.y:11127 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1698: + case 1699: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11123 +//line mysql_sql.y:11131 { ival, errStr := util.GetInt64(yyDollar[2].item) if errStr != "" { @@ -24768,20 +24808,20 @@ yydefault: yyLOCAL = tree.NewNumVal(ival, str, false, tree.P_int64) } yyVAL.union = yyLOCAL - case 1705: + case 1706: yyDollar = yyS[yypt-0 : yypt+1] -//line mysql_sql.y:11142 +//line mysql_sql.y:11150 { } - case 1706: + case 1707: yyDollar = yyS[yypt-2 : yypt+1] -//line mysql_sql.y:11144 +//line mysql_sql.y:11152 { } - case 1741: + case 1742: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11186 +//line mysql_sql.y:11194 { name := tree.NewUnresolvedColName(yyDollar[1].str) str := strings.ToLower(yyDollar[3].str) @@ -24793,106 +24833,106 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1742: + case 1743: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.FuncType -//line mysql_sql.y:11198 +//line mysql_sql.y:11206 { yyLOCAL = tree.FUNC_TYPE_DEFAULT } yyVAL.union = yyLOCAL - case 1743: + case 1744: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.FuncType -//line mysql_sql.y:11202 +//line mysql_sql.y:11210 { yyLOCAL = tree.FUNC_TYPE_DISTINCT } yyVAL.union = yyLOCAL - case 1744: + case 1745: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.FuncType -//line mysql_sql.y:11206 +//line mysql_sql.y:11214 { yyLOCAL = tree.FUNC_TYPE_ALL } yyVAL.union = yyLOCAL - case 1745: + case 1746: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.Tuple -//line mysql_sql.y:11212 +//line mysql_sql.y:11220 { yyLOCAL = tree.NewTuple(yyDollar[2].exprsUnion()) } yyVAL.union = yyLOCAL - case 1746: + case 1747: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.Exprs -//line mysql_sql.y:11217 +//line mysql_sql.y:11225 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1747: + case 1748: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Exprs -//line mysql_sql.y:11221 +//line mysql_sql.y:11229 { yyLOCAL = yyDollar[1].exprsUnion() } yyVAL.union = yyLOCAL - case 1748: + case 1749: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Exprs -//line mysql_sql.y:11227 +//line mysql_sql.y:11235 { yyLOCAL = tree.Exprs{yyDollar[1].exprUnion()} } yyVAL.union = yyLOCAL - case 1749: + case 1750: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Exprs -//line mysql_sql.y:11231 +//line mysql_sql.y:11239 { yyLOCAL = append(yyDollar[1].exprsUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1750: + case 1751: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Exprs -//line mysql_sql.y:11237 +//line mysql_sql.y:11245 { yyLOCAL = tree.Exprs{yyDollar[1].exprUnion()} } yyVAL.union = yyLOCAL - case 1751: + case 1752: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Exprs -//line mysql_sql.y:11241 +//line mysql_sql.y:11249 { yyLOCAL = append(yyDollar[1].exprsUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1752: + case 1753: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11248 +//line mysql_sql.y:11256 { yyLOCAL = tree.NewAndExpr(yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1753: + case 1754: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11252 +//line mysql_sql.y:11260 { yyLOCAL = tree.NewOrExpr(yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1754: + case 1755: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11256 +//line mysql_sql.y:11264 { name := tree.NewUnresolvedColName("concat") yyLOCAL = &tree.FuncExpr{ @@ -24902,355 +24942,355 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1755: + case 1756: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11265 +//line mysql_sql.y:11273 { yyLOCAL = tree.NewXorExpr(yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1756: + case 1757: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11269 +//line mysql_sql.y:11277 { yyLOCAL = tree.NewNotExpr(yyDollar[2].exprUnion()) } yyVAL.union = yyLOCAL - case 1757: + case 1758: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11273 +//line mysql_sql.y:11281 { yyLOCAL = yyDollar[1].exprUnion() } yyVAL.union = yyLOCAL - case 1758: + case 1759: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11278 +//line mysql_sql.y:11286 { yyLOCAL = yyDollar[1].exprUnion() } yyVAL.union = yyLOCAL - case 1759: + case 1760: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11282 +//line mysql_sql.y:11290 { yyLOCAL = tree.NewMaxValue() } yyVAL.union = yyLOCAL - case 1760: + case 1761: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11288 +//line mysql_sql.y:11296 { yyLOCAL = tree.NewIsNullExpr(yyDollar[1].exprUnion()) } yyVAL.union = yyLOCAL - case 1761: + case 1762: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11292 +//line mysql_sql.y:11300 { yyLOCAL = tree.NewIsNotNullExpr(yyDollar[1].exprUnion()) } yyVAL.union = yyLOCAL - case 1762: + case 1763: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11296 +//line mysql_sql.y:11304 { yyLOCAL = tree.NewIsUnknownExpr(yyDollar[1].exprUnion()) } yyVAL.union = yyLOCAL - case 1763: + case 1764: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11300 +//line mysql_sql.y:11308 { yyLOCAL = tree.NewIsNotUnknownExpr(yyDollar[1].exprUnion()) } yyVAL.union = yyLOCAL - case 1764: + case 1765: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11304 +//line mysql_sql.y:11312 { yyLOCAL = tree.NewIsTrueExpr(yyDollar[1].exprUnion()) } yyVAL.union = yyLOCAL - case 1765: + case 1766: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11308 +//line mysql_sql.y:11316 { yyLOCAL = tree.NewIsNotTrueExpr(yyDollar[1].exprUnion()) } yyVAL.union = yyLOCAL - case 1766: + case 1767: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11312 +//line mysql_sql.y:11320 { yyLOCAL = tree.NewIsFalseExpr(yyDollar[1].exprUnion()) } yyVAL.union = yyLOCAL - case 1767: + case 1768: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11316 +//line mysql_sql.y:11324 { yyLOCAL = tree.NewIsNotFalseExpr(yyDollar[1].exprUnion()) } yyVAL.union = yyLOCAL - case 1768: + case 1769: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11320 +//line mysql_sql.y:11328 { yyLOCAL = tree.NewComparisonExpr(yyDollar[2].comparisonOpUnion(), yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1769: + case 1770: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11324 +//line mysql_sql.y:11332 { yyLOCAL = tree.NewSubqueryComparisonExpr(yyDollar[2].comparisonOpUnion(), yyDollar[3].comparisonOpUnion(), yyDollar[1].exprUnion(), yyDollar[4].subqueryUnion()) yyLOCAL = tree.NewSubqueryComparisonExpr(yyDollar[2].comparisonOpUnion(), yyDollar[3].comparisonOpUnion(), yyDollar[1].exprUnion(), yyDollar[4].subqueryUnion()) } yyVAL.union = yyLOCAL - case 1771: + case 1772: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11332 +//line mysql_sql.y:11340 { yyLOCAL = tree.NewComparisonExpr(tree.IN, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1772: + case 1773: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11336 +//line mysql_sql.y:11344 { yyLOCAL = tree.NewComparisonExpr(tree.NOT_IN, yyDollar[1].exprUnion(), yyDollar[4].exprUnion()) } yyVAL.union = yyLOCAL - case 1773: + case 1774: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11340 +//line mysql_sql.y:11348 { yyLOCAL = tree.NewComparisonExprWithEscape(tree.LIKE, yyDollar[1].exprUnion(), yyDollar[3].exprUnion(), yyDollar[4].exprUnion()) } yyVAL.union = yyLOCAL - case 1774: + case 1775: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11344 +//line mysql_sql.y:11352 { yyLOCAL = tree.NewComparisonExprWithEscape(tree.NOT_LIKE, yyDollar[1].exprUnion(), yyDollar[4].exprUnion(), yyDollar[5].exprUnion()) } yyVAL.union = yyLOCAL - case 1775: + case 1776: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11348 +//line mysql_sql.y:11356 { yyLOCAL = tree.NewComparisonExprWithEscape(tree.ILIKE, yyDollar[1].exprUnion(), yyDollar[3].exprUnion(), yyDollar[4].exprUnion()) } yyVAL.union = yyLOCAL - case 1776: + case 1777: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11352 +//line mysql_sql.y:11360 { yyLOCAL = tree.NewComparisonExprWithEscape(tree.NOT_ILIKE, yyDollar[1].exprUnion(), yyDollar[4].exprUnion(), yyDollar[5].exprUnion()) } yyVAL.union = yyLOCAL - case 1777: + case 1778: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11356 +//line mysql_sql.y:11364 { yyLOCAL = tree.NewComparisonExpr(tree.REG_MATCH, yyDollar[1].exprUnion(), yyDollar[3].exprUnion()) } yyVAL.union = yyLOCAL - case 1778: + case 1779: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11360 +//line mysql_sql.y:11368 { yyLOCAL = tree.NewComparisonExpr(tree.NOT_REG_MATCH, yyDollar[1].exprUnion(), yyDollar[4].exprUnion()) } yyVAL.union = yyLOCAL - case 1779: + case 1780: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11364 +//line mysql_sql.y:11372 { yyLOCAL = tree.NewRangeCond(false, yyDollar[1].exprUnion(), yyDollar[3].exprUnion(), yyDollar[5].exprUnion()) } yyVAL.union = yyLOCAL - case 1780: + case 1781: yyDollar = yyS[yypt-6 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11368 +//line mysql_sql.y:11376 { yyLOCAL = tree.NewRangeCond(true, yyDollar[1].exprUnion(), yyDollar[4].exprUnion(), yyDollar[6].exprUnion()) } yyVAL.union = yyLOCAL - case 1782: + case 1783: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11374 +//line mysql_sql.y:11382 { yyLOCAL = nil } yyVAL.union = yyLOCAL - case 1783: + case 1784: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11378 +//line mysql_sql.y:11386 { yyLOCAL = yyDollar[2].exprUnion() } yyVAL.union = yyLOCAL - case 1784: + case 1785: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11384 +//line mysql_sql.y:11392 { yyLOCAL = yyDollar[1].tupleUnion() } yyVAL.union = yyLOCAL - case 1785: + case 1786: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11388 +//line mysql_sql.y:11396 { yyLOCAL = yyDollar[1].subqueryUnion() } yyVAL.union = yyLOCAL - case 1786: + case 1787: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ComparisonOp -//line mysql_sql.y:11395 +//line mysql_sql.y:11403 { yyLOCAL = tree.ALL } yyVAL.union = yyLOCAL - case 1787: + case 1788: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ComparisonOp -//line mysql_sql.y:11399 +//line mysql_sql.y:11407 { yyLOCAL = tree.ANY } yyVAL.union = yyLOCAL - case 1788: + case 1789: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ComparisonOp -//line mysql_sql.y:11403 +//line mysql_sql.y:11411 { yyLOCAL = tree.SOME } yyVAL.union = yyLOCAL - case 1789: + case 1790: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ComparisonOp -//line mysql_sql.y:11409 +//line mysql_sql.y:11417 { yyLOCAL = tree.EQUAL } yyVAL.union = yyLOCAL - case 1790: + case 1791: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ComparisonOp -//line mysql_sql.y:11413 +//line mysql_sql.y:11421 { yyLOCAL = tree.LESS_THAN } yyVAL.union = yyLOCAL - case 1791: + case 1792: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ComparisonOp -//line mysql_sql.y:11417 +//line mysql_sql.y:11425 { yyLOCAL = tree.GREAT_THAN } yyVAL.union = yyLOCAL - case 1792: + case 1793: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ComparisonOp -//line mysql_sql.y:11421 +//line mysql_sql.y:11429 { yyLOCAL = tree.LESS_THAN_EQUAL } yyVAL.union = yyLOCAL - case 1793: + case 1794: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ComparisonOp -//line mysql_sql.y:11425 +//line mysql_sql.y:11433 { yyLOCAL = tree.GREAT_THAN_EQUAL } yyVAL.union = yyLOCAL - case 1794: + case 1795: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ComparisonOp -//line mysql_sql.y:11429 +//line mysql_sql.y:11437 { yyLOCAL = tree.NOT_EQUAL } yyVAL.union = yyLOCAL - case 1795: + case 1796: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ComparisonOp -//line mysql_sql.y:11433 +//line mysql_sql.y:11441 { yyLOCAL = tree.NULL_SAFE_EQUAL } yyVAL.union = yyLOCAL - case 1796: + case 1797: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:11439 +//line mysql_sql.y:11447 { yyLOCAL = tree.NewAttributePrimaryKey() } yyVAL.union = yyLOCAL - case 1797: + case 1798: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:11443 +//line mysql_sql.y:11451 { yyLOCAL = tree.NewAttributeUniqueKey() } yyVAL.union = yyLOCAL - case 1798: + case 1799: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:11447 +//line mysql_sql.y:11455 { yyLOCAL = tree.NewAttributeUnique() } yyVAL.union = yyLOCAL - case 1799: + case 1800: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.ColumnAttribute -//line mysql_sql.y:11451 +//line mysql_sql.y:11459 { yyLOCAL = tree.NewAttributeKey() } yyVAL.union = yyLOCAL - case 1800: + case 1801: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11457 +//line mysql_sql.y:11465 { str := fmt.Sprintf("%v", yyDollar[1].item) switch v := yyDollar[1].item.(type) { @@ -25264,35 +25304,35 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1801: + case 1802: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11470 +//line mysql_sql.y:11478 { fval := yyDollar[1].item.(float64) yyLOCAL = tree.NewNumVal(fval, yylex.(*Lexer).scanner.LastToken, false, tree.P_float64) } yyVAL.union = yyLOCAL - case 1802: + case 1803: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11475 +//line mysql_sql.y:11483 { yyLOCAL = tree.NewNumVal(yyDollar[1].str, yyDollar[1].str, false, tree.P_decimal) } yyVAL.union = yyLOCAL - case 1803: + case 1804: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11481 +//line mysql_sql.y:11489 { yyLOCAL = tree.NewNumVal(yyDollar[1].str, yyDollar[1].str, false, tree.P_char) } yyVAL.union = yyLOCAL - case 1804: + case 1805: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11485 +//line mysql_sql.y:11493 { str := fmt.Sprintf("%v", yyDollar[1].item) switch v := yyDollar[1].item.(type) { @@ -25306,51 +25346,51 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1805: + case 1806: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11498 +//line mysql_sql.y:11506 { fval := yyDollar[1].item.(float64) yyLOCAL = tree.NewNumVal(fval, yylex.(*Lexer).scanner.LastToken, false, tree.P_float64) } yyVAL.union = yyLOCAL - case 1806: + case 1807: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11503 +//line mysql_sql.y:11511 { yyLOCAL = tree.NewNumVal(true, "true", false, tree.P_bool) } yyVAL.union = yyLOCAL - case 1807: + case 1808: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11507 +//line mysql_sql.y:11515 { yyLOCAL = tree.NewNumVal(false, "false", false, tree.P_bool) } yyVAL.union = yyLOCAL - case 1808: + case 1809: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11511 +//line mysql_sql.y:11519 { yyLOCAL = tree.NewNumVal("null", "null", false, tree.P_null) } yyVAL.union = yyLOCAL - case 1809: + case 1810: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11515 +//line mysql_sql.y:11523 { yyLOCAL = tree.NewNumVal(yyDollar[1].str, yyDollar[1].str, false, tree.P_hexnum) } yyVAL.union = yyLOCAL - case 1810: + case 1811: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11519 +//line mysql_sql.y:11527 { if strings.HasPrefix(yyDollar[2].str, "0x") { yyDollar[2].str = yyDollar[2].str[2:] @@ -25358,69 +25398,69 @@ yydefault: yyLOCAL = tree.NewNumVal(yyDollar[2].str, yyDollar[2].str, false, tree.P_bit) } yyVAL.union = yyLOCAL - case 1811: + case 1812: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11526 +//line mysql_sql.y:11534 { yyLOCAL = tree.NewNumVal(yyDollar[1].str, yyDollar[1].str, false, tree.P_decimal) } yyVAL.union = yyLOCAL - case 1812: + case 1813: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11530 +//line mysql_sql.y:11538 { yyLOCAL = tree.NewNumVal(yyDollar[1].str, yyDollar[1].str, false, tree.P_bit) } yyVAL.union = yyLOCAL - case 1813: + case 1814: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11534 +//line mysql_sql.y:11542 { yyLOCAL = tree.NewParamExpr(yylex.(*Lexer).GetParamIndex()) } yyVAL.union = yyLOCAL - case 1814: + case 1815: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Expr -//line mysql_sql.y:11538 +//line mysql_sql.y:11546 { yyLOCAL = tree.NewNumVal(yyDollar[2].str, yyDollar[2].str, false, tree.P_ScoreBinary) } yyVAL.union = yyLOCAL - case 1815: + case 1816: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11545 +//line mysql_sql.y:11553 { yyLOCAL = yyDollar[1].columnTypeUnion() yyLOCAL.InternalType.Unsigned = yyDollar[2].unsignedOptUnion() yyLOCAL.InternalType.Zerofill = yyDollar[3].zeroFillOptUnion() } yyVAL.union = yyLOCAL - case 1819: + case 1820: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11556 +//line mysql_sql.y:11564 { yyLOCAL = yyDollar[1].columnTypeUnion() yyLOCAL.InternalType.DisplayWith = yyDollar[2].lengthOptUnion() } yyVAL.union = yyLOCAL - case 1820: + case 1821: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11561 +//line mysql_sql.y:11569 { yyLOCAL = yyDollar[1].columnTypeUnion() } yyVAL.union = yyLOCAL - case 1821: + case 1822: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11567 +//line mysql_sql.y:11575 { locale := "" yyLOCAL = &tree.T{ @@ -25433,10 +25473,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1822: + case 1823: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11579 +//line mysql_sql.y:11587 { locale := "" yyLOCAL = &tree.T{ @@ -25449,10 +25489,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1823: + case 1824: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11591 +//line mysql_sql.y:11599 { locale := "" yyLOCAL = &tree.T{ @@ -25465,10 +25505,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1824: + case 1825: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11603 +//line mysql_sql.y:11611 { locale := "" yyLOCAL = &tree.T{ @@ -25482,10 +25522,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1825: + case 1826: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11616 +//line mysql_sql.y:11624 { locale := "" yyLOCAL = &tree.T{ @@ -25499,10 +25539,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1826: + case 1827: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11629 +//line mysql_sql.y:11637 { locale := "" yyLOCAL = &tree.T{ @@ -25516,10 +25556,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1827: + case 1828: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11642 +//line mysql_sql.y:11650 { locale := "" yyLOCAL = &tree.T{ @@ -25533,10 +25573,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1828: + case 1829: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11655 +//line mysql_sql.y:11663 { locale := "" yyLOCAL = &tree.T{ @@ -25550,10 +25590,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1829: + case 1830: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11668 +//line mysql_sql.y:11676 { locale := "" yyLOCAL = &tree.T{ @@ -25567,10 +25607,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1830: + case 1831: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11681 +//line mysql_sql.y:11689 { locale := "" yyLOCAL = &tree.T{ @@ -25584,10 +25624,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1831: + case 1832: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11694 +//line mysql_sql.y:11702 { locale := "" yyLOCAL = &tree.T{ @@ -25601,10 +25641,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1832: + case 1833: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11707 +//line mysql_sql.y:11715 { locale := "" yyLOCAL = &tree.T{ @@ -25618,10 +25658,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1833: + case 1834: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11720 +//line mysql_sql.y:11728 { locale := "" yyLOCAL = &tree.T{ @@ -25635,10 +25675,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1834: + case 1835: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11733 +//line mysql_sql.y:11741 { locale := "" yyLOCAL = &tree.T{ @@ -25652,10 +25692,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1835: + case 1836: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11748 +//line mysql_sql.y:11756 { locale := "" if yyDollar[2].lengthScaleOptUnion().DisplayWith > 255 { @@ -25683,10 +25723,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1836: + case 1837: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11775 +//line mysql_sql.y:11783 { locale := "" if yyDollar[2].lengthScaleOptUnion().DisplayWith > 255 { @@ -25728,10 +25768,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1837: + case 1838: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11817 +//line mysql_sql.y:11825 { locale := "" if yyDollar[2].lengthScaleOptUnion().Scale != tree.NotDefineDec && yyDollar[2].lengthScaleOptUnion().Scale > yyDollar[2].lengthScaleOptUnion().DisplayWith { @@ -25768,10 +25808,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1838: + case 1839: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11853 +//line mysql_sql.y:11861 { locale := "" if yyDollar[2].lengthScaleOptUnion().Scale != tree.NotDefineDec && yyDollar[2].lengthScaleOptUnion().Scale > yyDollar[2].lengthScaleOptUnion().DisplayWith { @@ -25808,10 +25848,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1839: + case 1840: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11889 +//line mysql_sql.y:11897 { locale := "" yyLOCAL = &tree.T{ @@ -25827,10 +25867,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1840: + case 1841: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11906 +//line mysql_sql.y:11914 { locale := "" yyLOCAL = &tree.T{ @@ -25843,10 +25883,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1841: + case 1842: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11918 +//line mysql_sql.y:11926 { locale := "" if yyDollar[2].lengthOptUnion() < 0 || yyDollar[2].lengthOptUnion() > 6 { @@ -25867,10 +25907,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1842: + case 1843: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11938 +//line mysql_sql.y:11946 { locale := "" if yyDollar[2].lengthOptUnion() < 0 || yyDollar[2].lengthOptUnion() > 6 { @@ -25891,10 +25931,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1843: + case 1844: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11958 +//line mysql_sql.y:11966 { locale := "" if yyDollar[2].lengthOptUnion() < 0 || yyDollar[2].lengthOptUnion() > 6 { @@ -25915,10 +25955,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1844: + case 1845: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11978 +//line mysql_sql.y:11986 { locale := "" yyLOCAL = &tree.T{ @@ -25933,10 +25973,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1845: + case 1846: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:11994 +//line mysql_sql.y:12002 { locale := "" yyLOCAL = &tree.T{ @@ -25950,10 +25990,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1846: + case 1847: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12007 +//line mysql_sql.y:12015 { locale := "" yyLOCAL = &tree.T{ @@ -25967,10 +26007,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1847: + case 1848: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12020 +//line mysql_sql.y:12028 { locale := "" yyLOCAL = &tree.T{ @@ -25984,10 +26024,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1848: + case 1849: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12033 +//line mysql_sql.y:12041 { locale := "" yyLOCAL = &tree.T{ @@ -26001,10 +26041,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1849: + case 1850: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12046 +//line mysql_sql.y:12054 { locale := "" yyLOCAL = &tree.T{ @@ -26017,10 +26057,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1850: + case 1851: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12058 +//line mysql_sql.y:12066 { locale := "" yyLOCAL = &tree.T{ @@ -26033,10 +26073,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1851: + case 1852: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12070 +//line mysql_sql.y:12078 { locale := "" yyLOCAL = &tree.T{ @@ -26049,10 +26089,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1852: + case 1853: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12082 +//line mysql_sql.y:12090 { locale := "" yyLOCAL = &tree.T{ @@ -26065,10 +26105,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1853: + case 1854: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12094 +//line mysql_sql.y:12102 { locale := "" yyLOCAL = &tree.T{ @@ -26081,10 +26121,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1854: + case 1855: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12106 +//line mysql_sql.y:12114 { locale := "" yyLOCAL = &tree.T{ @@ -26097,10 +26137,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1855: + case 1856: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12118 +//line mysql_sql.y:12126 { locale := "" yyLOCAL = &tree.T{ @@ -26113,10 +26153,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1856: + case 1857: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12130 +//line mysql_sql.y:12138 { locale := "" yyLOCAL = &tree.T{ @@ -26129,10 +26169,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1857: + case 1858: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12142 +//line mysql_sql.y:12150 { locale := "" yyLOCAL = &tree.T{ @@ -26145,10 +26185,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1858: + case 1859: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12154 +//line mysql_sql.y:12162 { locale := "" yyLOCAL = &tree.T{ @@ -26161,10 +26201,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1859: + case 1860: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12166 +//line mysql_sql.y:12174 { locale := "" yyLOCAL = &tree.T{ @@ -26178,10 +26218,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1860: + case 1861: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12179 +//line mysql_sql.y:12187 { locale := "" yyLOCAL = &tree.T{ @@ -26195,10 +26235,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1861: + case 1862: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12192 +//line mysql_sql.y:12200 { locale := "" yyLOCAL = &tree.T{ @@ -26212,10 +26252,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1862: + case 1863: yyDollar = yyS[yypt-4 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12205 +//line mysql_sql.y:12213 { locale := "" yyLOCAL = &tree.T{ @@ -26229,10 +26269,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1863: + case 1864: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12218 +//line mysql_sql.y:12226 { locale := "" yyLOCAL = &tree.T{ @@ -26246,20 +26286,20 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1864: + case 1865: yyDollar = yyS[yypt-2 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:12233 +//line mysql_sql.y:12241 { yyLOCAL = &tree.Do{ Exprs: yyDollar[2].exprsUnion(), } } yyVAL.union = yyLOCAL - case 1865: + case 1866: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:12241 +//line mysql_sql.y:12249 { yyLOCAL = &tree.Declare{ Variables: yyDollar[2].strsUnion(), @@ -26268,10 +26308,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1866: + case 1867: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.Statement -//line mysql_sql.y:12250 +//line mysql_sql.y:12258 { yyLOCAL = &tree.Declare{ Variables: yyDollar[2].strsUnion(), @@ -26280,10 +26320,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1867: + case 1868: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL *tree.T -//line mysql_sql.y:12260 +//line mysql_sql.y:12268 { locale := "" yyLOCAL = &tree.T{ @@ -26296,75 +26336,75 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1868: + case 1869: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL []string -//line mysql_sql.y:12283 +//line mysql_sql.y:12291 { yyLOCAL = make([]string, 0, 4) yyLOCAL = append(yyLOCAL, yyDollar[1].str) } yyVAL.union = yyLOCAL - case 1869: + case 1870: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL []string -//line mysql_sql.y:12288 +//line mysql_sql.y:12296 { yyLOCAL = append(yyDollar[1].strsUnion(), yyDollar[3].str) } yyVAL.union = yyLOCAL - case 1870: + case 1871: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL int32 -//line mysql_sql.y:12294 +//line mysql_sql.y:12302 { yyLOCAL = 0 } yyVAL.union = yyLOCAL - case 1872: + case 1873: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL int32 -//line mysql_sql.y:12301 +//line mysql_sql.y:12309 { yyLOCAL = 0 } yyVAL.union = yyLOCAL - case 1873: + case 1874: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL int32 -//line mysql_sql.y:12305 +//line mysql_sql.y:12313 { yyLOCAL = int32(yyDollar[2].item.(int64)) } yyVAL.union = yyLOCAL - case 1874: + case 1875: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL int32 -//line mysql_sql.y:12310 +//line mysql_sql.y:12318 { yyLOCAL = int32(-1) } yyVAL.union = yyLOCAL - case 1875: + case 1876: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL int32 -//line mysql_sql.y:12314 +//line mysql_sql.y:12322 { yyLOCAL = int32(yyDollar[2].item.(int64)) } yyVAL.union = yyLOCAL - case 1876: + case 1877: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL int32 -//line mysql_sql.y:12320 +//line mysql_sql.y:12328 { yyLOCAL = tree.GetDisplayWith(int32(yyDollar[2].item.(int64))) } yyVAL.union = yyLOCAL - case 1877: + case 1878: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.LengthScaleOpt -//line mysql_sql.y:12326 +//line mysql_sql.y:12334 { yyLOCAL = tree.LengthScaleOpt{ DisplayWith: tree.NotDefineDisplayWidth, @@ -26372,10 +26412,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1878: + case 1879: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.LengthScaleOpt -//line mysql_sql.y:12333 +//line mysql_sql.y:12341 { yyLOCAL = tree.LengthScaleOpt{ DisplayWith: tree.GetDisplayWith(int32(yyDollar[2].item.(int64))), @@ -26383,10 +26423,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1879: + case 1880: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.LengthScaleOpt -//line mysql_sql.y:12340 +//line mysql_sql.y:12348 { yyLOCAL = tree.LengthScaleOpt{ DisplayWith: tree.GetDisplayWith(int32(yyDollar[2].item.(int64))), @@ -26394,10 +26434,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1880: + case 1881: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL tree.LengthScaleOpt -//line mysql_sql.y:12349 +//line mysql_sql.y:12357 { yyLOCAL = tree.LengthScaleOpt{ DisplayWith: 38, // this is the default precision for decimal @@ -26405,10 +26445,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1881: + case 1882: yyDollar = yyS[yypt-3 : yypt+1] var yyLOCAL tree.LengthScaleOpt -//line mysql_sql.y:12356 +//line mysql_sql.y:12364 { yyLOCAL = tree.LengthScaleOpt{ DisplayWith: tree.GetDisplayWith(int32(yyDollar[2].item.(int64))), @@ -26416,10 +26456,10 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1882: + case 1883: yyDollar = yyS[yypt-5 : yypt+1] var yyLOCAL tree.LengthScaleOpt -//line mysql_sql.y:12363 +//line mysql_sql.y:12371 { yyLOCAL = tree.LengthScaleOpt{ DisplayWith: tree.GetDisplayWith(int32(yyDollar[2].item.(int64))), @@ -26427,52 +26467,52 @@ yydefault: } } yyVAL.union = yyLOCAL - case 1883: + case 1884: yyDollar = yyS[yypt-0 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:12372 +//line mysql_sql.y:12380 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1884: + case 1885: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:12376 +//line mysql_sql.y:12384 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1885: + case 1886: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:12380 +//line mysql_sql.y:12388 { yyLOCAL = false } yyVAL.union = yyLOCAL - case 1886: + case 1887: yyDollar = yyS[yypt-0 : yypt+1] -//line mysql_sql.y:12386 +//line mysql_sql.y:12394 { } - case 1887: + case 1888: yyDollar = yyS[yypt-1 : yypt+1] var yyLOCAL bool -//line mysql_sql.y:12388 +//line mysql_sql.y:12396 { yyLOCAL = true } yyVAL.union = yyLOCAL - case 1891: + case 1892: yyDollar = yyS[yypt-0 : yypt+1] -//line mysql_sql.y:12398 +//line mysql_sql.y:12406 { yyVAL.str = "" } - case 1892: + case 1893: yyDollar = yyS[yypt-1 : yypt+1] -//line mysql_sql.y:12402 +//line mysql_sql.y:12410 { yyVAL.str = string(yyDollar[1].str) } diff --git a/pkg/sql/parsers/dialect/mysql/mysql_sql.y b/pkg/sql/parsers/dialect/mysql/mysql_sql.y index 90635b1e4f4f6..5502b6250fb03 100644 --- a/pkg/sql/parsers/dialect/mysql/mysql_sql.y +++ b/pkg/sql/parsers/dialect/mysql/mysql_sql.y @@ -363,7 +363,7 @@ import ( // Secondary Index %token PARSER VISIBLE INVISIBLE BTREE HASH RTREE BSI IVFFLAT MASTER HNSW -%token ZONEMAP LEADING BOTH TRAILING UNKNOWN LISTS OP_TYPE REINDEX EF_SEARCH EF_CONSTRUCTION M QUANTIZATION +%token ZONEMAP LEADING BOTH TRAILING UNKNOWN LISTS OP_TYPE REINDEX EF_SEARCH EF_CONSTRUCTION M QUANTIZATION ASYNC // Alter @@ -7562,6 +7562,8 @@ index_option_list: opt1.HnswQuantization = opt2.HnswQuantization } else if opt2.HnswEfSearch > 0 { opt1.HnswEfSearch = opt2.HnswEfSearch + } else if opt2.Async { + opt1.Async = opt2.Async } $$ = opt1 } @@ -7655,6 +7657,12 @@ index_option: io.HnswQuantization = $3 $$ = io } +| ASYNC + { + io := tree.NewIndexOption() + io.Async = true + $$ = io + } index_column_list: @@ -12606,6 +12614,7 @@ non_reserved_keyword: | ATTRIBUTE | ACTION | ALGORITHM +| ASYNC | BEGIN | BIGINT | BIT diff --git a/pkg/sql/parsers/dialect/mysql/mysql_sql_test.go b/pkg/sql/parsers/dialect/mysql/mysql_sql_test.go index 2faf054ff05b6..8b1c8e6834277 100644 --- a/pkg/sql/parsers/dialect/mysql/mysql_sql_test.go +++ b/pkg/sql/parsers/dialect/mysql/mysql_sql_test.go @@ -871,7 +871,8 @@ var ( }, { input: "create table t (a int, b char, index if not exists idx (a, b))", }, { - input: "create table t (a int, b char, fulltext idx (a, b))", + input: "create table t (a int, b char, fulltext idx (a, b) async)", + output: "create table t (a int, b char, fulltext idx (a, b) ASYNC )", }, { input: "create table t (a int, b char, constraint p1 primary key idx using hash (a, b))", output: "create table t (a int, b char, constraint p1 primary key idx using none (a, b))", @@ -1571,6 +1572,9 @@ var ( }, { input: "create index idx using ivfflat on A (a) LISTS 10 op_type 'vector_l2_ops'", output: "create index idx using ivfflat on a (a) LISTS 10 OP_TYPE vector_l2_ops ", + }, { + input: "create index idx using ivfflat on A (a) LISTS 10 op_type 'vector_l2_ops' async", + output: "create index idx using ivfflat on a (a) LISTS 10 OP_TYPE vector_l2_ops ASYNC ", }, { input: "create index idx1 on a (a)", }, { @@ -3259,6 +3263,10 @@ var ( input: "create index idx using hnsw on A (a) M 4 ef_construction 100 ef_search 32 QUANTIZATION 'BF16' OP_TYPE 'VECTOR_L2_OPS'", output: "create index idx using hnsw on a (a) M 4 EF_CONSTRUCTION 100 EF_SEARCH 32 QUANTIZATION BF16 OP_TYPE VECTOR_L2_OPS ", }, + { + input: "create index idx using hnsw on A (a) M 4 ef_construction 100 ef_search 32 QUANTIZATION 'BF16' OP_TYPE 'VECTOR_L2_OPS' ASYNC", + output: "create index idx using hnsw on a (a) M 4 EF_CONSTRUCTION 100 EF_SEARCH 32 QUANTIZATION BF16 OP_TYPE VECTOR_L2_OPS ASYNC ", + }, { input: "CREATE TABLE `vector_index_01` ( `a` bigint NOT NULL, `b` vecf32(128) DEFAULT NULL, PRIMARY KEY (`a`), KEY `idx01` USING hnsw (`b`) m = 4 ef_search = 64 ef_construction = 100 quantization 'bf16' op_type 'vector_l2_ops' )", output: "create table vector_index_01 (a bigint not null, b vecf32(128) default null, primary key (a), index idx01 using hnsw (b) M 4 EF_CONSTRUCTION 100 EF_SEARCH 64 QUANTIZATION bf16 OP_TYPE vector_l2_ops )", diff --git a/pkg/sql/parsers/tree/create.go b/pkg/sql/parsers/tree/create.go index f2bde38b7d1ad..10f63ab955ba2 100644 --- a/pkg/sql/parsers/tree/create.go +++ b/pkg/sql/parsers/tree/create.go @@ -2070,6 +2070,7 @@ type IndexOption struct { HnswEfConstruction int64 HnswEfSearch int64 HnswQuantization string + Async bool } // Must follow the following sequence when test @@ -2129,6 +2130,9 @@ func (node *IndexOption) Format(ctx *FmtCtx) { if node.Visible != VISIBLE_TYPE_INVALID { ctx.WriteString(node.Visible.ToString()) } + if node.Async { + ctx.WriteString("ASYNC ") + } } func (node IndexOption) TypeName() string { return "tree.IndexOption" } diff --git a/pkg/sql/plan/build_ddl.go b/pkg/sql/plan/build_ddl.go index a4889be9fb5d9..d6e818df5ce03 100644 --- a/pkg/sql/plan/build_ddl.go +++ b/pkg/sql/plan/build_ddl.go @@ -1677,10 +1677,10 @@ func buildFullTextIndexTable(createTable *plan.CreateTable, indexInfos []*tree.F if indexInfo.IndexOption != nil { if indexInfo.IndexOption.ParserName != "" { indexDef.Option = &plan.IndexOption{ParserName: indexInfo.IndexOption.ParserName, NgramTokenSize: int32(3)} - indexDef.IndexAlgoParams, err = catalog.IndexParamsToJsonString(indexInfo) - if err != nil { - return err - } + } + indexDef.IndexAlgoParams, err = catalog.IndexParamsToJsonString(indexInfo) + if err != nil { + return err } if indexInfo.IndexOption.Comment != "" { indexDef.Comment = indexInfo.IndexOption.Comment diff --git a/pkg/sql/plan/build_dml_util.go b/pkg/sql/plan/build_dml_util.go index a6f05c0cf190c..6d5e27270cc51 100644 --- a/pkg/sql/plan/build_dml_util.go +++ b/pkg/sql/plan/build_dml_util.go @@ -885,8 +885,9 @@ func buildInsertPlansWithRelatedHiddenTable( // IVF indexDefs are aggregated and handled later if _, ok := multiTableIndexes[indexdef.IndexName]; !ok { multiTableIndexes[indexdef.IndexName] = &MultiTableIndex{ - IndexAlgo: catalog.ToLower(indexdef.IndexAlgo), - IndexDefs: make(map[string]*IndexDef), + IndexAlgo: catalog.ToLower(indexdef.IndexAlgo), + IndexAlgoParams: indexdef.IndexAlgoParams, + IndexDefs: make(map[string]*IndexDef), } } multiTableIndexes[indexdef.IndexName].IndexDefs[catalog.ToLower(indexdef.IndexAlgoTableType)] = indexdef @@ -896,6 +897,7 @@ func buildInsertPlansWithRelatedHiddenTable( if err != nil { return err } + } else if postdml_flag && indexdef.TableExist && catalog.IsFullTextIndexAlgo(indexdef.IndexAlgo) { // TODO: choose either PostInsertFullTextIndex or PreInsertFullTextIndex err = buildPostInsertFullTextIndex(stmt, ctx, builder, bindCtx, objRef, tableDef, updateColLength, sourceStep, ifInsertFromUniqueColMap, indexdef, idx) @@ -3505,6 +3507,16 @@ func buildPreInsertMultiTableIndexes(ctx CompilerContext, builder *QueryBuilder, switch multiTableIndex.IndexAlgo { case catalog.MoIndexIvfFlatAlgo.ToString(): + // skip async + var async bool + async, err = catalog.IsIndexAsync(multiTableIndex.IndexAlgoParams) + if err != nil { + return err + } + if async { + continue + } + lastNodeId = appendSinkScanNode(builder, bindCtx, sourceStep) var idxRefs = make([]*ObjectRef, 3) var idxTableDefs = make([]*TableDef, 3) @@ -3578,6 +3590,15 @@ func buildDeleteMultiTableIndexes(ctx CompilerContext, builder *QueryBuilder, bi for _, multiTableIndex := range multiTableIndexes { switch multiTableIndex.IndexAlgo { case catalog.MoIndexIvfFlatAlgo.ToString(): + // skip async + var async bool + async, err = catalog.IsIndexAsync(multiTableIndex.IndexAlgoParams) + if err != nil { + return err + } + if async { + continue + } // Used by pre-insert vector index. var idxRefs = make([]*ObjectRef, 3) @@ -4238,8 +4259,9 @@ func buildDeleteIndexPlans(ctx CompilerContext, builder *QueryBuilder, bindCtx * // IVF indexDefs are aggregated and handled later if _, ok := multiTableIndexes[indexdef.IndexName]; !ok { multiTableIndexes[indexdef.IndexName] = &MultiTableIndex{ - IndexAlgo: catalog.ToLower(indexdef.IndexAlgo), - IndexDefs: make(map[string]*IndexDef), + IndexAlgo: catalog.ToLower(indexdef.IndexAlgo), + IndexAlgoParams: indexdef.IndexAlgoParams, + IndexDefs: make(map[string]*IndexDef), } } multiTableIndexes[indexdef.IndexName].IndexDefs[catalog.ToLower(indexdef.IndexAlgoTableType)] = indexdef @@ -4295,6 +4317,15 @@ func buildDeleteIndexPlans(ctx CompilerContext, builder *QueryBuilder, bindCtx * func buildPreInsertFullTextIndex(stmt *tree.Insert, ctx CompilerContext, builder *QueryBuilder, bindCtx *BindContext, objRef *ObjectRef, tableDef *TableDef, updateColLength int, sourceStep int32, ifInsertFromUniqueColMap map[string]bool, indexdef *plan.IndexDef, idx int) error { + // skip async + async, err := catalog.IsIndexAsync(indexdef.IndexAlgoParams) + if err != nil { + return err + } + if async { + return nil + } + isUpdate := (updateColLength > 0) lastNodeId := appendSinkScanNode(builder, bindCtx, sourceStep) @@ -4716,6 +4747,15 @@ func buildDeleteRowsFullTextIndex(ctx CompilerContext, builder *QueryBuilder, bi func buildPreDeleteFullTextIndex(ctx CompilerContext, builder *QueryBuilder, bindCtx *BindContext, delCtx *dmlPlanCtx, indexdef *plan.IndexDef, idx int, typMap map[string]plan.Type, posMap map[string]int) error { + // skip async + async, err := catalog.IsIndexAsync(indexdef.IndexAlgoParams) + if err != nil { + return err + } + if async { + return nil + } + //isUpdate := delCtx.updateColLength > 0 indexObjRef, indexTableDef, err := ctx.ResolveIndexTableByRef(delCtx.objRef, indexdef.IndexTableName, nil) if err != nil { @@ -4747,6 +4787,15 @@ func buildPreDeleteFullTextIndex(ctx CompilerContext, builder *QueryBuilder, bin func buildPostDmlFullTextIndex(ctx CompilerContext, builder *QueryBuilder, bindCtx *BindContext, indexObjRef *ObjectRef, indexTableDef *TableDef, tableDef *TableDef, sourceStep int32, indexdef *plan.IndexDef, idx int, isDelete, isInsert, isDeleteWithoutFilters bool) error { + // skip async + async, err := catalog.IsIndexAsync(indexdef.IndexAlgoParams) + if err != nil { + return err + } + if async { + return nil + } + lastNodeId := appendSinkScanNode(builder, bindCtx, sourceStep) orgPkColPos, _ := getPkPos(tableDef, false) diff --git a/pkg/sql/plan/build_show_util.go b/pkg/sql/plan/build_show_util.go index 0195044b5ec9a..cc0c7f8a5eace 100644 --- a/pkg/sql/plan/build_show_util.go +++ b/pkg/sql/plan/build_show_util.go @@ -212,6 +212,11 @@ func ConstructCreateTableSQL( if ok { indexStr += " WITH PARSER " + parser } + + async, ok := paramMap[catalog.Async] + if ok && async == "true" { + indexStr += " ASYNC" + } } } else { diff --git a/pkg/sql/plan/fulltext.go b/pkg/sql/plan/fulltext.go index db4e9eea80497..48f2fa0f43c40 100644 --- a/pkg/sql/plan/fulltext.go +++ b/pkg/sql/plan/fulltext.go @@ -156,8 +156,24 @@ func (builder *QueryBuilder) getFullTextSql(fn *tree.FuncExpr, params string) (s return fulltext.PatternToSql(ps, mode, idxtbl, param.Parser, scoreAlgo) } -// select * from index_table, fulltext_index_tokenize(doc_id, concat(body, ' ', title)) -// arg list [params, doc_id, content] +// for table scan, primary key type is passed from TableDef +// select f.* from index_table CROSS APPLY fulltext_index_tokenize('param', doc_id, body, title) as f +// arg list [params, doc_id, part1, part2,...] +// +// for values scan, primary key type is passed from second argument +// arg list [params, pktype, doc_id, part1, part2,...] +// +// select f.* from (select cast(column_0 as bigint) as id, column_1 as body, column_2 as title from (values row(1, 'body content', 'title content'))) as src +// cross apply fulltext_index_tokenize('{"parser":"ngram"}', 23, id, body, title) as f; +// +// for composite primary key, +// +// select f.* from (select serial(cast(column_0 as bigint), cast(column_1 as bigint)) as id, column_2 as body, column_3 as title from +// (values row(1, 2, 'body', 'title'), row(2, 3, 'body is heavy', 'I do not know'))) as src +// cross apply fulltext_index_tokenize('{"parser":"ngram"}', 61, id, body, title) as f; +// +// for composite key, use hex string X'abcd' as input of primary key and skip serial() +// select unhex(hex(serial(cast(0 as smallint), cast(1 as int)))); func (builder *QueryBuilder) buildFullTextIndexTokenize(tbl *tree.TableFunction, ctx *BindContext, exprs []*plan.Expr, children []int32) (int32, error) { if len(exprs) < 3 { @@ -171,18 +187,31 @@ func (builder *QueryBuilder) buildFullTextIndexTokenize(tbl *tree.TableFunction, } scanNode := builder.qry.Nodes[children[0]] - if scanNode.NodeType != plan.Node_TABLE_SCAN { - return 0, moerr.NewNoConfig(builder.GetContext(), "child node is not a TABLE SCAN") - } - - pkPos := scanNode.TableDef.Name2ColIndex[scanNode.TableDef.Pkey.PkeyColName] - pkType := scanNode.TableDef.Cols[pkPos].Typ + if scanNode.NodeType == plan.Node_TABLE_SCAN { + if len(exprs) < 3 { + return 0, moerr.NewInvalidInput(builder.GetContext(), "Invalid number of arguments (NARGS < 3).") + } + pkPos := scanNode.TableDef.Name2ColIndex[scanNode.TableDef.Pkey.PkeyColName] + pkType := scanNode.TableDef.Cols[pkPos].Typ + // set type to source table primary key + colDefs[0].Typ = pkType + // remove the first argment and put the first argument to Param + exprs = exprs[1:] + } else { + // VALUES. First argument is Params and second argument is pkType + if len(exprs) < 4 { + return 0, moerr.NewInvalidInput(builder.GetContext(), "Invalid number of arguments (NARGS < 4).") + } + pkType, err := builder.getFullTextPkeyType(tbl.Func) + if err != nil { + return 0, err + } - // set type to source table primary key - colDefs[0].Typ = pkType + colDefs[0].Typ = pkType + // remove the first two argments and put the first argument to Param + exprs = exprs[2:] - // remove the first argment and put the first argument to Param - exprs = exprs[1:] + } node := &plan.Node{ NodeType: plan.Node_FUNCTION_SCAN, @@ -209,3 +238,16 @@ func (builder *QueryBuilder) getFullTextParams(fn *tree.FuncExpr) (string, error } return "", moerr.NewNoConfig(builder.GetContext(), "first parameter must be string") } + +func (builder *QueryBuilder) getFullTextPkeyType(fn *tree.FuncExpr) (plan.Type, error) { + if v, ok := fn.Exprs[1].(*tree.NumVal); ok { + if t64, ok2 := v.Int64(); ok2 { + return plan.Type{ + Id: int32(t64), + NotNullable: false, + }, nil + } + return plan.Type{}, moerr.NewNoConfig(builder.GetContext(), "second parameter must be int32") + } + return plan.Type{}, moerr.NewNoConfig(builder.GetContext(), "second parameter must be int32") +} diff --git a/pkg/sql/plan/function/func_cast.go b/pkg/sql/plan/function/func_cast.go index f19400fae5f1d..80c61e5428e4b 100644 --- a/pkg/sql/plan/function/func_cast.go +++ b/pkg/sql/plan/function/func_cast.go @@ -4416,6 +4416,8 @@ func strToArray[T types.RealNumbers]( from vector.FunctionParameterWrapper[types.Varlena], to *vector.FunctionResult[types.Varlena], length int, _ types.Type) error { + toType := to.GetType() + var i uint64 var l = uint64(length) for i = 0; i < l; i++ { @@ -4425,11 +4427,18 @@ func strToArray[T types.RealNumbers]( return err } } else { - - b, err := types.StringToArrayToBytes[T](convertByteSliceToString(v)) + arr, err := types.StringToArray[T](convertByteSliceToString(v)) if err != nil { return err } + + // bypass the dimension check if width is max dimension + if int(toType.Width) != types.MaxArrayDimension && int(toType.Width) != len(arr) { + return moerr.NewArrayDefMismatchNoCtx(int(toType.Width), len(arr)) + } + + b := types.ArrayToBytes[T](arr) + if err = to.AppendBytes(b, false); err != nil { return err } diff --git a/pkg/sql/plan/function/func_hnsw.go b/pkg/sql/plan/function/func_hnsw.go new file mode 100644 index 0000000000000..0956936b3d29a --- /dev/null +++ b/pkg/sql/plan/function/func_hnsw.go @@ -0,0 +1,77 @@ +// Copyright 2021 - 2022 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package function + +import ( + "encoding/json" + + "github.com/matrixorigin/matrixone/pkg/common/moerr" + "github.com/matrixorigin/matrixone/pkg/container/vector" + "github.com/matrixorigin/matrixone/pkg/logutil" + "github.com/matrixorigin/matrixone/pkg/vectorindex" + "github.com/matrixorigin/matrixone/pkg/vectorindex/hnsw" + "github.com/matrixorigin/matrixone/pkg/vm/process" +) + +func hnswCdcUpdate(ivecs []*vector.Vector, result vector.FunctionResultWrapper, proc *process.Process, length int, selectList *FunctionSelectList) error { + + if len(ivecs) != 4 { + return moerr.NewInvalidInput(proc.Ctx, "number of arguments != 4") + } + + dbVec := vector.GenerateFunctionStrParameter(ivecs[0]) + tblVec := vector.GenerateFunctionStrParameter(ivecs[1]) + dimVec := vector.GenerateFunctionFixedTypeParameter[int32](ivecs[2]) + cdcVec := vector.GenerateFunctionStrParameter(ivecs[3]) + + for i := uint64(0); i < uint64(length); i++ { + dbname, isnull := dbVec.GetStrValue(i) + if isnull { + return moerr.NewInvalidInput(proc.Ctx, "dbname is null") + } + + tblname, isnull := tblVec.GetStrValue(i) + if isnull { + return moerr.NewInvalidInput(proc.Ctx, "table name is null") + + } + + dim, isnull := dimVec.GetValue(i) + if isnull { + return moerr.NewInvalidInput(proc.Ctx, "dimension is null") + } + + cdcstr, isnull := cdcVec.GetStrValue(i) + if isnull { + return moerr.NewInvalidInput(proc.Ctx, "cdc is null") + } + + var cdc vectorindex.VectorIndexCdc[float32] + err := json.Unmarshal([]byte(cdcstr), &cdc) + if err != nil { + return moerr.NewInvalidInput(proc.Ctx, "cdc is not json object") + } + logutil.Infof("hnsw_cdc_update: START db=%s, table=%s\n", dbname, tblname) + // hnsw sync + //os.Stderr.WriteString(fmt.Sprintf("db=%s, table=%s, dim=%d, json=%s\n", dbname, tblname, dim, cdcstr)) + err = hnsw.CdcSync(proc, string(dbname), string(tblname), dim, &cdc) + if err != nil { + return err + } + logutil.Infof("hnsw_cdc_update: END db=%s, table=%s\n", dbname, tblname) + } + + return nil +} diff --git a/pkg/sql/plan/function/func_hnsw_test.go b/pkg/sql/plan/function/func_hnsw_test.go new file mode 100644 index 0000000000000..4e900513d79ce --- /dev/null +++ b/pkg/sql/plan/function/func_hnsw_test.go @@ -0,0 +1,129 @@ +// Copyright 2021 - 2022 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package function + +import ( + "testing" + + "github.com/matrixorigin/matrixone/pkg/container/types" + "github.com/matrixorigin/matrixone/pkg/testutil" + "github.com/stretchr/testify/require" +) + +func TestHnswCdcUpdateFn(t *testing.T) { + tcs := []tcTemp{ + { + info: "nargs invalid", + inputs: []FunctionTestInput{ + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{true}), + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{false}), + NewFunctionTestInput(types.T_int32.ToType(), + []int32{2}, []bool{false}), + }, + expect: NewFunctionTestResult(types.T_int64.ToType(), true, + []int64{0}, []bool{false}), + }, + + { + info: "dbname null", + inputs: []FunctionTestInput{ + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{true}), + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{false}), + NewFunctionTestInput(types.T_int32.ToType(), + []int32{2}, []bool{false}), + NewFunctionTestInput(types.T_json.ToType(), + []string{""}, []bool{false}), + }, + expect: NewFunctionTestResult(types.T_int64.ToType(), true, + []int64{0}, []bool{false}), + }, + + { + info: "table name null", + inputs: []FunctionTestInput{ + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{false}), + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{true}), + NewFunctionTestInput(types.T_int32.ToType(), + []int32{2}, []bool{false}), + NewFunctionTestInput(types.T_json.ToType(), + []string{""}, []bool{false}), + }, + expect: NewFunctionTestResult(types.T_int64.ToType(), true, + []int64{0}, []bool{false}), + }, + + { + info: "dimension null", + inputs: []FunctionTestInput{ + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{false}), + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{false}), + NewFunctionTestInput(types.T_int32.ToType(), + []int32{0}, []bool{true}), + NewFunctionTestInput(types.T_json.ToType(), + []string{""}, []bool{false}), + }, + expect: NewFunctionTestResult(types.T_int64.ToType(), true, + []int64{0}, []bool{false}), + }, + + { + info: "cdc json null", + inputs: []FunctionTestInput{ + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{false}), + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{false}), + NewFunctionTestInput(types.T_int32.ToType(), + []int32{2}, []bool{false}), + NewFunctionTestInput(types.T_json.ToType(), + []string{""}, []bool{true}), + }, + expect: NewFunctionTestResult(types.T_int64.ToType(), true, + []int64{0}, []bool{false}), + }, + + { + info: "cdc json invalid", + inputs: []FunctionTestInput{ + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{false}), + NewFunctionTestInput(types.T_varchar.ToType(), + []string{""}, []bool{false}), + NewFunctionTestInput(types.T_int32.ToType(), + []int32{2}, []bool{false}), + NewFunctionTestInput(types.T_json.ToType(), + []string{"{..."}, []bool{false}), + }, + expect: NewFunctionTestResult(types.T_int64.ToType(), true, + []int64{0}, []bool{false}), + }, + } + + proc := testutil.NewProcess(t) + for _, tc := range tcs { + fcTC := NewFunctionTestCase(proc, + tc.inputs, tc.expect, hnswCdcUpdate) + s, info := fcTC.Run() + require.True(t, s, info, tc.info) + } +} diff --git a/pkg/sql/plan/function/function_id.go b/pkg/sql/plan/function/function_id.go index 9eeb1090ee828..c30895a9e4e17 100644 --- a/pkg/sql/plan/function/function_id.go +++ b/pkg/sql/plan/function/function_id.go @@ -417,9 +417,12 @@ const ( LLM_CHAT = 347 LLM_EMBEDDING = 348 + // hnsw function + HNSW_CDC_UPDATE = 349 + // FUNCTION_END_NUMBER is not a function, just a flag to record the max number of function. // TODO: every one should put the new function id in front of this one if you want to make a new function. - FUNCTION_END_NUMBER = 349 + FUNCTION_END_NUMBER = 350 ) // functionIdRegister is what function we have registered already. @@ -761,4 +764,7 @@ var functionIdRegister = map[string]int32{ // fault inject function "fault_inject": FAULT_INJECT, + + // hnsw function + "hnsw_cdc_update": HNSW_CDC_UPDATE, } diff --git a/pkg/sql/plan/function/function_id_test.go b/pkg/sql/plan/function/function_id_test.go index 42f0a9ed23e81..8223d6801989a 100644 --- a/pkg/sql/plan/function/function_id_test.go +++ b/pkg/sql/plan/function/function_id_test.go @@ -400,7 +400,9 @@ var predefinedFunids = map[int]int{ LLM_CHAT: 347, LLM_EMBEDDING: 348, - FUNCTION_END_NUMBER: 349, + HNSW_CDC_UPDATE: 349, + + FUNCTION_END_NUMBER: 350, } func Test_funids(t *testing.T) { diff --git a/pkg/sql/plan/function/list_builtIn.go b/pkg/sql/plan/function/list_builtIn.go index 4e272eb93403e..b39439e71d7f7 100644 --- a/pkg/sql/plan/function/list_builtIn.go +++ b/pkg/sql/plan/function/list_builtIn.go @@ -7029,6 +7029,27 @@ var supportedOthersBuiltIns = []FuncNew{ Overloads: fulltext_expand_overload(types.T_float32), }, + + // function `HNSW_CDC_UPDATE` + { + functionId: HNSW_CDC_UPDATE, + class: plan.Function_STRICT, + layout: STANDARD_FUNCTION, + checkFn: fixedTypeMatch, + + Overloads: []overload{ + { + overloadId: 0, + args: []types.T{types.T_varchar, types.T_varchar, types.T_int32, types.T_varchar}, + retType: func(parameters []types.Type) types.Type { + return types.T_uint64.ToType() + }, + newOp: func() executeLogicOfOverload { + return hnswCdcUpdate + }, + }, + }, + }, } // fulltext_match supports varchar, char and text. Expand the function signature to all possible combination of input types diff --git a/pkg/sql/plan/hnsw.go b/pkg/sql/plan/hnsw.go index 587b7dbb5ce84..2053026e4fa3a 100644 --- a/pkg/sql/plan/hnsw.go +++ b/pkg/sql/plan/hnsw.go @@ -69,10 +69,12 @@ func (builder *QueryBuilder) buildHnswCreate(tbl *tree.TableFunction, ctx *BindC return 0, err } - scanNode := builder.qry.Nodes[children[0]] - if scanNode.NodeType != plan.Node_TABLE_SCAN { - return 0, moerr.NewNoConfig(builder.GetContext(), "child node is not a TABLE SCAN") - } + /* + scanNode := builder.qry.Nodes[children[0]] + if scanNode.NodeType != plan.Node_TABLE_SCAN { + return 0, moerr.NewNoConfig(builder.GetContext(), "child node is not a TABLE SCAN") + } + */ // remove the first argment and put the first argument to Param exprs = exprs[1:] diff --git a/pkg/sql/plan/types.go b/pkg/sql/plan/types.go index f00507344eac0..2c3c51c8e4958 100644 --- a/pkg/sql/plan/types.go +++ b/pkg/sql/plan/types.go @@ -476,8 +476,9 @@ type OriginTableMessageForFuzzy struct { } type MultiTableIndex struct { - IndexAlgo string - IndexDefs map[string]*plan.IndexDef + IndexAlgo string + IndexAlgoParams string + IndexDefs map[string]*plan.IndexDef } type RemapInfo struct { diff --git a/pkg/vectorindex/hnsw/build.go b/pkg/vectorindex/hnsw/build.go index b61d42b0216e8..4749ab52c4010 100644 --- a/pkg/vectorindex/hnsw/build.go +++ b/pkg/vectorindex/hnsw/build.go @@ -17,7 +17,6 @@ package hnsw import ( "errors" "fmt" - "math" "os" "strings" "sync" @@ -26,24 +25,13 @@ import ( "github.com/matrixorigin/matrixone/pkg/common/moerr" "github.com/matrixorigin/matrixone/pkg/vectorindex" "github.com/matrixorigin/matrixone/pkg/vm/process" - usearch "github.com/unum-cloud/usearch/golang" ) -// Hnsw Build index implementation -type HnswBuildIndex struct { - Id string - Index *usearch.Index - Path string - Saved bool - Size int64 - MaxCapacity uint -} - type HnswBuild struct { uid string cfg vectorindex.IndexConfig tblcfg vectorindex.IndexTableConfig - indexes []*HnswBuildIndex + indexes []*HnswModel nthread int add_chan chan AddItem err_chan chan error @@ -58,165 +46,6 @@ type AddItem struct { vec []float32 } -// New HnswBuildIndex struct -func NewHnswBuildIndex(id string, cfg vectorindex.IndexConfig, nthread int, max_capacity uint) (*HnswBuildIndex, error) { - var err error - idx := &HnswBuildIndex{} - - idx.Id = id - - idx.Index, err = usearch.NewIndex(cfg.Usearch) - if err != nil { - return nil, err - } - - idx.MaxCapacity = max_capacity - - err = idx.Index.Reserve(idx.MaxCapacity) - if err != nil { - return nil, err - } - - err = idx.Index.ChangeThreadsAdd(uint(nthread)) - if err != nil { - return nil, err - } - return idx, nil -} - -// Destroy the struct -func (idx *HnswBuildIndex) Destroy() error { - if idx.Index != nil { - err := idx.Index.Destroy() - if err != nil { - return err - } - idx.Index = nil - } - - if idx.Saved && len(idx.Path) > 0 { - // remove the file - err := os.Remove(idx.Path) - if err != nil { - return err - } - } - return nil -} - -// Save the index to file -func (idx *HnswBuildIndex) SaveToFile() error { - if idx.Saved { - return nil - } - - f, err := os.CreateTemp("", "hnsw") - if err != nil { - return err - } - - err = idx.Index.Save(f.Name()) - if err != nil { - os.Remove(f.Name()) - return err - } - - // free memory - err = idx.Index.Destroy() - if err != nil { - return err - } - idx.Index = nil - - idx.Saved = true - idx.Path = f.Name() - return nil -} - -// Generate the SQL to update the secondary index tables. -// 1. store the index file into the index table -func (idx *HnswBuildIndex) ToSql(cfg vectorindex.IndexTableConfig) ([]string, error) { - - err := idx.SaveToFile() - if err != nil { - return nil, err - } - - fi, err := os.Stat(idx.Path) - if err != nil { - return nil, err - } - - filesz := fi.Size() - offset := int64(0) - chunksz := int64(0) - chunkid := int64(0) - - idx.Size = filesz - - sqls := make([]string, 0, 5) - - sql := fmt.Sprintf("INSERT INTO `%s`.`%s` VALUES ", cfg.DbName, cfg.IndexTable) - values := make([]string, 0, int64(math.Ceil(float64(filesz)/float64(vectorindex.MaxChunkSize)))) - n := 0 - for offset = 0; offset < filesz; { - if offset+vectorindex.MaxChunkSize < filesz { - chunksz = vectorindex.MaxChunkSize - - } else { - chunksz = filesz - offset - } - - url := fmt.Sprintf("file://%s?offset=%d&size=%d", idx.Path, offset, chunksz) - tuple := fmt.Sprintf("('%s', %d, load_file(cast('%s' as datalink)), 0)", idx.Id, chunkid, url) - values = append(values, tuple) - - // offset and chunksz - offset += chunksz - chunkid++ - - n++ - if n == 10000 { - newsql := sql + strings.Join(values, ", ") - sqls = append(sqls, newsql) - values = values[:0] - n = 0 - } - } - - if len(values) > 0 { - newsql := sql + strings.Join(values, ", ") - sqls = append(sqls, newsql) - } - - //sql += strings.Join(values, ", ") - //return []string{sql}, nil - return sqls, nil -} - -// is the index empty -func (idx *HnswBuildIndex) Empty() (bool, error) { - sz, err := idx.Index.Len() - if err != nil { - return false, err - } - return (sz == 0), nil -} - -// check the index is full, i.e. 10K vectors -func (idx *HnswBuildIndex) Full() (bool, error) { - sz, err := idx.Index.Len() - if err != nil { - return false, err - } - return (sz == idx.MaxCapacity), nil -} - -// add vector to the index -func (idx *HnswBuildIndex) Add(key int64, vec []float32) error { - return idx.Index.Add(uint64(key), vec) -} - // create HsnwBuild struct func NewHnswBuild(proc *process.Process, uid string, nworker int32, cfg vectorindex.IndexConfig, tblcfg vectorindex.IndexTableConfig) (info *HnswBuild, err error) { @@ -239,7 +68,7 @@ func NewHnswBuild(proc *process.Process, uid string, nworker int32, uid: uid, cfg: cfg, tblcfg: tblcfg, - indexes: make([]*HnswBuildIndex, 0, 16), + indexes: make([]*HnswModel, 0, 16), nthread: int(nthread), } @@ -337,18 +166,18 @@ func (h *HnswBuild) createIndexUniqueKey(id int64) string { return fmt.Sprintf("%s:%d", h.uid, id) } -func (h *HnswBuild) getIndexForAddSync() (idx *HnswBuildIndex, save_idx *HnswBuildIndex, err error) { +func (h *HnswBuild) getIndexForAddSync() (idx *HnswModel, save_idx *HnswModel, err error) { h.mutex.Lock() defer h.mutex.Unlock() return h.getIndexForAdd() } -func (h *HnswBuild) getIndexForAdd() (idx *HnswBuildIndex, save_idx *HnswBuildIndex, err error) { +func (h *HnswBuild) getIndexForAdd() (idx *HnswModel, save_idx *HnswModel, err error) { save_idx = nil nidx := int64(len(h.indexes)) if nidx == 0 { - idx, err = NewHnswBuildIndex(h.createIndexUniqueKey(nidx), h.cfg, h.nthread, uint(h.tblcfg.IndexCapacity)) + idx, err = NewHnswModelForBuild(h.createIndexUniqueKey(nidx), h.cfg, h.nthread, uint(h.tblcfg.IndexCapacity)) if err != nil { return nil, nil, err } @@ -363,7 +192,7 @@ func (h *HnswBuild) getIndexForAdd() (idx *HnswBuildIndex, save_idx *HnswBuildIn save_idx = idx // create new index - idx, err = NewHnswBuildIndex(h.createIndexUniqueKey(nidx), h.cfg, h.nthread, uint(h.tblcfg.IndexCapacity)) + idx, err = NewHnswModelForBuild(h.createIndexUniqueKey(nidx), h.cfg, h.nthread, uint(h.tblcfg.IndexCapacity)) if err != nil { return nil, nil, err } @@ -382,8 +211,8 @@ func (h *HnswBuild) getIndexForAdd() (idx *HnswBuildIndex, save_idx *HnswBuildIn // sync version for multi-thread func (h *HnswBuild) addVectorSync(key int64, vec []float32) error { var err error - var idx *HnswBuildIndex - var save_idx *HnswBuildIndex + var idx *HnswModel + var save_idx *HnswModel idx, save_idx, err = h.getIndexForAddSync() if err != nil { @@ -406,8 +235,8 @@ func (h *HnswBuild) addVectorSync(key int64, vec []float32) error { // single-threaded version. func (h *HnswBuild) addVector(key int64, vec []float32) error { var err error - var idx *HnswBuildIndex - var save_idx *HnswBuildIndex + var idx *HnswModel + var save_idx *HnswModel h.mutex.Lock() defer h.mutex.Unlock() @@ -470,6 +299,6 @@ func (h *HnswBuild) ToInsertSql(ts int64) ([]string, error) { return sqls, nil } -func (h *HnswBuild) GetIndexes() []*HnswBuildIndex { +func (h *HnswBuild) GetIndexes() []*HnswModel { return h.indexes } diff --git a/pkg/vectorindex/hnsw/build_test.go b/pkg/vectorindex/hnsw/build_test.go index 9fdfeb7705df9..27dbede5757b5 100644 --- a/pkg/vectorindex/hnsw/build_test.go +++ b/pkg/vectorindex/hnsw/build_test.go @@ -111,9 +111,9 @@ func TestBuildMulti(t *testing.T) { fmt.Printf("load model from files\n") // load index - search.Indexes = make([]*HnswSearchIndex, len(indexes)) + search.Indexes = make([]*HnswModel, len(indexes)) for i, idx := range indexes { - sidx := &HnswSearchIndex{} + sidx := &HnswModel{} sidx.Index, err = usearch.NewIndex(idxcfg.Usearch) require.Nil(t, err) @@ -175,7 +175,7 @@ func TestBuildIndex(t *testing.T) { idxcfg.Usearch.Metric = 100 //tblcfg := vectorindex.IndexTableConfig{DbName: "db", SrcTable: "src", MetadataTable: "__secondary_meta", IndexTable: "__secondary_index"} - idx, err := NewHnswBuildIndex("abc-0", idxcfg, 1, MaxIndexCapacity) + idx, err := NewHnswModelForBuild("abc-0", idxcfg, 1, MaxIndexCapacity) require.Nil(t, err) empty, err := idx.Empty() @@ -275,9 +275,9 @@ func TestBuildSingleThread(t *testing.T) { fmt.Printf("load model from files\n") // load index - search.Indexes = make([]*HnswSearchIndex, len(indexes)) + search.Indexes = make([]*HnswModel, len(indexes)) for i, idx := range indexes { - sidx := &HnswSearchIndex{} + sidx := &HnswModel{} sidx.Index, err = usearch.NewIndex(idxcfg.Usearch) require.Nil(t, err) diff --git a/pkg/vectorindex/hnsw/model.go b/pkg/vectorindex/hnsw/model.go new file mode 100644 index 0000000000000..010a5fa9a3825 --- /dev/null +++ b/pkg/vectorindex/hnsw/model.go @@ -0,0 +1,524 @@ +// Copyright 2022 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package hnsw + +import ( + "fmt" + "io" + "math" + "os" + "strings" + "sync/atomic" + + "github.com/detailyang/go-fallocate" + "github.com/matrixorigin/matrixone/pkg/catalog" + "github.com/matrixorigin/matrixone/pkg/common/moerr" + "github.com/matrixorigin/matrixone/pkg/container/vector" + "github.com/matrixorigin/matrixone/pkg/logutil" + "github.com/matrixorigin/matrixone/pkg/util/executor" + "github.com/matrixorigin/matrixone/pkg/vectorindex" + "github.com/matrixorigin/matrixone/pkg/vm/process" + usearch "github.com/unum-cloud/usearch/golang" +) + +// HnswModel struct - This structure shares with Search, Build and Sync +type HnswModel struct { + Id string + Index *usearch.Index + Path string + FileSize int64 + + // info required for build + MaxCapacity uint + + // from metadata. info required for search + Timestamp int64 + Checksum string + + // for cdc update + Dirty atomic.Bool + View bool + Len atomic.Int64 +} + +// New HnswModel struct +func NewHnswModelForBuild(id string, cfg vectorindex.IndexConfig, nthread int, max_capacity uint) (*HnswModel, error) { + var err error + idx := &HnswModel{} + + idx.Id = id + + idx.Index, err = usearch.NewIndex(cfg.Usearch) + if err != nil { + return nil, err + } + + idx.MaxCapacity = max_capacity + + err = idx.Index.Reserve(idx.MaxCapacity) + if err != nil { + return nil, err + } + + err = idx.Index.ChangeThreadsAdd(uint(nthread)) + if err != nil { + return nil, err + } + + err = idx.Index.ChangeThreadsSearch(uint(nthread)) + if err != nil { + return nil, err + } + return idx, nil +} + +// Destroy the struct +func (idx *HnswModel) Destroy() error { + if idx.Index != nil { + err := idx.Index.Destroy() + if err != nil { + return err + } + idx.Index = nil + } + + if len(idx.Path) > 0 { + // remove the file + if _, err := os.Stat(idx.Path); err == nil || os.IsExist(err) { + err := os.Remove(idx.Path) + if err != nil { + return err + } + } + } + return nil +} + +// Save the index to file +func (idx *HnswModel) SaveToFile() error { + + if idx.Index == nil { + // index is nil. ignore + return nil + } + + if !idx.Dirty.Load() { + // nothing change. ignore + return nil + } + + // delete old file + oldpath := idx.Path + if len(oldpath) > 0 { + // remove the file + if _, err := os.Stat(oldpath); err == nil || os.IsExist(err) { + err := os.Remove(oldpath) + if err != nil { + return err + } + } + } + idx.Path = "" + + empty, err := idx.Empty() + if err != nil { + return err + } + if empty { + // index empty, no file need to save + err = idx.Index.Destroy() + if err != nil { + return err + } + idx.Index = nil + return nil + } + + // save to file + f, err := os.CreateTemp("", "hnsw") + if err != nil { + return err + } + + err = idx.Index.Save(f.Name()) + if err != nil { + os.Remove(f.Name()) + return err + } + + // get new checksum + chksum, err := vectorindex.CheckSum(f.Name()) + if err != nil { + return err + } + idx.Checksum = chksum + + // free memory + err = idx.Index.Destroy() + if err != nil { + return err + } + idx.Index = nil + idx.Path = f.Name() + + return nil +} + +// Generate the SQL to update the secondary index tables. +// 1. store the index file into the index table +func (idx *HnswModel) ToSql(cfg vectorindex.IndexTableConfig) ([]string, error) { + + err := idx.SaveToFile() + if err != nil { + return nil, err + } + + if len(idx.Path) == 0 { + // file path is empty string. No file is written + return []string{}, nil + } + + fi, err := os.Stat(idx.Path) + if err != nil { + return nil, err + } + + filesz := fi.Size() + offset := int64(0) + chunksz := int64(0) + chunkid := int64(0) + + idx.FileSize = filesz + + if idx.FileSize == 0 { + return []string{}, nil + } + + logutil.Infof("HnswModel.ToSql idx %s, len = %d\n", idx.Id, idx.Len.Load()) + + sqls := make([]string, 0, 5) + + sql := fmt.Sprintf("INSERT INTO `%s`.`%s` VALUES ", cfg.DbName, cfg.IndexTable) + values := make([]string, 0, int64(math.Ceil(float64(filesz)/float64(vectorindex.MaxChunkSize)))) + n := 0 + for offset = 0; offset < filesz; { + if offset+vectorindex.MaxChunkSize < filesz { + chunksz = vectorindex.MaxChunkSize + + } else { + chunksz = filesz - offset + } + + url := fmt.Sprintf("file://%s?offset=%d&size=%d", idx.Path, offset, chunksz) + tuple := fmt.Sprintf("('%s', %d, load_file(cast('%s' as datalink)), 0)", idx.Id, chunkid, url) + values = append(values, tuple) + + // offset and chunksz + offset += chunksz + chunkid++ + + n++ + if n == 10000 { + newsql := sql + strings.Join(values, ", ") + sqls = append(sqls, newsql) + values = values[:0] + n = 0 + } + } + + if len(values) > 0 { + newsql := sql + strings.Join(values, ", ") + sqls = append(sqls, newsql) + } + + //sql += strings.Join(values, ", ") + //return []string{sql}, nil + return sqls, nil +} + +func (idx *HnswModel) ToDeleteSql(cfg vectorindex.IndexTableConfig) ([]string, error) { + sqls := make([]string, 0, 2) + + sql := fmt.Sprintf("DELETE FROM `%s`.`%s` WHERE %s = '%s'", cfg.DbName, cfg.IndexTable, catalog.Hnsw_TblCol_Storage_Index_Id, idx.Id) + sqls = append(sqls, sql) + sql = fmt.Sprintf("DELETE FROM `%s`.`%s` WHERE %s = '%s'", cfg.DbName, cfg.MetadataTable, catalog.Hnsw_TblCol_Metadata_Index_Id, idx.Id) + sqls = append(sqls, sql) + + return sqls, nil +} + +// is the index empty +func (idx *HnswModel) Empty() (bool, error) { + if idx.Index == nil { + return false, moerr.NewInternalErrorNoCtx("usearch index is nil") + } + + sz, err := idx.Index.Len() + if err != nil { + return false, err + } + return (sz == 0), nil +} + +// check the index is full, i.e. 10K vectors +func (idx *HnswModel) Full() (bool, error) { + if idx.Index == nil { + return false, moerr.NewInternalErrorNoCtx("usearch index is nil") + } + sz, err := idx.Index.Len() + if err != nil { + return false, err + } + return (sz == idx.MaxCapacity), nil +} + +// add vector to the index +func (idx *HnswModel) Add(key int64, vec []float32) error { + if idx.Index == nil { + return moerr.NewInternalErrorNoCtx("usearch index is nil") + } + idx.Dirty.Store(true) + idx.Len.Add(1) + return idx.Index.Add(uint64(key), vec) +} + +// add vector without increment the counter. concurrency add will increment the counter before Add +func (idx *HnswModel) AddWithoutIncr(key int64, vec []float32) error { + if idx.Index == nil { + return moerr.NewInternalErrorNoCtx("usearch index is nil") + } + idx.Dirty.Store(true) + //idx.Len.Add(1) + return idx.Index.Add(uint64(key), vec) +} + +// remove key +func (idx *HnswModel) Remove(key int64) error { + if idx.Index == nil { + return moerr.NewInternalErrorNoCtx("usearch index is nil") + } + idx.Dirty.Store(true) + idx.Len.Add(-1) + return idx.Index.Remove(uint64(key)) +} + +// contains key +func (idx *HnswModel) Contains(key int64) (found bool, err error) { + if idx.Index == nil { + return false, moerr.NewInternalErrorNoCtx("usearch index is nil") + } + return idx.Index.Contains(uint64(key)) +} + +// load chunk from database +func (idx *HnswModel) loadChunk(proc *process.Process, stream_chan chan executor.Result, error_chan chan error, fp *os.File) (stream_closed bool, err error) { + var res executor.Result + var ok bool + + select { + case res, ok = <-stream_chan: + if !ok { + return true, nil + } + case err = <-error_chan: + return false, err + case <-proc.Ctx.Done(): + return false, moerr.NewInternalError(proc.Ctx, "context cancelled") + } + + bat := res.Batches[0] + defer res.Close() + + for i := 0; i < bat.RowCount(); i++ { + chunk_id := vector.GetFixedAtWithTypeCheck[int64](bat.Vecs[0], i) + data := bat.Vecs[1].GetRawBytesAt(i) + + offset := chunk_id * vectorindex.MaxChunkSize + _, err = fp.Seek(offset, io.SeekStart) + if err != nil { + return false, err + } + + _, err = fp.Write(data) + if err != nil { + return false, err + } + } + return false, nil +} + +// load index from database +// TODO: loading file is tricky. +// 1. we need to know the size of the file. +// 2. Write Zero to file to have a pre-allocated size +// 3. SELECT chunk_id, data from index_table WHERE index_id = id. Result will be out of order +// 4. according to the chunk_id, seek to the offset and write the chunk +// 5. check the checksum to verify the correctness of the file +func (idx *HnswModel) LoadIndex(proc *process.Process, idxcfg vectorindex.IndexConfig, tblcfg vectorindex.IndexTableConfig, nthread int64, view bool) error { + + if idx.Index != nil { + // index already loaded. ignore + return nil + + } + + stream_chan := make(chan executor.Result, 2) + error_chan := make(chan error) + + if len(idx.Path) == 0 { + // create tempfile for writing + fp, err := os.CreateTemp("", "hnsw") + if err != nil { + return err + } + + // load index to memory + defer func() { + if view { + // if view == true, remove the file. right now view equals to read-only model when search. + // since model loads into memory anyway, we can safely remove the file after load. + // NOTE: when choose to load with usearch.View() mmap(), we cannot remove this file. + // for update, we need this file for Load() and unload(). + os.Remove(fp.Name()) + } + }() + + err = fallocate.Fallocate(fp, 0, idx.FileSize) + if err != nil { + fp.Close() + return err + } + + // run streaming sql + sql := fmt.Sprintf("SELECT chunk_id, data from `%s`.`%s` WHERE index_id = '%s'", tblcfg.DbName, tblcfg.IndexTable, idx.Id) + go func() { + _, err := runSql_streaming(proc, sql, stream_chan, error_chan) + if err != nil { + error_chan <- err + return + } + }() + + // incremental load from database + sql_closed := false + for !sql_closed { + sql_closed, err = idx.loadChunk(proc, stream_chan, error_chan, fp) + if err != nil { + fp.Close() + return err + } + } + + idx.Path = fp.Name() + fp.Close() + } + + // check checksum + chksum, err := vectorindex.CheckSum(idx.Path) + if err != nil { + return err + } + if chksum != idx.Checksum { + return moerr.NewInternalError(proc.Ctx, "Checksum mismatch with the index file") + } + + usearchidx, err := usearch.NewIndex(idxcfg.Usearch) + if err != nil { + return err + } + + err = usearchidx.ChangeThreadsSearch(uint(nthread)) + if err != nil { + return err + } + + err = usearchidx.ChangeThreadsAdd(uint(nthread)) + if err != nil { + return err + } + + if view { + err = usearchidx.Load(idx.Path) + idx.View = true + } else { + err = usearchidx.Load(idx.Path) + usearchidx.Reserve(uint(tblcfg.IndexCapacity)) + } + if err != nil { + return err + } + + // always get the number of item and capacity when model loaded. + idx.Index = usearchidx + idxLen, err := idx.Index.Len() + if err != nil { + return err + } + idx.Len.Store(int64(idxLen)) + + logutil.Debugf("HnswModel.LoadIndex idx %s, len = %d\n", idx.Id, idxLen) + + idx.MaxCapacity, err = idx.Index.Capacity() + if err != nil { + return err + } + + if !view { + // sometimes Reserve() will give bigger capacity than requested + if idx.MaxCapacity > uint(tblcfg.IndexCapacity) { + idx.MaxCapacity = uint(tblcfg.IndexCapacity) + } + } + + return nil +} + +// unload +func (idx *HnswModel) Unload() error { + if idx.Index == nil { + return moerr.NewInternalErrorNoCtx("usearch index is nil") + } + + idxLen, err := idx.Index.Len() + if err != nil { + return err + } + logutil.Debugf("HnswModel.Unload idx %s, len = %d\n", idx.Id, idxLen) + + // SaveToFile will check Dirty bit. If dirty is true, save to file before unload + err = idx.SaveToFile() + if err != nil { + return err + } + + // SaveToFile will release the usearch index when dirty is true so always check nil index + if idx.Index != nil { + err := idx.Index.Destroy() + if err != nil { + return err + } + // reset variable + idx.Index = nil + } + return nil +} + +// Call usearch.Search +func (idx *HnswModel) Search(query []float32, limit uint) (keys []usearch.Key, distances []float32, err error) { + if idx.Index == nil { + return nil, nil, moerr.NewInternalErrorNoCtx("usearch index is nil") + } + return idx.Index.Search(query, limit) +} diff --git a/pkg/vectorindex/hnsw/model_test.go b/pkg/vectorindex/hnsw/model_test.go new file mode 100644 index 0000000000000..531fadb133ac5 --- /dev/null +++ b/pkg/vectorindex/hnsw/model_test.go @@ -0,0 +1,206 @@ +// Copyright 2022 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package hnsw + +import ( + "fmt" + "testing" + + "github.com/matrixorigin/matrixone/pkg/common/mpool" + "github.com/matrixorigin/matrixone/pkg/testutil" + "github.com/matrixorigin/matrixone/pkg/vectorindex" + "github.com/stretchr/testify/require" + + usearch "github.com/unum-cloud/usearch/golang" +) + +/* +// give metadata [index_id, checksum, timestamp] +func mock_runSql(proc *process.Process, sql string) (executor.Result, error) { + + return executor.Result{Mp: proc.Mp(), Batches: []*batch.Batch{makeMetaBatch(proc)}}, nil +} + +// give blob +func mock_runSql_streaming(proc *process.Process, sql string, ch chan executor.Result, err_chan chan error) (executor.Result, error) { + + defer close(ch) + res := executor.Result{Mp: proc.Mp(), Batches: []*batch.Batch{makeIndexBatch(proc)}} + ch <- res + return executor.Result{}, nil +} +*/ + +func doModelSearchTest(t *testing.T, idx *HnswModel, key uint64, v []float32) { + keys, distances, err := idx.Search(v, 4) + require.Nil(t, err) + require.Equal(t, len(keys), 4) + require.Equal(t, keys[0], key) + require.Equal(t, distances[0], float32(0)) + fmt.Printf("%v %v\n", keys, distances) + +} + +func TestModel(t *testing.T) { + var err error + fp32a := []float32{0, 1, 2} + v1000 := []float32{1000, 2000, 3000} + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + // stub runSql function + runSql = mock_runSql + runSql_streaming = mock_runSql_streaming + + models, err := LoadMetadata(proc, "db", "meta") + require.Nil(t, err) + + idxcfg := vectorindex.IndexConfig{Type: "hnsw", Usearch: usearch.DefaultConfig(3)} + idxcfg.Usearch.Metric = usearch.L2sq + tblcfg := vectorindex.IndexTableConfig{DbName: "db", SrcTable: "src", MetadataTable: "__secondary_meta", IndexTable: "__secondary_index"} + + require.Equal(t, len(models), 1) + idx := models[0] + defer idx.Destroy() + + err = idx.LoadIndex(proc, idxcfg, tblcfg, 0, false) + require.Nil(t, err) + + doModelSearchTest(t, idx, 0, fp32a) + + require.Equal(t, idx.Dirty.Load(), false) + + err = idx.Unload() + require.Nil(t, err) + + err = idx.LoadIndex(proc, idxcfg, tblcfg, 0, false) + require.Nil(t, err) + + doModelSearchTest(t, idx, 0, fp32a) + + var found bool + found, err = idx.Contains(0) + require.Nil(t, err) + require.Equal(t, found, true) + + found, err = idx.Contains(1000) + require.Nil(t, err) + require.Equal(t, found, false) + + key := int64(1000) + v := v1000 + full := false + empty := false + + for i := 0; i < 10; i++ { + full, err = idx.Full() + require.Nil(t, err) + require.Equal(t, full, false) + + empty, err = idx.Empty() + require.Nil(t, err) + require.Equal(t, empty, false) + + err = idx.Add(int64(key), v) + require.Nil(t, err) + + require.Equal(t, idx.Dirty.Load(), true) + + err = idx.Unload() + require.Nil(t, err) + + err = idx.LoadIndex(proc, idxcfg, tblcfg, 0, false) + require.Nil(t, err) + + doModelSearchTest(t, idx, uint64(key), v) + + key += 1 + v[0] += 1 + } + + // reset vector to [1000, 2000, 3000] + key = int64(1000) + v[0] = 1000 + + for i := 0; i < 10; i++ { + err = idx.Remove(key) + require.Nil(t, err) + key += 1 + } + + deletesqls, err := idx.ToDeleteSql(tblcfg) + require.Nil(t, err) + + fmt.Printf("%v\n", deletesqls) + + // ToSql will release the index so index is nil + sqls, err := idx.ToSql(tblcfg) + require.Nil(t, err) + fmt.Printf("%v\n", sqls) + + // unload with nil index will output error + err = idx.Unload() + require.NotNil(t, err) + + // load again + err = idx.LoadIndex(proc, idxcfg, tblcfg, 0, false) + require.Nil(t, err) + + key = int64(1000) + for i := 0; i < 10; i++ { + found, err = idx.Contains(key) + require.Nil(t, err) + require.Equal(t, found, false) + key += 1 + } + +} + +func TestModelNil(t *testing.T) { + + var err error + var tblcfg vectorindex.IndexTableConfig + + idx := HnswModel{} + err = idx.SaveToFile() + require.Nil(t, err) + + sqls, err := idx.ToSql(tblcfg) + require.Nil(t, err) + require.Equal(t, len(sqls), 0) + + _, err = idx.Empty() + require.NotNil(t, err) + + _, err = idx.Full() + require.NotNil(t, err) + + err = idx.Add(0, nil) + require.NotNil(t, err) + + err = idx.Remove(0) + require.NotNil(t, err) + + _, err = idx.Contains(0) + require.NotNil(t, err) + + err = idx.Unload() + require.NotNil(t, err) + + _, _, err = idx.Search(nil, 0) + require.NotNil(t, err) + +} diff --git a/pkg/vectorindex/hnsw/search.go b/pkg/vectorindex/hnsw/search.go index 70a4ed98b9776..4094e41430ac5 100644 --- a/pkg/vectorindex/hnsw/search.go +++ b/pkg/vectorindex/hnsw/search.go @@ -17,164 +17,31 @@ package hnsw import ( "errors" "fmt" - "io" - "os" "sync" "sync/atomic" - "github.com/detailyang/go-fallocate" "github.com/matrixorigin/matrixone/pkg/common/moerr" "github.com/matrixorigin/matrixone/pkg/container/vector" - "github.com/matrixorigin/matrixone/pkg/util/executor" "github.com/matrixorigin/matrixone/pkg/vectorindex" "github.com/matrixorigin/matrixone/pkg/vectorindex/cache" "github.com/matrixorigin/matrixone/pkg/vectorindex/sqlexec" "github.com/matrixorigin/matrixone/pkg/vm/process" - - usearch "github.com/unum-cloud/usearch/golang" ) var runSql = sqlexec.RunSql var runSql_streaming = sqlexec.RunStreamingSql -// Hnsw search index struct to hold the usearch index -type HnswSearchIndex struct { - Id string - Path string - Index *usearch.Index - Timestamp int64 - Checksum string - Filesize int64 -} - // This is the HNSW search implementation that implement VectorIndexSearchIf interface type HnswSearch struct { Idxcfg vectorindex.IndexConfig Tblcfg vectorindex.IndexTableConfig - Indexes []*HnswSearchIndex + Indexes []*HnswModel Concurrency atomic.Int64 Mutex sync.Mutex Cond *sync.Cond ThreadsSearch int64 } -// load chunk from database -func (idx *HnswSearchIndex) loadChunk(proc *process.Process, stream_chan chan executor.Result, error_chan chan error, fp *os.File) (stream_closed bool, err error) { - var res executor.Result - var ok bool - - select { - case res, ok = <-stream_chan: - if !ok { - return true, nil - } - case err = <-error_chan: - return false, err - case <-proc.Ctx.Done(): - return false, moerr.NewInternalError(proc.Ctx, "context cancelled") - } - - bat := res.Batches[0] - defer res.Close() - - for i := 0; i < bat.RowCount(); i++ { - chunk_id := vector.GetFixedAtWithTypeCheck[int64](bat.Vecs[0], i) - data := bat.Vecs[1].GetRawBytesAt(i) - - offset := chunk_id * vectorindex.MaxChunkSize - _, err = fp.Seek(offset, io.SeekStart) - if err != nil { - return false, err - } - - _, err = fp.Write(data) - if err != nil { - return false, err - } - } - return false, nil -} - -// load index from database -// TODO: loading file is tricky. -// 1. we need to know the size of the file. -// 2. Write Zero to file to have a pre-allocated size -// 3. SELECT chunk_id, data from index_table WHERE index_id = id. Result will be out of order -// 4. according to the chunk_id, seek to the offset and write the chunk -// 5. check the checksum to verify the correctness of the file -func (idx *HnswSearchIndex) LoadIndex(proc *process.Process, idxcfg vectorindex.IndexConfig, tblcfg vectorindex.IndexTableConfig, nthread int64) error { - - stream_chan := make(chan executor.Result, 2) - error_chan := make(chan error) - - // create tempfile for writing - fp, err := os.CreateTemp("", "hnswindx") - if err != nil { - return err - } - defer os.Remove(fp.Name()) - - err = fallocate.Fallocate(fp, 0, idx.Filesize) - if err != nil { - return err - } - - // run streaming sql - sql := fmt.Sprintf("SELECT chunk_id, data from `%s`.`%s` WHERE index_id = '%s'", tblcfg.DbName, tblcfg.IndexTable, idx.Id) - go func() { - _, err := runSql_streaming(proc, sql, stream_chan, error_chan) - if err != nil { - error_chan <- err - return - } - }() - - // incremental load from database - sql_closed := false - for !sql_closed { - sql_closed, err = idx.loadChunk(proc, stream_chan, error_chan, fp) - if err != nil { - return err - } - } - - // load index to memory - fp.Close() - - // check checksum - chksum, err := vectorindex.CheckSum(fp.Name()) - if err != nil { - return err - } - if chksum != idx.Checksum { - return moerr.NewInternalError(proc.Ctx, "Checksum mismatch with the index file") - } - - usearchidx, err := usearch.NewIndex(idxcfg.Usearch) - if err != nil { - return err - } - - err = usearchidx.ChangeThreadsSearch(uint(nthread)) - if err != nil { - return err - } - - err = usearchidx.Load(fp.Name()) - if err != nil { - return err - } - - idx.Index = usearchidx - - return nil -} - -// Call usearch.Search -func (idx *HnswSearchIndex) Search(query []float32, limit uint) (keys []usearch.Key, distances []float32, err error) { - return idx.Index.Search(query, limit) -} - func NewHnswSearch(idxcfg vectorindex.IndexConfig, tblcfg vectorindex.IndexTableConfig) *HnswSearch { nthread := vectorindex.GetConcurrency(tblcfg.ThreadsSearch) s := &HnswSearch{Idxcfg: idxcfg, Tblcfg: tblcfg, ThreadsSearch: nthread} @@ -300,9 +167,9 @@ func (s *HnswSearch) Destroy() { } // load metadata from database -func (s *HnswSearch) LoadMetadata(proc *process.Process) ([]*HnswSearchIndex, error) { +func LoadMetadata(proc *process.Process, dbname string, metatbl string) ([]*HnswModel, error) { - sql := fmt.Sprintf("SELECT * FROM `%s`.`%s`", s.Tblcfg.DbName, s.Tblcfg.MetadataTable) + sql := fmt.Sprintf("SELECT * FROM `%s`.`%s` ORDER BY timestamp ASC", dbname, metatbl) res, err := runSql(proc, sql) if err != nil { return nil, err @@ -314,7 +181,7 @@ func (s *HnswSearch) LoadMetadata(proc *process.Process) ([]*HnswSearchIndex, er total += bat.RowCount() } - indexes := make([]*HnswSearchIndex, 0, total) + indexes := make([]*HnswModel, 0, total) for _, bat := range res.Batches { idVec := bat.Vecs[0] chksumVec := bat.Vecs[1] @@ -326,7 +193,7 @@ func (s *HnswSearch) LoadMetadata(proc *process.Process) ([]*HnswSearchIndex, er ts := vector.GetFixedAtWithTypeCheck[int64](tsVec, i) fs := vector.GetFixedAtWithTypeCheck[int64](fsVec, i) - idx := &HnswSearchIndex{Id: id, Checksum: chksum, Timestamp: ts, Filesize: fs} + idx := &HnswModel{Id: id, Checksum: chksum, Timestamp: ts, FileSize: fs} indexes = append(indexes, idx) } } @@ -335,10 +202,10 @@ func (s *HnswSearch) LoadMetadata(proc *process.Process) ([]*HnswSearchIndex, er } // load index from database -func (s *HnswSearch) LoadIndex(proc *process.Process, indexes []*HnswSearchIndex) ([]*HnswSearchIndex, error) { +func (s *HnswSearch) LoadIndex(proc *process.Process, indexes []*HnswModel) ([]*HnswModel, error) { for _, idx := range indexes { - err := idx.LoadIndex(proc, s.Idxcfg, s.Tblcfg, s.ThreadsSearch) + err := idx.LoadIndex(proc, s.Idxcfg, s.Tblcfg, s.ThreadsSearch, true) if err != nil { return nil, err } @@ -349,7 +216,7 @@ func (s *HnswSearch) LoadIndex(proc *process.Process, indexes []*HnswSearchIndex // load index from database (implement VectorIndexSearch.LoadFromDatabase) func (s *HnswSearch) Load(proc *process.Process) error { // load metadata - indexes, err := s.LoadMetadata(proc) + indexes, err := LoadMetadata(proc, s.Tblcfg.DbName, s.Tblcfg.MetadataTable) if err != nil { return err } diff --git a/pkg/vectorindex/hnsw/search_test.go b/pkg/vectorindex/hnsw/search_test.go index 4d36e43761602..19d09bb75a621 100644 --- a/pkg/vectorindex/hnsw/search_test.go +++ b/pkg/vectorindex/hnsw/search_test.go @@ -15,13 +15,16 @@ package hnsw import ( + "fmt" "os" + "strings" "sync" "testing" "time" fallocate "github.com/detailyang/go-fallocate" + "github.com/matrixorigin/matrixone/pkg/catalog" "github.com/matrixorigin/matrixone/pkg/common/mpool" "github.com/matrixorigin/matrixone/pkg/container/batch" "github.com/matrixorigin/matrixone/pkg/container/types" @@ -51,6 +54,33 @@ func mock_runSql_streaming(proc *process.Process, sql string, ch chan executor.R return executor.Result{}, nil } +// give metadata [index_id, checksum, timestamp] +func mock_runSql_2files(proc *process.Process, sql string) (executor.Result, error) { + + return executor.Result{Mp: proc.Mp(), Batches: []*batch.Batch{makeMetaBatch2Files(proc)}}, nil +} + +// give blob +func mock_runSql_streaming_2files(proc *process.Process, sql string, ch chan executor.Result, err_chan chan error) (executor.Result, error) { + + fmt.Printf("SQL %s\n", sql) + idx := 0 + if strings.Contains(sql, "abc-1") { + idx = 1 + } + + defer close(ch) + res := executor.Result{Mp: proc.Mp(), Batches: []*batch.Batch{makeIndexBatch2Files(proc, idx)}} + ch <- res + return executor.Result{}, nil +} + +// give moindexes metadata [index_table_name, algo_table_type, algo_params, column_name] +func mock_runCatalogSql(proc *process.Process, sql string) (executor.Result, error) { + + return executor.Result{Mp: proc.Mp(), Batches: []*batch.Batch{makeMoIndexesBatch(proc)}}, nil +} + func TestHnsw(t *testing.T) { m := mpool.MustNewZero() proc := testutil.NewProcessWithMPool(t, "", m) @@ -151,3 +181,79 @@ func TestFallocate(t *testing.T) { fallocate.Fallocate(f, 0, 10000) f.Close() } + +func makeMoIndexesBatch(proc *process.Process) *batch.Batch { + //param := "{\"op_type\": \"vector_l2_ops\", \"m\":\"128\",\"ef_construction\":\"256\", \"ef_search\":\"100\"}" + param := "{\"op_type\": \"vector_l2_ops\"}" + bat := batch.NewWithSize(4) + bat.Vecs[0] = vector.NewVec(types.New(types.T_varchar, 128, 0)) // index_table_name + bat.Vecs[1] = vector.NewVec(types.New(types.T_varchar, 128, 0)) // alog_table_type + bat.Vecs[2] = vector.NewVec(types.New(types.T_varchar, 128, 0)) // algo_params + bat.Vecs[3] = vector.NewVec(types.New(types.T_varchar, 128, 0)) // colname_name + + // metadata + vector.AppendBytes(bat.Vecs[0], []byte("__meta"), false, proc.Mp()) + vector.AppendBytes(bat.Vecs[1], []byte(catalog.Hnsw_TblType_Metadata), false, proc.Mp()) + vector.AppendBytes(bat.Vecs[2], []byte(param), false, proc.Mp()) + vector.AppendBytes(bat.Vecs[3], []byte("embed"), false, proc.Mp()) + + // storage + vector.AppendBytes(bat.Vecs[0], []byte("__storage"), false, proc.Mp()) + vector.AppendBytes(bat.Vecs[1], []byte(catalog.Hnsw_TblType_Storage), false, proc.Mp()) + vector.AppendBytes(bat.Vecs[2], []byte(param), false, proc.Mp()) + vector.AppendBytes(bat.Vecs[3], []byte("embed"), false, proc.Mp()) + + bat.SetRowCount(2) + return bat +} + +func makeMetaBatch2Files(proc *process.Process) *batch.Batch { + indexfiles := []string{"resources/hnsw0.bin", "resources/hnsw1.bin"} + ids := []string{"abc-0", "abc-1"} + + bat := batch.NewWithSize(4) + bat.Vecs[0] = vector.NewVec(types.New(types.T_varchar, 128, 0)) // index_id + bat.Vecs[1] = vector.NewVec(types.New(types.T_varchar, 65536, 0)) // checksum + bat.Vecs[2] = vector.NewVec(types.New(types.T_int64, 8, 0)) // timestamp + bat.Vecs[3] = vector.NewVec(types.New(types.T_int64, 8, 0)) // timestamp + + for i, indexfile := range indexfiles { + + vector.AppendBytes(bat.Vecs[0], []byte(ids[i]), false, proc.Mp()) + chksum, err := vectorindex.CheckSum(indexfile) + if err != nil { + panic("file checksum error") + } + + finfo, err := os.Stat(indexfile) + if err != nil { + panic("file not found") + } + + vector.AppendBytes(bat.Vecs[1], []byte(chksum), false, proc.Mp()) + vector.AppendFixed[int64](bat.Vecs[2], int64(0), false, proc.Mp()) + vector.AppendFixed[int64](bat.Vecs[3], finfo.Size(), false, proc.Mp()) + + } + + bat.SetRowCount(len(indexfiles)) + return bat +} + +func makeIndexBatch2Files(proc *process.Process, id int) *batch.Batch { + indexfiles := []string{"resources/hnsw0.bin", "resources/hnsw1.bin"} + indexfile := indexfiles[id] + + bat := batch.NewWithSize(2) + bat.Vecs[0] = vector.NewVec(types.New(types.T_int64, 8, 0)) // chunk_id + bat.Vecs[1] = vector.NewVec(types.New(types.T_blob, 65536, 0)) // data + + dat, err := os.ReadFile(indexfile) + if err != nil { + panic("read file error") + } + vector.AppendFixed[int64](bat.Vecs[0], int64(0), false, proc.Mp()) + vector.AppendBytes(bat.Vecs[1], dat, false, proc.Mp()) + bat.SetRowCount(1) + return bat +} diff --git a/pkg/vectorindex/hnsw/sync.go b/pkg/vectorindex/hnsw/sync.go new file mode 100644 index 0000000000000..ae01e67751a1f --- /dev/null +++ b/pkg/vectorindex/hnsw/sync.go @@ -0,0 +1,669 @@ +// Copyright 2022 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package hnsw + +import ( + "encoding/json" + "fmt" + "os" + "strconv" + "strings" + "sync" + "sync/atomic" + "time" + + "github.com/matrixorigin/matrixone/pkg/catalog" + "github.com/matrixorigin/matrixone/pkg/common/moerr" + "github.com/matrixorigin/matrixone/pkg/logutil" + "github.com/matrixorigin/matrixone/pkg/util/executor" + "github.com/matrixorigin/matrixone/pkg/vectorindex" + veccache "github.com/matrixorigin/matrixone/pkg/vectorindex/cache" + "github.com/matrixorigin/matrixone/pkg/vectorindex/metric" + "github.com/matrixorigin/matrixone/pkg/vectorindex/sqlexec" + "github.com/matrixorigin/matrixone/pkg/vm/process" +) + +// CdcSync is the main function to update hnsw index via CDC. SQL function hnsw_cdc_update() will call this function. + +const ( + catalogsql = "select index_table_name, algo_table_type, algo_params, column_name from mo_catalog.mo_indexes where table_id = (select rel_id from mo_catalog.mo_tables where relname = '%s' and reldatabase = '%s') and algo='hnsw';" +) + +var runTxn = sqlexec.RunTxn +var runCatalogSql = sqlexec.RunSql + +func CdcSync(proc *process.Process, db string, tbl string, dimension int32, cdc *vectorindex.VectorIndexCdc[float32]) error { + + // get index catalog + sql := fmt.Sprintf(catalogsql, tbl, db) + res, err := runCatalogSql(proc, sql) + if err != nil { + return err + } + defer res.Close() + + //os.Stderr.WriteString(sql) + + if len(res.Batches) == 0 { + return nil + } + + bat := res.Batches[0] + + idxtblvec := bat.Vecs[0] + algotypevec := bat.Vecs[1] + paramvec := bat.Vecs[2] + colvec := bat.Vecs[3] + + var idxtblcfg vectorindex.IndexTableConfig + var param vectorindex.HnswParam + + idxtblcfg.DbName = db + idxtblcfg.SrcTable = tbl + + // GetResolveVariableFunc() is nil because of internal SQL proc don't have ResolveVariableFunc(). + if proc.GetResolveVariableFunc() != nil { + val, err := proc.GetResolveVariableFunc()("hnsw_threads_build", true, false) + if err != nil { + return err + } + idxtblcfg.ThreadsBuild = vectorindex.GetConcurrencyForBuild(val.(int64)) + + idxcap, err := proc.GetResolveVariableFunc()("hnsw_max_index_capacity", true, false) + if err != nil { + return err + } + idxtblcfg.IndexCapacity = idxcap.(int64) + } else { + + idxtblcfg.ThreadsBuild = vectorindex.GetConcurrencyForBuild(0) + idxtblcfg.IndexCapacity = 1000000 + } + + for i := 0; i < bat.RowCount(); i++ { + + idxtbl := idxtblvec.UnsafeGetStringAt(i) + algotyp := algotypevec.UnsafeGetStringAt(i) + + if i == 0 { + paramstr := paramvec.UnsafeGetStringAt(i) + cname := colvec.UnsafeGetStringAt(i) + //os.Stderr.WriteString(fmt.Sprintf("idxtbl %s, type %s, param %s, cname %s\n", idxtbl, algotyp, paramstr, cname)) + idxtblcfg.KeyPart = cname + if len(paramstr) > 0 { + err := json.Unmarshal([]byte(paramstr), ¶m) + if err != nil { + return err + } + } + } + + if algotyp == catalog.Hnsw_TblType_Metadata { + idxtblcfg.MetadataTable = idxtbl + + } else if algotyp == catalog.Hnsw_TblType_Storage { + idxtblcfg.IndexTable = idxtbl + + } + } + + var idxcfg vectorindex.IndexConfig + idxcfg.Type = "hnsw" + + idxcfg.Usearch.Dimensions = uint(dimension) + + if len(param.Quantization) > 0 { + var ok bool + idxcfg.Usearch.Quantization, ok = vectorindex.QuantizationValid(param.Quantization) + if !ok { + return moerr.NewInternalError(proc.Ctx, "Invalid quantization value") + + } + } + + if len(param.M) > 0 { + val, err := strconv.Atoi(param.M) + if err != nil { + return err + } + idxcfg.Usearch.Connectivity = uint(val) + } + + // default L2Sq + metrictype, ok := metric.OpTypeToUsearchMetric[param.OpType] + if !ok { + return moerr.NewInternalError(proc.Ctx, "Invalid op_type") + } + idxcfg.Usearch.Metric = metrictype + + if len(param.EfConstruction) > 0 { + val, err := strconv.Atoi(param.EfConstruction) + if err != nil { + return err + } + idxcfg.Usearch.ExpansionAdd = uint(val) + } + // ef_search + if len(param.EfSearch) > 0 { + val, err := strconv.Atoi(param.EfSearch) + if err != nil { + return err + } + idxcfg.Usearch.ExpansionSearch = uint(val) + } + + //os.Stderr.WriteString(fmt.Sprintf("idxtblcfg: %v\n", idxtblcfg)) + //os.Stderr.WriteString(fmt.Sprintf("idxcfg: %v\n", idxcfg)) + + // load metadata + indexes, err := LoadMetadata(proc, idxtblcfg.DbName, idxtblcfg.MetadataTable) + if err != nil { + return err + } + + // assume CDC run in single thread + // model id for CDC is cdc:1:0:timestamp + uid := fmt.Sprintf("%s:%d:%d", "cdc", 1, 0) + ts := time.Now().Unix() + sync := &HnswSync{indexes: indexes, idxcfg: idxcfg, tblcfg: idxtblcfg, cdc: cdc, uid: uid, ts: ts} + defer sync.destroy() + err = sync.run(proc) + if err != nil { + return err + } + + // clear the cache (it only work in standalone mode though) + veccache.Cache.Remove(idxtblcfg.IndexTable) + + return nil +} + +type HnswSync struct { + indexes []*HnswModel + idxcfg vectorindex.IndexConfig + tblcfg vectorindex.IndexTableConfig + cdc *vectorindex.VectorIndexCdc[float32] + uid string + ts int64 + ninsert atomic.Int32 + ndelete atomic.Int32 + nupdate atomic.Int32 + current *HnswModel + last *HnswModel +} + +func (s *HnswSync) destroy() { + for _, m := range s.indexes { + m.Destroy() + } + s.indexes = nil +} + +func (s *HnswSync) checkContains(proc *process.Process) (maxcap uint, midx []int, err error) { + err_chan := make(chan error, s.tblcfg.ThreadsBuild) + + maxcap = uint(s.tblcfg.IndexCapacity) + + // try to find index cap + cdclen := len(s.cdc.Data) + + midx = make([]int, cdclen) + // reset idx to -1 + for i := range midx { + midx[i] = -1 + } + + // find corresponding indexes + for i, m := range s.indexes { + err = m.LoadIndex(proc, s.idxcfg, s.tblcfg, s.tblcfg.ThreadsBuild, false) + if err != nil { + return 0, nil, err + } + + if maxcap < m.MaxCapacity { + maxcap = m.MaxCapacity + } + + var wg sync.WaitGroup + + nthread := int(s.tblcfg.ThreadsBuild) + for k := 0; k < nthread; k++ { + wg.Add(1) + go func(tid int) { + defer wg.Done() + for j, row := range s.cdc.Data { + + if j%nthread != tid { + continue + } + + switch row.Type { + case vectorindex.CDC_UPSERT, vectorindex.CDC_DELETE: + if midx[j] == -1 { + found, err := m.Contains(row.PKey) + if err != nil { + err_chan <- err + return + } + if found { + //os.Stderr.WriteString(fmt.Sprintf("searching... found model %d row %d\n", i, j)) + midx[j] = i + + if row.Type == vectorindex.CDC_UPSERT { + s.nupdate.Add(1) + } else { + s.ndelete.Add(1) + } + } + } + } + + } + }(k) + } + + wg.Wait() + if len(err_chan) > 0 { + return 0, nil, <-err_chan + } + + m.Unload() + } + + return maxcap, midx, nil +} + +func (s *HnswSync) insertAllInParallel(proc *process.Process, maxcap uint) error { + var mu sync.Mutex + var wg sync.WaitGroup + err_chan := make(chan error, s.tblcfg.ThreadsBuild) + + nthread := int(s.tblcfg.ThreadsBuild) + for i := 0; i < nthread; i++ { + wg.Add(1) + go func(tid int) { + defer wg.Done() + + for j, row := range s.cdc.Data { + + if j%nthread != tid { + continue + } + + // skip delete with key not found in model + if row.Type == vectorindex.CDC_DELETE { + continue + } + + // make sure last model won't unload when full and return full + // don't unload any model here. Quite dangerous and There is no harm not to unload because + // cdc size max is 8192. Model will eventually unload when save. + last, _, err := s.getLastModelAndIncrForSync(proc, maxcap, &mu) + if err != nil { + err_chan <- err + return + } + + // Len counter already incremented. Just add to last model + last.AddWithoutIncr(row.PKey, row.Vec) + } + }(i) + } + + wg.Wait() + + if len(err_chan) > 0 { + return <-err_chan + } + + return nil +} + +func (s *HnswSync) setupModel(proc *process.Process, maxcap uint) error { + + s.current = (*HnswModel)(nil) + s.last = (*HnswModel)(nil) + if len(s.indexes) == 0 { + // create a new model and do insert + id := s.getModelId() + newmodel, err := NewHnswModelForBuild(id, s.idxcfg, int(s.tblcfg.ThreadsBuild), maxcap) + if err != nil { + return err + } + s.indexes = append(s.indexes, newmodel) + s.last = newmodel + } else { + s.last = s.indexes[len(s.indexes)-1] + // last model not load yet so check the last.Len instead of Full() + idxlen := uint(s.last.Len.Load()) + if idxlen >= s.last.MaxCapacity { + //os.Stderr.WriteString(fmt.Sprintf("full len %d, cap %d\n", idxlen, last.MaxCapacity)) + id := s.getModelId() + // model is already full, create a new model for insert + newmodel, err := NewHnswModelForBuild(id, s.idxcfg, int(s.tblcfg.ThreadsBuild), maxcap) + if err != nil { + return err + } + s.indexes = append(s.indexes, newmodel) + s.last = newmodel + + } else { + //os.Stderr.WriteString(fmt.Sprintf("load model with index %d\n", len(s.indexes)-1)) + // load last + s.last.LoadIndex(proc, s.idxcfg, s.tblcfg, s.tblcfg.ThreadsBuild, false) + + } + } + + return nil +} + +func (s *HnswSync) sequentialUpdate(proc *process.Process, maxcap uint, midx []int) error { + + for i, row := range s.cdc.Data { + + switch row.Type { + case vectorindex.CDC_UPSERT: + if midx[i] == -1 { + // cannot find key from existing model. simple insert + last, err := s.getLastModel(proc, maxcap) + if err != nil { + return err + } + // insert + err = last.Add(row.PKey, row.Vec) + if err != nil { + return err + } + + break + + } + current, err := s.getCurrentModel(proc, midx[i]) + if err != nil { + return err + } + + // update + err = current.Remove(row.PKey) + if err != nil { + return err + } + + err = current.Add(row.PKey, row.Vec) + if err != nil { + return err + } + + case vectorindex.CDC_DELETE: + if midx[i] == -1 { + // cannot find key from existing models. ignore it + //os.Stderr.WriteString("DELETE NOT FOUND\n") + continue + } + + current, err := s.getCurrentModel(proc, midx[i]) + if err != nil { + return err + } + + // delete + err = current.Remove(row.PKey) + if err != nil { + return err + } + + case vectorindex.CDC_INSERT: + last, err := s.getLastModel(proc, maxcap) + if err != nil { + return err + } + + // insert + err = last.Add(row.PKey, row.Vec) + if err != nil { + return err + } + } + + } + return nil +} + +func (s *HnswSync) run(proc *process.Process) error { + var err error + + start := time.Now() + + // check contains and find the correspoding index id + maxcap, midx, err := s.checkContains(proc) + if err != nil { + return err + } + + t := time.Now() + + checkidxElapsed := t.Sub(start) + + s.ninsert.Store(int32(len(s.cdc.Data)) - s.nupdate.Load() - s.ndelete.Load()) + + // setup s.last and s.current model. s.late will point to the last model in metadata and s.current is nil + err = s.setupModel(proc, maxcap) + if err != nil { + return err + } + + logutil.Infof("hnsw_cdc_update: db=%s, table=%s, cdc: len=%d, ninsert = %d, ndelete = %d, nupdate = %d\n", + s.tblcfg.DbName, s.tblcfg.SrcTable, + len(s.cdc.Data), s.ninsert.Load(), s.ndelete.Load(), s.nupdate.Load()) + + if len(s.cdc.Data) == int(s.ninsert.Load()) { + // pure insert and insert into parallel + err = s.insertAllInParallel(proc, maxcap) + if err != nil { + return err + } + + } else { + // perform sequential update in single thread + err = s.sequentialUpdate(proc, maxcap, midx) + if err != nil { + return err + } + } + + t2 := time.Now() + updateElapsed := t2.Sub(t) + + // save to files and then save to database + sqls, err := s.ToSql(s.ts) + if err != nil { + return err + } + + if len(sqls) == 0 { + return nil + } + + err = s.runSqls(proc, sqls) + if err != nil { + return err + } + + t3 := time.Now() + saveElapsed := t3.Sub(t2) + + logutil.Debugf("hnsw_cdc_update: time elapsed: checkidx %d ms, update %d ms, save %d ms", + checkidxElapsed.Milliseconds(), updateElapsed.Milliseconds(), saveElapsed.Milliseconds()) + return nil +} + +func (s *HnswSync) runSqls(proc *process.Process, sqls []string) error { + /* + for _, s := range sqls { + os.Stderr.WriteString(fmt.Sprintf("sql : %s\n", s)) + } + */ + opts := executor.Options{} + err := runTxn(proc, func(exec executor.TxnExecutor) error { + for _, sql := range sqls { + res, err := exec.Exec(sql, opts.StatementOption()) + if err != nil { + return err + } + res.Close() + } + return nil + }) + if err != nil { + return err + } + + return nil +} + +func (s *HnswSync) getModelId() string { + id := fmt.Sprintf("%s:%d", s.uid, s.ts) + s.ts++ + return id +} + +func (s *HnswSync) getCurrentModel(proc *process.Process, idx int) (*HnswModel, error) { + m := s.indexes[idx] + if s.current != m { + // check current == last, if not, safe to unload + if s.current != nil && s.current != s.last { + s.current.Unload() + } + m.LoadIndex(proc, s.idxcfg, s.tblcfg, s.tblcfg.ThreadsBuild, false) + s.current = m + } + return s.current, nil +} + +func (s *HnswSync) getLastModel(proc *process.Process, maxcap uint) (*HnswModel, error) { + + full, err := s.last.Full() + if err != nil { + return nil, err + } + + if full { + // check current == last, if not, safe to unload + if s.current != s.last { + s.last.Unload() + } + + id := s.getModelId() + // model is already full, create a new model for insert + newmodel, err := NewHnswModelForBuild(id, s.idxcfg, int(s.tblcfg.ThreadsBuild), maxcap) + if err != nil { + return nil, err + } + s.indexes = append(s.indexes, newmodel) + s.last = newmodel + + } + //os.Stderr.WriteString(fmt.Sprintf("getlast model full %v id = %s\n", full, last.Id)) + return s.last, nil +} + +func (s *HnswSync) getLastModelAndIncrForSync(proc *process.Process, maxcap uint, mu *sync.Mutex) (*HnswModel, bool, error) { + + mu.Lock() + defer mu.Unlock() + + full := (s.last.Len.Load() >= int64(s.last.MaxCapacity)) + if full { + id := s.getModelId() + // model is already full, create a new model for insert + newmodel, err := NewHnswModelForBuild(id, s.idxcfg, int(s.tblcfg.ThreadsBuild), maxcap) + if err != nil { + return nil, false, err + } + s.indexes = append(s.indexes, newmodel) + s.last = newmodel + + } + //os.Stderr.WriteString(fmt.Sprintf("getlast model full %v id = %s\n", full, last.Id)) + + // pre-occupy this model by increment a Len counter and do Add() outside the mutex + // make sure only one call can get full = true + idxlen := s.last.Len.Add(1) + full = (idxlen >= int64(s.last.MaxCapacity)) + return s.last, full, nil +} + +// generate SQL to update the secondary index tables +// 1. sync the metadata table +// 2. sync the index file to index table +func (s *HnswSync) ToSql(ts int64) ([]string, error) { + + if len(s.indexes) == 0 { + return []string{}, nil + } + + sqls := make([]string, 0, len(s.indexes)+1) + + metas := make([]string, 0, len(s.indexes)) + for _, idx := range s.indexes { + // check Dirty. Only update when Dirty is true + if !idx.Dirty.Load() { + continue + } + + // delete sql + deletesqls, err := idx.ToDeleteSql(s.tblcfg) + if err != nil { + return nil, err + } + if len(deletesqls) > 0 { + sqls = append(sqls, deletesqls...) + } + + // insert sql + indexsqls, err := idx.ToSql(s.tblcfg) + if err != nil { + return nil, err + } + + // skip when sqls is empty which means the index is empty + if len(indexsqls) == 0 { + continue + } + + sqls = append(sqls, indexsqls...) + + //os.Stderr.WriteString(fmt.Sprintf("Sql: %s\n", sql)) + chksum, err := vectorindex.CheckSum(idx.Path) + if err != nil { + return nil, err + } + + finfo, err := os.Stat(idx.Path) + if err != nil { + return nil, err + } + fs := finfo.Size() + + metas = append(metas, fmt.Sprintf("('%s', '%s', %d, %d)", idx.Id, chksum, ts, fs)) + } + + if len(metas) > 0 { + metasql := fmt.Sprintf("INSERT INTO `%s`.`%s` VALUES %s", s.tblcfg.DbName, s.tblcfg.MetadataTable, strings.Join(metas, ", ")) + sqls = append(sqls, metasql) + } + return sqls, nil +} diff --git a/pkg/vectorindex/hnsw/sync_test.go b/pkg/vectorindex/hnsw/sync_test.go new file mode 100644 index 0000000000000..cea0c9ffe4775 --- /dev/null +++ b/pkg/vectorindex/hnsw/sync_test.go @@ -0,0 +1,370 @@ +// Copyright 2022 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package hnsw + +import ( + "testing" + "time" + + "github.com/matrixorigin/matrixone/pkg/common/mpool" + "github.com/matrixorigin/matrixone/pkg/container/batch" + "github.com/matrixorigin/matrixone/pkg/testutil" + "github.com/matrixorigin/matrixone/pkg/util/executor" + "github.com/matrixorigin/matrixone/pkg/vectorindex" + "github.com/matrixorigin/matrixone/pkg/vm/process" + "github.com/stretchr/testify/require" + "golang.org/x/exp/rand" +) + +/* +// give metadata [index_id, checksum, timestamp] +func mock_runSql(proc *process.Process, sql string) (executor.Result, error) { + return executor.Result{Mp: proc.Mp(), Batches: []*batch.Batch{makeMetaBatch(proc)}}, nil +} + +// give blob +func mock_runSql_streaming(proc *process.Process, sql string, ch chan executor.Result, err_chan chan error) (executor.Result, error) { + defer close(ch) + res := executor.Result{Mp: proc.Mp(), Batches: []*batch.Batch{makeIndexBatch(proc)}} + ch <- res + return executor.Result{}, nil +} +*/ + +// give metadata [index_id, checksum, timestamp] +func mock_runSql_empty(proc *process.Process, sql string) (executor.Result, error) { + + return executor.Result{Mp: proc.Mp(), Batches: []*batch.Batch{}}, nil +} + +func mock_runTxn(proc *process.Process, fn func(exec executor.TxnExecutor) error) error { + return nil +} + +func TestSyncUpsertWithEmpty(t *testing.T) { + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + runSql = mock_runSql_empty + runSql_streaming = mock_runSql_streaming + runCatalogSql = mock_runCatalogSql + runTxn = mock_runTxn + + cdc := vectorindex.VectorIndexCdc[float32]{Data: make([]vectorindex.VectorIndexCdcEntry[float32], 0, 1000)} + + key := int64(1000) + v := []float32{0.1, 0.2, 0.3} + + for i := 0; i < 1000; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_UPSERT, PKey: key, Vec: v} + cdc.Data = append(cdc.Data, e) + key += 1 + for i := range len(v) { + v[i] += 0.01 + } + } + + err := CdcSync(proc, "db", "src", 3, &cdc) + require.Nil(t, err) +} + +func TestSyncUpsert(t *testing.T) { + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + runSql = mock_runSql + runSql_streaming = mock_runSql_streaming + runCatalogSql = mock_runCatalogSql + runTxn = mock_runTxn + + cdc := vectorindex.VectorIndexCdc[float32]{Data: make([]vectorindex.VectorIndexCdcEntry[float32], 0, 1000)} + + key := int64(1000) + v := []float32{0.1, 0.2, 0.3} + + for i := 0; i < 1000; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_UPSERT, PKey: key, Vec: v} + cdc.Data = append(cdc.Data, e) + key += 1 + for i := range len(v) { + v[i] += 0.01 + } + } + + err := CdcSync(proc, "db", "src", 3, &cdc) + require.Nil(t, err) +} + +// should delete all items +func TestSyncDelete(t *testing.T) { + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + runSql = mock_runSql + runSql_streaming = mock_runSql_streaming + runCatalogSql = mock_runCatalogSql + runTxn = mock_runTxn + + cdc := vectorindex.VectorIndexCdc[float32]{Data: make([]vectorindex.VectorIndexCdcEntry[float32], 0, 1000)} + + key := int64(0) + + for i := 0; i < 100; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_DELETE, PKey: key} + cdc.Data = append(cdc.Data, e) + key += 1 + } + + err := CdcSync(proc, "db", "src", 3, &cdc) + require.Nil(t, err) +} + +// should delete items and add the same keys back to the model +func TestSyncDeleteAndInsert(t *testing.T) { + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + runSql = mock_runSql + runSql_streaming = mock_runSql_streaming + runCatalogSql = mock_runCatalogSql + runTxn = mock_runTxn + + cdc := vectorindex.VectorIndexCdc[float32]{Data: make([]vectorindex.VectorIndexCdcEntry[float32], 0, 200)} + + key := int64(0) + + for i := 0; i < 100; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_DELETE, PKey: key} + cdc.Data = append(cdc.Data, e) + key += 1 + } + + key = 0 + v := []float32{0.1, 0.2, 0.3} + for i := 0; i < 100; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_INSERT, PKey: key, Vec: v} + cdc.Data = append(cdc.Data, e) + key += 1 + + } + + err := CdcSync(proc, "db", "src", 3, &cdc) + require.Nil(t, err) +} + +// should delete items and add the same keys back to the model +func TestSyncUpdate(t *testing.T) { + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + runSql = mock_runSql + runSql_streaming = mock_runSql_streaming + runCatalogSql = mock_runCatalogSql + runTxn = mock_runTxn + + cdc := vectorindex.VectorIndexCdc[float32]{Data: make([]vectorindex.VectorIndexCdcEntry[float32], 0, 100)} + + key := int64(0) + v := []float32{0.1, 0.2, 0.3} + + for i := 0; i < 100; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_UPSERT, PKey: key, Vec: v} + cdc.Data = append(cdc.Data, e) + key += 1 + } + + err := CdcSync(proc, "db", "src", 3, &cdc) + require.Nil(t, err) +} + +// should delete items and add the same keys back to the model +func TestSyncDeleteAndUpsert(t *testing.T) { + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + runSql = mock_runSql + runSql_streaming = mock_runSql_streaming + runCatalogSql = mock_runCatalogSql + runTxn = mock_runTxn + + cdc := vectorindex.VectorIndexCdc[float32]{Data: make([]vectorindex.VectorIndexCdcEntry[float32], 0, 200)} + + key := int64(0) + + for i := 0; i < 100; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_DELETE, PKey: key} + cdc.Data = append(cdc.Data, e) + key += 1 + } + + key = 0 + v := []float32{0.1, 0.2, 0.3} + for i := 0; i < 100; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_UPSERT, PKey: key, Vec: v} + cdc.Data = append(cdc.Data, e) + key += 1 + + } + + err := CdcSync(proc, "db", "src", 3, &cdc) + require.Nil(t, err) +} + +// total 1000100 items and should have two models +func TestSyncAddOneModel(t *testing.T) { + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + runSql = mock_runSql + runSql_streaming = mock_runSql_streaming + runCatalogSql = mock_runCatalogSql + runTxn = mock_runTxn + + cdc := vectorindex.VectorIndexCdc[float32]{Data: make([]vectorindex.VectorIndexCdcEntry[float32], 0, 1000000)} + + key := int64(1000) + v := []float32{0.1, 0.2, 0.3} + + for i := 0; i < 1000000; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_UPSERT, PKey: key, Vec: v} + cdc.Data = append(cdc.Data, e) + key += 1 + for i := range len(v) { + v[i] += 0.001 + } + } + + err := CdcSync(proc, "db", "src", 3, &cdc) + require.Nil(t, err) +} + +// should delete all items +func TestSyncDelete2Files(t *testing.T) { + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + runSql = mock_runSql_2files + runSql_streaming = mock_runSql_streaming_2files + runCatalogSql = mock_runCatalogSql + runTxn = mock_runTxn + + cdc := vectorindex.VectorIndexCdc[float32]{Data: make([]vectorindex.VectorIndexCdcEntry[float32], 0, 1000)} + + key := int64(0) + + for i := 0; i < 200; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_DELETE, PKey: key} + cdc.Data = append(cdc.Data, e) + key += 1 + } + + err := CdcSync(proc, "db", "src", 3, &cdc) + require.Nil(t, err) +} + +// should delete all items +func TestSyncDeleteShuffle2Files(t *testing.T) { + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + runSql = mock_runSql_2files + runSql_streaming = mock_runSql_streaming_2files + runCatalogSql = mock_runCatalogSql + runTxn = mock_runTxn + + cdc := vectorindex.VectorIndexCdc[float32]{Data: make([]vectorindex.VectorIndexCdcEntry[float32], 0, 1000)} + + key := int64(0) + + for i := 0; i < 200; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_DELETE, PKey: key} + cdc.Data = append(cdc.Data, e) + key += 1 + } + + rand.Seed(uint64(time.Now().UnixNano())) + rand.Shuffle(len(cdc.Data), func(i, j int) { cdc.Data[i], cdc.Data[j] = cdc.Data[j], cdc.Data[i] }) + + err := CdcSync(proc, "db", "src", 3, &cdc) + require.Nil(t, err) +} + +// should delete items and add the same keys back to the model +func TestSyncUpdateShuffle2Files(t *testing.T) { + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + runSql = mock_runSql_2files + runSql_streaming = mock_runSql_streaming_2files + runCatalogSql = mock_runCatalogSql + runTxn = mock_runTxn + + cdc := vectorindex.VectorIndexCdc[float32]{Data: make([]vectorindex.VectorIndexCdcEntry[float32], 0, 100)} + + key := int64(0) + v := []float32{0.1, 0.2, 0.3} + + for i := 0; i < 200; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_UPSERT, PKey: key, Vec: v} + cdc.Data = append(cdc.Data, e) + key += 1 + } + + rand.Seed(uint64(time.Now().UnixNano())) + rand.Shuffle(len(cdc.Data), func(i, j int) { cdc.Data[i], cdc.Data[j] = cdc.Data[j], cdc.Data[i] }) + + err := CdcSync(proc, "db", "src", 3, &cdc) + require.Nil(t, err) +} + +// should update and insert items +func TestSyncUpdateInsertShuffle2Files(t *testing.T) { + + m := mpool.MustNewZero() + proc := testutil.NewProcessWithMPool(t, "", m) + + runSql = mock_runSql_2files + runSql_streaming = mock_runSql_streaming_2files + runCatalogSql = mock_runCatalogSql + runTxn = mock_runTxn + + cdc := vectorindex.VectorIndexCdc[float32]{Data: make([]vectorindex.VectorIndexCdcEntry[float32], 0, 100)} + + key := int64(0) + v := []float32{0.1, 0.2, 0.3} + + // 0 - 199 key exists, 200 - 399 new insert + for i := 0; i < 400; i++ { + e := vectorindex.VectorIndexCdcEntry[float32]{Type: vectorindex.CDC_UPSERT, PKey: key, Vec: v} + cdc.Data = append(cdc.Data, e) + key += 1 + } + + rand.Seed(uint64(time.Now().UnixNano())) + rand.Shuffle(len(cdc.Data), func(i, j int) { cdc.Data[i], cdc.Data[j] = cdc.Data[j], cdc.Data[i] }) + + err := CdcSync(proc, "db", "src", 3, &cdc) + require.Nil(t, err) +} diff --git a/pkg/vectorindex/sqlexec/sqlexec.go b/pkg/vectorindex/sqlexec/sqlexec.go index b54b0e7648df5..0681973b13596 100644 --- a/pkg/vectorindex/sqlexec/sqlexec.go +++ b/pkg/vectorindex/sqlexec/sqlexec.go @@ -74,3 +74,30 @@ func RunStreamingSql(proc *process.Process, sql string, stream_chan chan executo WithStreaming(stream_chan, error_chan) return exec.Exec(topContext, sql, opts) } + +// run SQL in batch mode. Result batches will stored in memory and return once all result batches received. +func RunTxn(proc *process.Process, execFunc func(executor.TxnExecutor) error) error { + v, ok := moruntime.ServiceRuntime(proc.GetService()).GetGlobalVariables(moruntime.InternalSQLExecutor) + if !ok { + panic("missing lock service") + } + + //------------------------------------------------------- + topContext := proc.GetTopContext() + accountId, err := defines.GetAccountId(proc.Ctx) + if err != nil { + return err + } + //------------------------------------------------------- + + exec := v.(executor.SQLExecutor) + opts := executor.Options{}. + // All runSql and runSqlWithResult is a part of input sql, can not incr statement. + // All these sub-sql's need to be rolled back and retried en masse when they conflict in pessimistic mode + WithDisableIncrStatement(). + WithTxn(proc.GetTxnOperator()). + WithDatabase(proc.GetSessionInfo().Database). + WithTimeZone(proc.GetSessionInfo().TimeZone). + WithAccountID(accountId) + return exec.ExecTxn(topContext, execFunc, opts) +} diff --git a/pkg/vectorindex/types.go b/pkg/vectorindex/types.go index 3cbe815417ec0..0d21decf4044b 100644 --- a/pkg/vectorindex/types.go +++ b/pkg/vectorindex/types.go @@ -15,8 +15,10 @@ package vectorindex import ( + "encoding/json" "runtime" + "github.com/matrixorigin/matrixone/pkg/container/types" usearch "github.com/unum-cloud/usearch/golang" ) @@ -31,6 +33,12 @@ const ( MaxChunkSize = 65536 ) +const ( + CDC_INSERT = "I" + CDC_UPSERT = "U" + CDC_DELETE = "D" +) + // HNSW have two secondary index tables, metadata and index storage. For new vector index algorithm that share the same secondary tables, // can use the same IndexTableConfig struct type IndexTableConfig struct { @@ -61,12 +69,14 @@ type HnswParam struct { Quantization string `json:"quantization"` OpType string `json:"op_type"` EfSearch string `json:"ef_search"` + Async string `json:"async"` } // IVF specified parameters type IvfParam struct { Lists string `json:"lists"` OpType string `json:"op_type"` + Async string `json:"async"` } type IvfflatIndexConfig struct { @@ -91,6 +101,83 @@ type RuntimeConfig struct { Probe uint } +type VectorIndexCdc[T types.RealNumbers] struct { + // Start string `json:"start"` + // End string `json:"end"` + Data []VectorIndexCdcEntry[T] `json:"cdc"` +} + +func NewVectorIndexCdc[T types.RealNumbers]() *VectorIndexCdc[T] { + return &VectorIndexCdc[T]{ + Data: make([]VectorIndexCdcEntry[T], 0, 8192), + } +} + +func (h *VectorIndexCdc[T]) Reset() { + h.Data = h.Data[:0] +} + +func (h *VectorIndexCdc[T]) Empty() bool { + return len(h.Data) == 0 +} + +func (h *VectorIndexCdc[T]) Full() bool { + return len(h.Data) >= cap(h.Data) +} + +func (h *VectorIndexCdc[T]) Insert(key int64, v []T) { + e := VectorIndexCdcEntry[T]{ + Type: CDC_INSERT, + PKey: key, + Vec: v, + } + + h.Data = append(h.Data, e) +} + +func (h *VectorIndexCdc[T]) Upsert(key int64, v []T) { + e := VectorIndexCdcEntry[T]{ + Type: CDC_UPSERT, + PKey: key, + Vec: v, + } + + h.Data = append(h.Data, e) +} + +func (h *VectorIndexCdc[T]) Delete(key int64) { + e := VectorIndexCdcEntry[T]{ + Type: CDC_DELETE, + PKey: key, + } + + h.Data = append(h.Data, e) +} + +func (h *VectorIndexCdc[T]) ToJson() (string, error) { + + b, err := json.Marshal(h) + if err != nil { + return "", err + } + return string(b), nil +} + +type VectorIndexCdcEntry[T types.RealNumbers] struct { + Type string `json:"t"` // I - INSERT, D - DELETE, U - UPSERT + PKey int64 `json:"pk"` + Vec []T `json:"v,omitempty"` +} + +type HnswCdcParam struct { + DbName string `json:"db"` + Table string `json:"table"` + MetaTbl string `json:"meta"` + IndexTbl string `json:"index"` + Params HnswParam `json:"params"` + Dimension int32 `json:"dimension"` +} + // nthread == 0, result will return NumCPU - 1 func GetConcurrency(nthread int64) int64 { if nthread > 0 { diff --git a/pkg/vectorindex/types_test.go b/pkg/vectorindex/types_test.go new file mode 100644 index 0000000000000..fad882167d8af --- /dev/null +++ b/pkg/vectorindex/types_test.go @@ -0,0 +1,63 @@ +// Copyright 2022 Matrix Origin +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package vectorindex + +import ( + "testing" + + "github.com/stretchr/testify/require" +) + +func TestCdc(t *testing.T) { + key := int64(0) + v := []float32{0, 1, 2} + key2 := int64(1) + v2 := []float32{1, 2, 3} + + cdc := NewVectorIndexCdc[float32]() + + // Insert + cdc.Insert(key, v) + + js, err := cdc.ToJson() + require.Nil(t, err) + + require.Equal(t, js, `{"cdc":[{"t":"I","pk":0,"v":[0,1,2]}]}`) + + // delete + cdc.Delete(key) + js, err = cdc.ToJson() + require.Nil(t, err) + + require.Equal(t, js, `{"cdc":[{"t":"I","pk":0,"v":[0,1,2]},{"t":"D","pk":0}]}`) + + // upsert + cdc.Upsert(key2, v2) + + js, err = cdc.ToJson() + require.Nil(t, err) + + require.Equal(t, js, `{"cdc":[{"t":"I","pk":0,"v":[0,1,2]},{"t":"D","pk":0},{"t":"U","pk":1,"v":[1,2,3]}]}`) + + require.False(t, cdc.Empty()) + + require.False(t, cdc.Full()) + + cdc.Reset() + + js, err = cdc.ToJson() + require.NoError(t, err) + require.Equal(t, js, `{"cdc":[]}`) +} diff --git a/test/distributed/cases/array/array.result b/test/distributed/cases/array/array.result index b0ef7775263c1..24f96fb2b8d8d 100644 --- a/test/distributed/cases/array/array.result +++ b/test/distributed/cases/array/array.result @@ -54,9 +54,9 @@ select b + "[1,2,3]" from vec_table; b + [1,2,3] [2, 4, 6] select b + "[1,2]" from vec_table; -invalid input: vector ops between different dimensions (3, 2) is not permitted. +invalid input: expected vector dimension 3 != actual dimension 2. select b + "[1,2,3,4]" from vec_table; -invalid input: vector ops between different dimensions (3, 4) is not permitted. +invalid input: expected vector dimension 3 != actual dimension 4. select cast("[1,2,3]" as vecf32(3)); cast([1,2,3] as vecf32(3)) [1, 2, 3] diff --git a/test/distributed/cases/vector/vector_hnsw.result b/test/distributed/cases/vector/vector_hnsw.result index bdf9043c68a06..9cb79195bac10 100644 --- a/test/distributed/cases/vector/vector_hnsw.result +++ b/test/distributed/cases/vector/vector_hnsw.result @@ -117,7 +117,7 @@ create index idx01 using hnsw on vector_index_07(b) op_type "vector_l2_ops"; select * from vector_index_07 order by L2_DISTANCE(a, "[16, 15, 0, 0, 5, 46, 5, 5, 4, 0, 0, 0, 28, 118, 12, 5, 75, 44, 5, 0, 6, 32, 6, 49, 41, 74, 9, 1, 0, 0, 0, 9, 1, 9, 16, 41, 71, 80, 3, 0, 0, 4, 3, 5, 51, 106, 11, 3, 112, 28, 13, 1, 4, 8, 3, 104, 118, 14, 1, 1, 0, 0, 0, 88, 3, 27, 46, 118, 108, 49, 2, 0, 1, 46, 118, 118, 27, 12, 0, 0, 33, 118, 118, 8, 0, 0, 0, 4, 118, 95, 40, 0, 0, 0, 1, 11, 27, 38, 12, 12, 18, 29, 3, 2, 13, 30, 94, 78, 30, 19, 9, 3, 31, 45, 70, 42, 15, 1, 3, 12, 14, 22, 16, 2, 3, 17, 24, 13]") ASC LIMIT 2; invalid argument function l2_distance, bad value [BIGINT VARCHAR] select * from vector_index_07 order by L2_DISTANCE(b, "[16, 15, 3, 0, 0, 4, 3, 5, 51]") ASC LIMIT 2; -invalid input: vector ops between different dimensions (128, 9) is not permitted. +invalid input: expected vector dimension 128 != actual dimension 9. select * from vector_index_07 order by L2_DISTANCE(b, "abc") ASC LIMIT 2; internal error: malformed vector input: abc create table vector_index_08(a bigint auto_increment primary key, b vecf32(128),c int,key c_k(c)); diff --git a/test/distributed/cases/vector/vector_hnsw_async.result b/test/distributed/cases/vector/vector_hnsw_async.result new file mode 100644 index 0000000000000..a849151d687f9 --- /dev/null +++ b/test/distributed/cases/vector/vector_hnsw_async.result @@ -0,0 +1,66 @@ +SET experimental_hnsw_index = 1; +drop database if exists hnsw_cdc; +create database if not exists hnsw_cdc; +use hnsw_cdc; +create table t1(a bigint primary key, b vecf32(3),c int,key c_k(c)); +create index idx01 using hnsw on t1(b) op_type "vector_l2_ops" M 48 EF_CONSTRUCTION 64 EF_SEARCH 64 ASYNC; +insert into t1 values (0, "[1,2,3]", 1); +UPDATE t1 set b = '[4,5,6]' where a = 0; +insert into t1 values (1, "[2,3,4]", 1); +DELETE FROM t1 WHERE a=1; +select sleep(30); +sleep(30) +0 +select * from t1 order by L2_DISTANCE(b,"[1,2,3]") ASC LIMIT 10; +a b c +0 [4, 5, 6] 1 +select * from t1 order by L2_DISTANCE(b,"[4,5,6]") ASC LIMIT 10; +a b c +0 [4, 5, 6] 1 +select * from t1 order by L2_DISTANCE(b,"[2,3,4]") ASC LIMIT 10; +a b c +0 [4, 5, 6] 1 +drop table t1; +create table t2(a bigint primary key, b vecf32(128)); +create index idx2 using hnsw on t2(b) op_type "vector_l2_ops" M 48 EF_CONSTRUCTION 64 EF_SEARCH 64 ASYNC; +load data infile {'filepath'='$resources/vector/sift128_base_10k.csv.gz', 'compression'='gzip'} into table t2 fields terminated by ':' parallel 'true'; +select count(*) from t2; +count(*) +10000 +select sleep(30); +sleep(30) +0 +select * from t2 order by L2_DISTANCE(b, "[14, 2, 0, 0, 0, 2, 42, 55, 9, 1, 0, 0, 18, 100, 77, 32, 89, 1, 0, 0, 19, 85, 15, 68, 52, 4, 0, 0, 0, 0, 2, 28, 34, 13, 5, 12, 49, 40, 39, 37, 24, 2, 0, 0, 34, 83, 88, 28, 119, 20, 0, 0, 41, 39, 13, 62, 119, 16, 2, 0, 0, 0, 10, 42, 9, 46, 82, 79, 64, 19, 2, 5, 10, 35, 26, 53, 84, 32, 34, 9, 119, 119, 21, 3, 3, 11, 17, 14, 119, 25, 8, 5, 0, 0, 11, 22, 23, 17, 42, 49, 17, 12, 5, 5, 12, 78, 119, 90, 27, 0, 4, 2, 48, 92, 112, 85, 15, 0, 2, 7, 50, 36, 15, 11, 1, 0, 0, 7]") ASC LIMIT 1; +a b +9999 [14, 2, 0, 0, 0, 2, 42, 55, 9, 1, 0, 0, 18, 100, 77, 32, 89, 1, 0, 0, 19, 85, 15, 68, 52, 4, 0, 0, 0, 0, 2, 28, 34, 13, 5, 12, 49, 40, 39, 37, 24, 2, 0, 0, 34, 83, 88, 28, 119, 20, 0, 0, 41, 39, 13, 62, 119, 16, 2, 0, 0, 0, 10, 42, 9, 46, 82, 79, 64, 19, 2, 5, 10, 35, 26, 53, 84, 32, 34, 9, 119, 119, 21, 3, 3, 11, 17, 14, 119, 25, 8, 5, 0, 0, 11, 22, 23, 17, 42, 49, 17, 12, 5, 5, 12, 78, 119, 90, 27, 0, 4, 2, 48, 92, 112, 85, 15, 0, 2, 7, 50, 36, 15, 11, 1, 0, 0, 7] +select * from t2 order by L2_DISTANCE(b, "[0, 16, 35, 5, 32, 31, 14, 10, 11, 78, 55, 10, 45, 83, 11, 6, 14, 57, 102, 75, 20, 8, 3, 5, 67, 17, 19, 26, 5, 0, 1, 22, 60, 26, 7, 1, 18, 22, 84, 53, 85, 119, 119, 4, 24, 18, 7, 7, 1, 81, 106, 102, 72, 30, 6, 0, 9, 1, 9, 119, 72, 1, 4, 33, 119, 29, 6, 1, 0, 1, 14, 52, 119, 30, 3, 0, 0, 55, 92, 111, 2, 5, 4, 9, 22, 89, 96, 14, 1, 0, 1, 82, 59, 16, 20, 5, 25, 14, 11, 4, 0, 0, 1, 26, 47, 23, 4, 0, 0, 4, 38, 83, 30, 14, 9, 4, 9, 17, 23, 41, 0, 0, 2, 8, 19, 25, 23, 1]") ASC LIMIT 1; +a b +0 [0, 16, 35, 5, 32, 31, 14, 10, 11, 78, 55, 10, 45, 83, 11, 6, 14, 57, 102, 75, 20, 8, 3, 5, 67, 17, 19, 26, 5, 0, 1, 22, 60, 26, 7, 1, 18, 22, 84, 53, 85, 119, 119, 4, 24, 18, 7, 7, 1, 81, 106, 102, 72, 30, 6, 0, 9, 1, 9, 119, 72, 1, 4, 33, 119, 29, 6, 1, 0, 1, 14, 52, 119, 30, 3, 0, 0, 55, 92, 111, 2, 5, 4, 9, 22, 89, 96, 14, 1, 0, 1, 82, 59, 16, 20, 5, 25, 14, 11, 4, 0, 0, 1, 26, 47, 23, 4, 0, 0, 4, 38, 83, 30, 14, 9, 4, 9, 17, 23, 41, 0, 0, 2, 8, 19, 25, 23, 1] +drop table t2; +create table t3(a bigint primary key, b vecf32(128)); +load data infile {'filepath'='$resources/vector/sift128_base_10k.csv.gz', 'compression'='gzip'} into table t3 fields terminated by ':' parallel 'true'; +select count(*) from t3; +count(*) +10000 +create index idx3 using hnsw on t3(b) op_type "vector_l2_ops" M 48 EF_CONSTRUCTION 64 EF_SEARCH 64 ASYNC; +load data infile {'filepath'='$resources/vector/sift128_base_10k_2.csv.gz', 'compression'='gzip'} into table t3 fields terminated by ':' parallel 'true'; +select count(*) from t3; +count(*) +20000 +select sleep(45); +sleep(45) +0 +select * from t3 order by L2_DISTANCE(b, "[14, 2, 0, 0, 0, 2, 42, 55, 9, 1, 0, 0, 18, 100, 77, 32, 89, 1, 0, 0, 19, 85, 15, 68, 52, 4, 0, 0, 0, 0, 2, 28, 34, 13, 5, 12, 49, 40, 39, 37, 24, 2, 0, 0, 34, 83, 88, 28, 119, 20, 0, 0, 41, 39, 13, 62, 119, 16, 2, 0, 0, 0, 10, 42, 9, 46, 82, 79, 64, 19, 2, 5, 10, 35, 26, 53, 84, 32, 34, 9, 119, 119, 21, 3, 3, 11, 17, 14, 119, 25, 8, 5, 0, 0, 11, 22, 23, 17, 42, 49, 17, 12, 5, 5, 12, 78, 119, 90, 27, 0, 4, 2, 48, 92, 112, 85, 15, 0, 2, 7, 50, 36, 15, 11, 1, 0, 0, 7]") ASC LIMIT 1; +a b +9999 [14, 2, 0, 0, 0, 2, 42, 55, 9, 1, 0, 0, 18, 100, 77, 32, 89, 1, 0, 0, 19, 85, 15, 68, 52, 4, 0, 0, 0, 0, 2, 28, 34, 13, 5, 12, 49, 40, 39, 37, 24, 2, 0, 0, 34, 83, 88, 28, 119, 20, 0, 0, 41, 39, 13, 62, 119, 16, 2, 0, 0, 0, 10, 42, 9, 46, 82, 79, 64, 19, 2, 5, 10, 35, 26, 53, 84, 32, 34, 9, 119, 119, 21, 3, 3, 11, 17, 14, 119, 25, 8, 5, 0, 0, 11, 22, 23, 17, 42, 49, 17, 12, 5, 5, 12, 78, 119, 90, 27, 0, 4, 2, 48, 92, 112, 85, 15, 0, 2, 7, 50, 36, 15, 11, 1, 0, 0, 7] +select * from t3 order by L2_DISTANCE(b, "[0, 16, 35, 5, 32, 31, 14, 10, 11, 78, 55, 10, 45, 83, 11, 6, 14, 57, 102, 75, 20, 8, 3, 5, 67, 17, 19, 26, 5, 0, 1, 22, 60, 26, 7, 1, 18, 22, 84, 53, 85, 119, 119, 4, 24, 18, 7, 7, 1, 81, 106, 102, 72, 30, 6, 0, 9, 1, 9, 119, 72, 1, 4, 33, 119, 29, 6, 1, 0, 1, 14, 52, 119, 30, 3, 0, 0, 55, 92, 111, 2, 5, 4, 9, 22, 89, 96, 14, 1, 0, 1, 82, 59, 16, 20, 5, 25, 14, 11, 4, 0, 0, 1, 26, 47, 23, 4, 0, 0, 4, 38, 83, 30, 14, 9, 4, 9, 17, 23, 41, 0, 0, 2, 8, 19, 25, 23, 1]") ASC LIMIT 1; +a b +0 [0, 16, 35, 5, 32, 31, 14, 10, 11, 78, 55, 10, 45, 83, 11, 6, 14, 57, 102, 75, 20, 8, 3, 5, 67, 17, 19, 26, 5, 0, 1, 22, 60, 26, 7, 1, 18, 22, 84, 53, 85, 119, 119, 4, 24, 18, 7, 7, 1, 81, 106, 102, 72, 30, 6, 0, 9, 1, 9, 119, 72, 1, 4, 33, 119, 29, 6, 1, 0, 1, 14, 52, 119, 30, 3, 0, 0, 55, 92, 111, 2, 5, 4, 9, 22, 89, 96, 14, 1, 0, 1, 82, 59, 16, 20, 5, 25, 14, 11, 4, 0, 0, 1, 26, 47, 23, 4, 0, 0, 4, 38, 83, 30, 14, 9, 4, 9, 17, 23, 41, 0, 0, 2, 8, 19, 25, 23, 1] +select * from t3 order by L2_DISTANCE(b, "[59, 0, 0, 1, 1, 1, 5, 100, 41, 0, 0, 4, 57, 34, 31, 115, 4, 0, 0, 12, 30, 33, 43, 85, 21, 0, 0, 14, 25, 9, 10, 60, 99, 11, 0, 0, 0, 0, 10, 55, 68, 1, 0, 3, 115, 65, 42, 115, 32, 3, 0, 4, 13, 21, 104, 115, 81, 15, 15, 23, 9, 2, 21, 75, 43, 20, 1, 0, 10, 2, 2, 20, 52, 35, 32, 61, 79, 8, 7, 41, 50, 106, 96, 20, 8, 2, 11, 39, 115, 48, 53, 11, 3, 0, 2, 43, 35, 11, 0, 1, 13, 7, 0, 1, 115, 58, 54, 29, 1, 2, 0, 3, 32, 115, 99, 34, 1, 0, 0, 0, 35, 15, 52, 44, 9, 0, 0, 18]") ASC LIMIT 1; +a b +10000 [59, 0, 0, 1, 1, 1, 5, 100, 41, 0, 0, 4, 57, 34, 31, 115, 4, 0, 0, 12, 30, 33, 43, 85, 21, 0, 0, 14, 25, 9, 10, 60, 99, 11, 0, 0, 0, 0, 10, 55, 68, 1, 0, 3, 115, 65, 42, 115, 32, 3, 0, 4, 13, 21, 104, 115, 81, 15, 15, 23, 9, 2, 21, 75, 43, 20, 1, 0, 10, 2, 2, 20, 52, 35, 32, 61, 79, 8, 7, 41, 50, 106, 96, 20, 8, 2, 11, 39, 115, 48, 53, 11, 3, 0, 2, 43, 35, 11, 0, 1, 13, 7, 0, 1, 115, 58, 54, 29, 1, 2, 0, 3, 32, 115, 99, 34, 1, 0, 0, 0, 35, 15, 52, 44, 9, 0, 0, 18] +select * from t3 order by L2_DISTANCE(b, "[0, 0, 0, 0, 0, 101, 82, 4, 2, 0, 0, 0, 3, 133, 133, 8, 46, 1, 2, 13, 15, 29, 87, 50, 22, 1, 0, 16, 25, 6, 18, 49, 5, 2, 0, 2, 3, 59, 70, 19, 18, 2, 0, 11, 42, 37, 30, 13, 133, 13, 4, 53, 28, 3, 8, 42, 77, 6, 11, 103, 36, 0, 0, 32, 7, 15, 59, 27, 2, 0, 2, 5, 14, 5, 55, 52, 51, 3, 2, 5, 133, 21, 10, 38, 26, 1, 0, 64, 71, 3, 10, 118, 53, 5, 6, 28, 33, 26, 73, 15, 0, 0, 0, 22, 13, 15, 133, 133, 4, 0, 0, 15, 107, 62, 46, 91, 9, 1, 7, 16, 28, 4, 0, 27, 33, 4, 15, 25]") ASC LIMIT 1; +a b +19999 [0, 0, 0, 0, 0, 101, 82, 4, 2, 0, 0, 0, 3, 133, 133, 8, 46, 1, 2, 13, 15, 29, 87, 50, 22, 1, 0, 16, 25, 6, 18, 49, 5, 2, 0, 2, 3, 59, 70, 19, 18, 2, 0, 11, 42, 37, 30, 13, 133, 13, 4, 53, 28, 3, 8, 42, 77, 6, 11, 103, 36, 0, 0, 32, 7, 15, 59, 27, 2, 0, 2, 5, 14, 5, 55, 52, 51, 3, 2, 5, 133, 21, 10, 38, 26, 1, 0, 64, 71, 3, 10, 118, 53, 5, 6, 28, 33, 26, 73, 15, 0, 0, 0, 22, 13, 15, 133, 133, 4, 0, 0, 15, 107, 62, 46, 91, 9, 1, 7, 16, 28, 4, 0, 27, 33, 4, 15, 25] +drop table t3; +drop database hnsw_cdc; diff --git a/test/distributed/cases/vector/vector_hnsw_async.sql b/test/distributed/cases/vector/vector_hnsw_async.sql new file mode 100644 index 0000000000000..79f9cef553d95 --- /dev/null +++ b/test/distributed/cases/vector/vector_hnsw_async.sql @@ -0,0 +1,96 @@ + +SET experimental_hnsw_index = 1; + +drop database if exists hnsw_cdc; +create database if not exists hnsw_cdc; +use hnsw_cdc; + +create table t1(a bigint primary key, b vecf32(3),c int,key c_k(c)); + +-- empty data +create index idx01 using hnsw on t1(b) op_type "vector_l2_ops" M 48 EF_CONSTRUCTION 64 EF_SEARCH 64 ASYNC; + +-- select sleep(30); + +insert into t1 values (0, "[1,2,3]", 1); +-- select hnsw_cdc_update('hnsw_cdc', 't1', 3, '{"start":"", "end":"", "cdc":[{"t":"U", "pk":0, "v":[1,2,3]}]}'); + +UPDATE t1 set b = '[4,5,6]' where a = 0; +-- select hnsw_cdc_update('hnsw_cdc', 't1', 3, '{"start":"", "end":"", "cdc":[{"t":"U", "pk":0, "v":[4,5,6]}]}'); + +insert into t1 values (1, "[2,3,4]", 1); +-- select hnsw_cdc_update('hnsw_cdc', 't1', 3, '{"start":"", "end":"", "cdc":[{"t":"I", "pk":1, "v":[2,3,4]}]}'); + +DELETE FROM t1 WHERE a=1; +-- select hnsw_cdc_update('hnsw_cdc', 't1', 3, '{"start":"", "end":"", "cdc":[{"t":"D", "pk":0}]}'); + +select sleep(30); + +-- test with multi-cn is tricky. since model is cached in memory, model may not be updated after CDC sync'd. The only way to test is to all INSERT/DELETE/UPDATE before SELECT. +-- already update to [4,5,6], result is [4,5,6] +select * from t1 order by L2_DISTANCE(b,"[1,2,3]") ASC LIMIT 10; + +-- should return a=0 +select * from t1 order by L2_DISTANCE(b,"[4,5,6]") ASC LIMIT 10; + +-- a=1 deleted. result is [4,5,6] +select * from t1 order by L2_DISTANCE(b,"[2,3,4]") ASC LIMIT 10; + +drop table t1; + +-- t2 +create table t2(a bigint primary key, b vecf32(128)); +create index idx2 using hnsw on t2(b) op_type "vector_l2_ops" M 48 EF_CONSTRUCTION 64 EF_SEARCH 64 ASYNC; +-- select sleep(30); + +load data infile {'filepath'='$resources/vector/sift128_base_10k.csv.gz', 'compression'='gzip'} into table t2 fields terminated by ':' parallel 'true'; + +select count(*) from t2; + +select sleep(30); + +select * from t2 order by L2_DISTANCE(b, "[14, 2, 0, 0, 0, 2, 42, 55, 9, 1, 0, 0, 18, 100, 77, 32, 89, 1, 0, 0, 19, 85, 15, 68, 52, 4, 0, 0, 0, 0, 2, 28, 34, 13, 5, 12, 49, 40, 39, 37, 24, 2, 0, 0, 34, 83, 88, 28, 119, 20, 0, 0, 41, 39, 13, 62, 119, 16, 2, 0, 0, 0, 10, 42, 9, 46, 82, 79, 64, 19, 2, 5, 10, 35, 26, 53, 84, 32, 34, 9, 119, 119, 21, 3, 3, 11, 17, 14, 119, 25, 8, 5, 0, 0, 11, 22, 23, 17, 42, 49, 17, 12, 5, 5, 12, 78, 119, 90, 27, 0, 4, 2, 48, 92, 112, 85, 15, 0, 2, 7, 50, 36, 15, 11, 1, 0, 0, 7]") ASC LIMIT 1; + +select * from t2 order by L2_DISTANCE(b, "[0, 16, 35, 5, 32, 31, 14, 10, 11, 78, 55, 10, 45, 83, 11, 6, 14, 57, 102, 75, 20, 8, 3, 5, 67, 17, 19, 26, 5, 0, 1, 22, 60, 26, 7, 1, 18, 22, 84, 53, 85, 119, 119, 4, 24, 18, 7, 7, 1, 81, 106, 102, 72, 30, 6, 0, 9, 1, 9, 119, 72, 1, 4, 33, 119, 29, 6, 1, 0, 1, 14, 52, 119, 30, 3, 0, 0, 55, 92, 111, 2, 5, 4, 9, 22, 89, 96, 14, 1, 0, 1, 82, 59, 16, 20, 5, 25, 14, 11, 4, 0, 0, 1, 26, 47, 23, 4, 0, 0, 4, 38, 83, 30, 14, 9, 4, 9, 17, 23, 41, 0, 0, 2, 8, 19, 25, 23, 1]") ASC LIMIT 1; + + +-- delete whole table won't work for now. +-- delete from t2 +-- select sleep(10) + +drop table t2; + +-- end t2 + +-- t3 +create table t3(a bigint primary key, b vecf32(128)); + +load data infile {'filepath'='$resources/vector/sift128_base_10k.csv.gz', 'compression'='gzip'} into table t3 fields terminated by ':' parallel 'true'; + +select count(*) from t3; + +create index idx3 using hnsw on t3(b) op_type "vector_l2_ops" M 48 EF_CONSTRUCTION 64 EF_SEARCH 64 ASYNC; + +-- select sleep(30); + +load data infile {'filepath'='$resources/vector/sift128_base_10k_2.csv.gz', 'compression'='gzip'} into table t3 fields terminated by ':' parallel 'true'; + +select count(*) from t3; + +select sleep(45); + +select * from t3 order by L2_DISTANCE(b, "[14, 2, 0, 0, 0, 2, 42, 55, 9, 1, 0, 0, 18, 100, 77, 32, 89, 1, 0, 0, 19, 85, 15, 68, 52, 4, 0, 0, 0, 0, 2, 28, 34, 13, 5, 12, 49, 40, 39, 37, 24, 2, 0, 0, 34, 83, 88, 28, 119, 20, 0, 0, 41, 39, 13, 62, 119, 16, 2, 0, 0, 0, 10, 42, 9, 46, 82, 79, 64, 19, 2, 5, 10, 35, 26, 53, 84, 32, 34, 9, 119, 119, 21, 3, 3, 11, 17, 14, 119, 25, 8, 5, 0, 0, 11, 22, 23, 17, 42, 49, 17, 12, 5, 5, 12, 78, 119, 90, 27, 0, 4, 2, 48, 92, 112, 85, 15, 0, 2, 7, 50, 36, 15, 11, 1, 0, 0, 7]") ASC LIMIT 1; + +select * from t3 order by L2_DISTANCE(b, "[0, 16, 35, 5, 32, 31, 14, 10, 11, 78, 55, 10, 45, 83, 11, 6, 14, 57, 102, 75, 20, 8, 3, 5, 67, 17, 19, 26, 5, 0, 1, 22, 60, 26, 7, 1, 18, 22, 84, 53, 85, 119, 119, 4, 24, 18, 7, 7, 1, 81, 106, 102, 72, 30, 6, 0, 9, 1, 9, 119, 72, 1, 4, 33, 119, 29, 6, 1, 0, 1, 14, 52, 119, 30, 3, 0, 0, 55, 92, 111, 2, 5, 4, 9, 22, 89, 96, 14, 1, 0, 1, 82, 59, 16, 20, 5, 25, 14, 11, 4, 0, 0, 1, 26, 47, 23, 4, 0, 0, 4, 38, 83, 30, 14, 9, 4, 9, 17, 23, 41, 0, 0, 2, 8, 19, 25, 23, 1]") ASC LIMIT 1; + + +select * from t3 order by L2_DISTANCE(b, "[59, 0, 0, 1, 1, 1, 5, 100, 41, 0, 0, 4, 57, 34, 31, 115, 4, 0, 0, 12, 30, 33, 43, 85, 21, 0, 0, 14, 25, 9, 10, 60, 99, 11, 0, 0, 0, 0, 10, 55, 68, 1, 0, 3, 115, 65, 42, 115, 32, 3, 0, 4, 13, 21, 104, 115, 81, 15, 15, 23, 9, 2, 21, 75, 43, 20, 1, 0, 10, 2, 2, 20, 52, 35, 32, 61, 79, 8, 7, 41, 50, 106, 96, 20, 8, 2, 11, 39, 115, 48, 53, 11, 3, 0, 2, 43, 35, 11, 0, 1, 13, 7, 0, 1, 115, 58, 54, 29, 1, 2, 0, 3, 32, 115, 99, 34, 1, 0, 0, 0, 35, 15, 52, 44, 9, 0, 0, 18]") ASC LIMIT 1; + +select * from t3 order by L2_DISTANCE(b, "[0, 0, 0, 0, 0, 101, 82, 4, 2, 0, 0, 0, 3, 133, 133, 8, 46, 1, 2, 13, 15, 29, 87, 50, 22, 1, 0, 16, 25, 6, 18, 49, 5, 2, 0, 2, 3, 59, 70, 19, 18, 2, 0, 11, 42, 37, 30, 13, 133, 13, 4, 53, 28, 3, 8, 42, 77, 6, 11, 103, 36, 0, 0, 32, 7, 15, 59, 27, 2, 0, 2, 5, 14, 5, 55, 52, 51, 3, 2, 5, 133, 21, 10, 38, 26, 1, 0, 64, 71, 3, 10, 118, 53, 5, 6, 28, 33, 26, 73, 15, 0, 0, 0, 22, 13, 15, 133, 133, 4, 0, 0, 15, 107, 62, 46, 91, 9, 1, 7, 16, 28, 4, 0, 27, 33, 4, 15, 25]") ASC LIMIT 1; + +drop table t3; + +-- end t3 + +drop database hnsw_cdc; + diff --git a/test/distributed/cases/vector/vector_index.result b/test/distributed/cases/vector/vector_index.result index 5618003a88fd4..ae7cef583098f 100644 --- a/test/distributed/cases/vector/vector_index.result +++ b/test/distributed/cases/vector/vector_index.result @@ -128,7 +128,7 @@ create index idx01 using ivfflat on vector_index_07(b) lists=5 op_type "vector_l select * from vector_index_07 order by L2_DISTANCE(a, "[16, 15, 0, 0, 5, 46, 5, 5, 4, 0, 0, 0, 28, 118, 12, 5, 75, 44, 5, 0, 6, 32, 6, 49, 41, 74, 9, 1, 0, 0, 0, 9, 1, 9, 16, 41, 71, 80, 3, 0, 0, 4, 3, 5, 51, 106, 11, 3, 112, 28, 13, 1, 4, 8, 3, 104, 118, 14, 1, 1, 0, 0, 0, 88, 3, 27, 46, 118, 108, 49, 2, 0, 1, 46, 118, 118, 27, 12, 0, 0, 33, 118, 118, 8, 0, 0, 0, 4, 118, 95, 40, 0, 0, 0, 1, 11, 27, 38, 12, 12, 18, 29, 3, 2, 13, 30, 94, 78, 30, 19, 9, 3, 31, 45, 70, 42, 15, 1, 3, 12, 14, 22, 16, 2, 3, 17, 24, 13]") ASC LIMIT 2; invalid argument function l2_distance, bad value [INT VARCHAR] select * from vector_index_07 order by L2_DISTANCE(b, "[16, 15, 3, 0, 0, 4, 3, 5, 51]") ASC LIMIT 2; -invalid input: vector ops between different dimensions (128, 9) is not permitted. +invalid input: expected vector dimension 128 != actual dimension 9. select * from vector_index_07 order by L2_DISTANCE(b, "abc") ASC LIMIT 2; internal error: malformed vector input: abc create table vector_index_08(a int auto_increment primary key, b vecf32(128),c int,key c_k(c)); diff --git a/test/distributed/resources/vector/sift128_base_10k.csv.gz b/test/distributed/resources/vector/sift128_base_10k.csv.gz new file mode 100644 index 0000000000000..3c3b52655c35d Binary files /dev/null and b/test/distributed/resources/vector/sift128_base_10k.csv.gz differ diff --git a/test/distributed/resources/vector/sift128_base_10k_2.csv.gz b/test/distributed/resources/vector/sift128_base_10k_2.csv.gz new file mode 100644 index 0000000000000..095a5965daae4 Binary files /dev/null and b/test/distributed/resources/vector/sift128_base_10k_2.csv.gz differ