diff --git a/.gitignore b/.gitignore index 1c9a181..3a2238d 100644 --- a/.gitignore +++ b/.gitignore @@ -140,7 +140,7 @@ publish/ *.[Pp]ublish.xml *.azurePubxml -# TODO: Un-comment the next line if you do not want to checkin +# TODO: Un-comment the next line if you do not want to checkin # your web deploy settings because they may include unencrypted # passwords #*.pubxml @@ -166,6 +166,9 @@ csx/ ecf/ rcf/ +# Microsoft Azure ApplicationInsights config file +ApplicationInsights.config + # Windows Store app package directory AppPackages/ BundleArtifacts/ @@ -239,4 +242,4 @@ ModelManifest.xml .paket/paket.exe # FAKE - F# Make -.fake/ +.fake/ \ No newline at end of file diff --git a/AsPartitionProcessing/AdventureWorksDW.bak b/AsPartitionProcessing/AdventureWorksDW.bak new file mode 100644 index 0000000..34cc4c6 Binary files /dev/null and b/AsPartitionProcessing/AdventureWorksDW.bak differ diff --git a/AsPartitionProcessing/AsPartitionProcessing.AdventureWorks/AsPartitionProcessing.AdventureWorks.smproj b/AsPartitionProcessing/AsPartitionProcessing.AdventureWorks/AsPartitionProcessing.AdventureWorks.smproj new file mode 100644 index 0000000..d26bf54 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing.AdventureWorks/AsPartitionProcessing.AdventureWorks.smproj @@ -0,0 +1,42 @@ + + + + Development + 2.0 + {7274efcc-e7df-40ad-83df-1dfd5b954e67} + Exe + MyRootNamespace + MyAssemblyName + false + bin\ + AsPartitionProcessing.AdventureWorks + localhost + Developer + Version_11_0 + AW Tabular Model SQL 2014 + Model + Default + False + InMemory + Default + + + bin\ + localhost + Developer + Version_11_0 + AdventureWorks + Model + Default + False + InMemory + Default + + + + + Code + + + + \ No newline at end of file diff --git a/AsPartitionProcessing/AsPartitionProcessing.AdventureWorks/Model.bim b/AsPartitionProcessing/AsPartitionProcessing.AdventureWorks/Model.bim new file mode 100644 index 0000000..cf4cd59 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing.AdventureWorks/Model.bim @@ -0,0 +1,6009 @@ +{ + "name": "SemanticModel", + "id": "SemanticModel", + "compatibilityLevel": 1200, + "model": { + "culture": "en-US", + "dataSources": [ + { + "name": "AdventureWorksDW", + "connectionString": "Provider=SQLNCLI11;Data Source=localhost;Integrated Security=SSPI;Persist Security Info=false;Initial Catalog=AdventureWorksDW", + "impersonationMode": "impersonateServiceAccount", + "annotations": [ + { + "name": "ConnectionEditUISource", + "value": "SqlServer" + } + ] + } + ], + "tables": [ + { + "name": "Customer", + "columns": [ + { + "name": "Customer Id", + "dataType": "string", + "sourceColumn": "CustomerAlternateKey" + }, + { + "name": "Title", + "dataType": "string", + "sourceColumn": "Title" + }, + { + "name": "First Name", + "dataType": "string", + "sourceColumn": "FirstName" + }, + { + "name": "Middle Name", + "dataType": "string", + "sourceColumn": "MiddleName" + }, + { + "name": "Last Name", + "dataType": "string", + "sourceColumn": "LastName" + }, + { + "name": "Name Style", + "dataType": "boolean", + "sourceColumn": "NameStyle" + }, + { + "name": "Birth Date", + "dataType": "dateTime", + "sourceColumn": "BirthDate" + }, + { + "name": "Marital Status", + "dataType": "string", + "sourceColumn": "MaritalStatus" + }, + { + "name": "Suffix", + "dataType": "string", + "sourceColumn": "Suffix" + }, + { + "name": "Gender", + "dataType": "string", + "sourceColumn": "Gender" + }, + { + "name": "Email Address", + "dataType": "string", + "sourceColumn": "EmailAddress" + }, + { + "name": "Yearly Income", + "dataType": "decimal", + "sourceColumn": "YearlyIncome", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Children", + "dataType": "int64", + "sourceColumn": "TotalChildren", + "summarizeBy": "none" + }, + { + "name": "Number of Children At Home", + "dataType": "int64", + "sourceColumn": "NumberChildrenAtHome", + "summarizeBy": "none" + }, + { + "name": "Education", + "dataType": "string", + "sourceColumn": "EnglishEducation" + }, + { + "name": "Occupation", + "dataType": "string", + "sourceColumn": "EnglishOccupation" + }, + { + "name": "Owns House", + "dataType": "boolean", + "sourceColumn": "HouseOwnerFlag", + "formatString": "\"TRUE\";\"TRUE\";\"FALSE\"" + }, + { + "name": "Address Line 1", + "dataType": "string", + "sourceColumn": "AddressLine1" + }, + { + "name": "Address Line 2", + "dataType": "string", + "sourceColumn": "AddressLine2" + }, + { + "name": "Date Of First Purchase", + "dataType": "dateTime", + "sourceColumn": "DateFirstPurchase" + }, + { + "name": "Commute Distance", + "dataType": "string", + "sourceColumn": "CommuteDistance" + }, + { + "name": "CustomerKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "CustomerKey" + }, + { + "name": "GeographyKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "GeographyKey" + }, + { + "name": "Total Cars Owned", + "dataType": "int64", + "sourceColumn": "NumberCarsOwned", + "summarizeBy": "none" + }, + { + "name": "Phone", + "dataType": "string", + "sourceColumn": "Phone" + } + ], + "partitions": [ + { + "name": "Customer", + "source": { + "query": "SELECT [dbo].[DimCustomer].* \t\tFROM [dbo].[DimCustomer]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization" + }, + { + "name": "QueryEditorSerialization" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "DimCustomer" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[DimCustomer].* FROM [dbo].[DimCustomer] " + } + ] + }, + { + "name": "Date", + "dataCategory": "Time", + "columns": [ + { + "name": "Date", + "dataType": "dateTime", + "isKey": true, + "sourceColumn": "FullDateAlternateKey" + }, + { + "name": "Day Number Of Week", + "dataType": "int64", + "sourceColumn": "DayNumberOfWeek", + "summarizeBy": "none" + }, + { + "name": "Day Of Month", + "dataType": "int64", + "sourceColumn": "DayNumberOfMonth", + "summarizeBy": "none" + }, + { + "name": "Day Of Year", + "dataType": "int64", + "sourceColumn": "DayNumberOfYear", + "summarizeBy": "none" + }, + { + "name": "Month Name", + "dataType": "string", + "sourceColumn": "EnglishMonthName", + "sortByColumn": "Month" + }, + { + "name": "Month", + "dataType": "int64", + "sourceColumn": "MonthNumberOfYear", + "summarizeBy": "none" + }, + { + "name": "Calendar Quarter", + "dataType": "int64", + "sourceColumn": "CalendarQuarter", + "summarizeBy": "none" + }, + { + "name": "Calendar Year", + "dataType": "int64", + "sourceColumn": "CalendarYear", + "summarizeBy": "none" + }, + { + "name": "Calendar Semester", + "dataType": "int64", + "sourceColumn": "CalendarSemester", + "summarizeBy": "none" + }, + { + "name": "Fiscal Quarter", + "dataType": "int64", + "sourceColumn": "FiscalQuarter", + "summarizeBy": "none" + }, + { + "name": "Fiscal Year", + "dataType": "int64", + "sourceColumn": "FiscalYear", + "summarizeBy": "none" + }, + { + "name": "Fiscal Semester", + "dataType": "int64", + "sourceColumn": "FiscalSemester", + "summarizeBy": "none" + }, + { + "name": "DateKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "DateKey", + "summarizeBy": "none" + }, + { + "name": "Day Name Of Week", + "dataType": "string", + "sourceColumn": "EnglishDayNameOfWeek", + "sortByColumn": "Day Number Of Week" + }, + { + "name": "Week Of Year", + "dataType": "int64", + "sourceColumn": "WeekNumberOfYear", + "summarizeBy": "none" + } + ], + "partitions": [ + { + "name": "Date", + "source": { + "query": "SELECT [dbo].[DimDate].* \t\tFROM [dbo].[DimDate]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization" + }, + { + "name": "QueryEditorSerialization" + } + ] + } + ], + "measures": [ + { + "name": "Days In Current Quarter", + "expression": "COUNTROWS( DATESBETWEEN( 'Date'[Date], STARTOFQUARTER( LASTDATE('Date'[Date])), ENDOFQUARTER('Date'[Date])))" + }, + { + "name": "Days In Current Quarter to Date", + "expression": "COUNTROWS( DATESQTD( 'Date'[Date]))" + } + ], + "hierarchies": [ + { + "name": "Calendar", + "levels": [ + { + "name": "Year", + "ordinal": 0, + "column": "Calendar Year" + }, + { + "name": "Semester", + "ordinal": 1, + "column": "Calendar Semester" + }, + { + "name": "Quarter", + "ordinal": 2, + "column": "Calendar Quarter" + }, + { + "name": "Month", + "ordinal": 3, + "column": "Month Name" + }, + { + "name": "Day", + "ordinal": 4, + "column": "Day Of Month" + } + ] + }, + { + "name": "Fiscal", + "levels": [ + { + "name": "Month", + "ordinal": 3, + "column": "Month Name" + }, + { + "name": "Day", + "ordinal": 4, + "column": "Day Of Month" + }, + { + "name": "Fiscal Year", + "ordinal": 0, + "column": "Fiscal Year" + }, + { + "name": "Fiscal Semester", + "ordinal": 1, + "column": "Fiscal Semester" + }, + { + "name": "Fiscal Quarter", + "ordinal": 2, + "column": "Fiscal Quarter" + } + ] + }, + { + "name": "Production Calendar", + "levels": [ + { + "name": "Year", + "ordinal": 0, + "column": "Calendar Year" + }, + { + "name": "Week", + "ordinal": 1, + "column": "Week Of Year" + }, + { + "name": "Week Day", + "ordinal": 2, + "column": "Day Name Of Week" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "DimDate" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[DimDate].* FROM [dbo].[DimDate] " + } + ] + }, + { + "name": "Geography", + "columns": [ + { + "name": "City", + "dataType": "string", + "sourceColumn": "City" + }, + { + "name": "State Province Code", + "dataType": "string", + "sourceColumn": "StateProvinceCode" + }, + { + "name": "State Province Name", + "dataType": "string", + "sourceColumn": "StateProvinceName" + }, + { + "name": "Country Region Code", + "dataType": "string", + "sourceColumn": "CountryRegionCode" + }, + { + "name": "Country Region Name", + "dataType": "string", + "sourceColumn": "EnglishCountryRegionName" + }, + { + "name": "Postal Code", + "dataType": "string", + "sourceColumn": "PostalCode" + }, + { + "name": "GeographyKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "GeographyKey" + }, + { + "name": "SalesTerritoryKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "SalesTerritoryKey" + } + ], + "partitions": [ + { + "name": "Geography", + "source": { + "query": "SELECT [dbo].[DimGeography].* \t\tFROM [dbo].[DimGeography]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization" + }, + { + "name": "QueryEditorSerialization" + } + ] + } + ], + "hierarchies": [ + { + "name": "Geography", + "levels": [ + { + "name": "Country Region", + "ordinal": 0, + "column": "Country Region Name" + }, + { + "name": "State Province", + "ordinal": 1, + "column": "State Province Name" + }, + { + "name": "City", + "ordinal": 2, + "column": "City" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "DimGeography" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[DimGeography].* FROM [dbo].[DimGeography] " + } + ] + }, + { + "name": "Product", + "columns": [ + { + "name": "Product Id", + "dataType": "string", + "sourceColumn": "ProductAlternateKey" + }, + { + "name": "Weight Unit Code", + "dataType": "string", + "sourceColumn": "WeightUnitMeasureCode" + }, + { + "name": "Size Unit Code", + "dataType": "string", + "sourceColumn": "SizeUnitMeasureCode" + }, + { + "name": "Product Name", + "dataType": "string", + "sourceColumn": "EnglishProductName", + "isDefaultLabel": true + }, + { + "name": "Standard Cost", + "dataType": "decimal", + "sourceColumn": "StandardCost", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Color", + "dataType": "string", + "sourceColumn": "Color" + }, + { + "name": "Safety Stock Level", + "dataType": "int64", + "sourceColumn": "SafetyStockLevel", + "summarizeBy": "none" + }, + { + "name": "Reorder Point", + "dataType": "int64", + "sourceColumn": "ReorderPoint", + "summarizeBy": "none" + }, + { + "name": "List Price", + "dataType": "decimal", + "sourceColumn": "ListPrice", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Size", + "dataType": "string", + "sourceColumn": "Size" + }, + { + "name": "Size Range", + "dataType": "string", + "sourceColumn": "SizeRange" + }, + { + "name": "Weight", + "dataType": "double", + "sourceColumn": "Weight", + "summarizeBy": "none" + }, + { + "name": "Days To Manufacture", + "dataType": "int64", + "sourceColumn": "DaysToManufacture" + }, + { + "name": "Product Line", + "dataType": "string", + "sourceColumn": "ProductLine" + }, + { + "name": "Dealer Price", + "dataType": "decimal", + "sourceColumn": "DealerPrice", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Class", + "dataType": "string", + "sourceColumn": "Class" + }, + { + "name": "Style", + "dataType": "string", + "sourceColumn": "Style" + }, + { + "name": "Model Name", + "dataType": "string", + "sourceColumn": "ModelName" + }, + { + "name": "Description", + "dataType": "string", + "sourceColumn": "EnglishDescription" + }, + { + "name": "Product Start Date", + "dataType": "dateTime", + "sourceColumn": "StartDate" + }, + { + "name": "Product End Date", + "dataType": "dateTime", + "sourceColumn": "EndDate" + }, + { + "name": "Product Status", + "dataType": "string", + "sourceColumn": "Status" + }, + { + "type": "calculated", + "name": "Product SubCategory Name", + "dataType": "string", + "isDataTypeInferred": true, + "expression": "RELATED('Product SubCategory'[Product Subcategory Name])" + }, + { + "type": "calculated", + "name": "Product Category Name", + "dataType": "string", + "isDataTypeInferred": true, + "expression": "RELATED('Product Category'[Product Category Name])" + }, + { + "name": "ProductKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ProductKey" + }, + { + "name": "ProductSubcategoryKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ProductSubcategoryKey" + }, + { + "name": "Is Finished Goods", + "dataType": "boolean", + "sourceColumn": "FinishedGoodsFlag" + }, + { + "name": "LargePhoto", + "dataType": "binary", + "sourceColumn": "LargePhoto", + "isDefaultImage": true + } + ], + "partitions": [ + { + "name": "Product", + "source": { + "query": "SELECT [dbo].[DimProduct].* \t\tFROM [dbo].[DimProduct]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization" + }, + { + "name": "QueryEditorSerialization" + } + ] + } + ], + "hierarchies": [ + { + "name": "Category", + "levels": [ + { + "name": "Category", + "ordinal": 0, + "column": "Product Category Name" + }, + { + "name": "SubCategory", + "ordinal": 1, + "column": "Product SubCategory Name" + }, + { + "name": "Model", + "ordinal": 2, + "column": "Model Name" + }, + { + "name": "Product", + "ordinal": 3, + "column": "Product Name" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "DimProduct" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[DimProduct].* FROM [dbo].[DimProduct] " + } + ] + }, + { + "name": "Product Category", + "columns": [ + { + "name": "Product Category Name", + "dataType": "string", + "sourceColumn": "EnglishProductCategoryName" + }, + { + "name": "ProductCategoryKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ProductCategoryKey", + "summarizeBy": "none" + } + ], + "partitions": [ + { + "name": "Product Category", + "source": { + "query": "SELECT [dbo].[DimProductCategory].* \t\tFROM [dbo].[DimProductCategory]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization" + }, + { + "name": "QueryEditorSerialization" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "DimProductCategory" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[DimProductCategory].* FROM [dbo].[DimProductCategory] " + } + ] + }, + { + "name": "Product Subcategory", + "columns": [ + { + "name": "Product Subcategory Name", + "dataType": "string", + "sourceColumn": "EnglishProductSubcategoryName" + }, + { + "name": "ProductSubcategoryKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ProductSubcategoryKey", + "summarizeBy": "none" + }, + { + "name": "ProductCategoryKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ProductCategoryKey", + "summarizeBy": "none" + } + ], + "partitions": [ + { + "name": "Product Subcategory", + "source": { + "query": "SELECT [dbo].[DimProductSubcategory].* \t\tFROM [dbo].[DimProductSubcategory]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization" + }, + { + "name": "QueryEditorSerialization" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "DimProductSubcategory" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[DimProductSubcategory].* FROM [dbo].[DimProductSubcategory] " + } + ] + }, + { + "name": "Currency", + "columns": [ + { + "name": "CurrencyKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "CurrencyKey" + }, + { + "name": "Currency Code", + "dataType": "string", + "sourceColumn": "CurrencyAlternateKey" + }, + { + "name": "CurrencyName", + "dataType": "string", + "sourceColumn": "CurrencyName" + } + ], + "partitions": [ + { + "name": "Currency", + "source": { + "query": "SELECT [dbo].[DimCurrency].* \t\tFROM [dbo].[DimCurrency]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "QueryEditorSerialization" + }, + { + "name": "TableWidgetSerialization" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "DimCurrency" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[DimCurrency].* FROM [dbo].[DimCurrency] " + } + ] + }, + { + "name": "Employee", + "columns": [ + { + "name": "EmployeeKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "EmployeeKey", + "summarizeBy": "none" + }, + { + "name": "ParentEmployeeKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ParentEmployeeKey", + "summarizeBy": "none" + }, + { + "name": "Employee Id", + "dataType": "string", + "sourceColumn": "EmployeeNationalIDAlternateKey" + }, + { + "name": "SalesTerritoryKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "SalesTerritoryKey" + }, + { + "name": "First Name", + "dataType": "string", + "sourceColumn": "FirstName" + }, + { + "name": "Last Name", + "dataType": "string", + "sourceColumn": "LastName" + }, + { + "name": "Middle Name", + "dataType": "string", + "sourceColumn": "MiddleName" + }, + { + "name": "NameStyle", + "dataType": "boolean", + "sourceColumn": "NameStyle" + }, + { + "name": "Title", + "dataType": "string", + "sourceColumn": "Title" + }, + { + "name": "Hire Date", + "dataType": "dateTime", + "sourceColumn": "HireDate" + }, + { + "name": "Birth Date", + "dataType": "dateTime", + "sourceColumn": "BirthDate" + }, + { + "name": "Login", + "dataType": "string", + "sourceColumn": "LoginID" + }, + { + "name": "Email", + "dataType": "string", + "sourceColumn": "EmailAddress" + }, + { + "name": "Phone", + "dataType": "string", + "sourceColumn": "Phone" + }, + { + "name": "Marital Status", + "dataType": "string", + "sourceColumn": "MaritalStatus" + }, + { + "name": "Emergency Contact Name", + "dataType": "string", + "sourceColumn": "EmergencyContactName" + }, + { + "name": "Emergency Contact Phone", + "dataType": "string", + "sourceColumn": "EmergencyContactPhone" + }, + { + "name": "Is Salaried", + "dataType": "boolean", + "sourceColumn": "SalariedFlag" + }, + { + "name": "Gender", + "dataType": "string", + "sourceColumn": "Gender" + }, + { + "name": "Pay Frequency", + "dataType": "int64", + "sourceColumn": "PayFrequency", + "summarizeBy": "none" + }, + { + "name": "Base Rate", + "dataType": "decimal", + "sourceColumn": "BaseRate", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Vacation Hours", + "dataType": "int64", + "sourceColumn": "VacationHours", + "summarizeBy": "none" + }, + { + "name": "Sick Leave Hours", + "dataType": "int64", + "sourceColumn": "SickLeaveHours", + "summarizeBy": "none" + }, + { + "name": "Is Current", + "dataType": "boolean", + "sourceColumn": "CurrentFlag" + }, + { + "name": "Is Sales Person", + "dataType": "boolean", + "sourceColumn": "SalesPersonFlag" + }, + { + "name": "Department Name", + "dataType": "string", + "sourceColumn": "DepartmentName" + }, + { + "name": "Start Date", + "dataType": "dateTime", + "sourceColumn": "StartDate" + }, + { + "name": "End Date", + "dataType": "dateTime", + "sourceColumn": "EndDate" + }, + { + "name": "Status", + "dataType": "string", + "sourceColumn": "Status" + }, + { + "name": "Employee Photo", + "dataType": "binary", + "sourceColumn": "EmployeePhoto", + "isDefaultImage": true + } + ], + "partitions": [ + { + "name": "Employee", + "source": { + "query": "SELECT [dbo].[DimEmployee].* \t\tFROM [dbo].[DimEmployee]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "QueryEditorSerialization" + }, + { + "name": "TableWidgetSerialization" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "DimEmployee" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[DimEmployee].* FROM [dbo].[DimEmployee] " + } + ] + }, + { + "name": "Promotion", + "columns": [ + { + "name": "PromotionKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "PromotionKey", + "summarizeBy": "none" + }, + { + "name": "Promotion Name", + "dataType": "string", + "sourceColumn": "EnglishPromotionName" + }, + { + "name": "DiscountPct", + "dataType": "double", + "sourceColumn": "DiscountPct", + "formatString": "0.00", + "summarizeBy": "none" + }, + { + "name": "Promotion Type", + "dataType": "string", + "sourceColumn": "EnglishPromotionType" + }, + { + "name": "Promotion Category", + "dataType": "string", + "sourceColumn": "EnglishPromotionCategory" + }, + { + "name": "Promotion Start Date", + "dataType": "dateTime", + "sourceColumn": "StartDate" + }, + { + "name": "Promotion End Date", + "dataType": "dateTime", + "sourceColumn": "EndDate" + }, + { + "name": "Min Quantity", + "dataType": "int64", + "sourceColumn": "MinQty" + }, + { + "name": "Max Quantity", + "dataType": "int64", + "sourceColumn": "MaxQty" + } + ], + "partitions": [ + { + "name": "Promotion", + "source": { + "query": "SELECT [dbo].[DimPromotion].* \t\tFROM [dbo].[DimPromotion]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "QueryEditorSerialization" + }, + { + "name": "TableWidgetSerialization" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "DimPromotion" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[DimPromotion].* FROM [dbo].[DimPromotion] " + } + ] + }, + { + "name": "Reseller", + "columns": [ + { + "name": "ResellerKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ResellerKey" + }, + { + "name": "GeographyKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "GeographyKey" + }, + { + "name": "Reseller Id", + "dataType": "string", + "sourceColumn": "ResellerAlternateKey" + }, + { + "name": "Reseller Phone", + "dataType": "string", + "sourceColumn": "Phone" + }, + { + "name": "Business Type", + "dataType": "string", + "sourceColumn": "BusinessType" + }, + { + "name": "Reseller Name", + "dataType": "string", + "sourceColumn": "ResellerName", + "isDefaultLabel": true + }, + { + "name": "Number Employees", + "dataType": "int64", + "sourceColumn": "NumberEmployees", + "summarizeBy": "none" + }, + { + "name": "Order Frequency", + "dataType": "string", + "sourceColumn": "OrderFrequency" + }, + { + "name": "Order Month", + "dataType": "int64", + "sourceColumn": "OrderMonth" + }, + { + "name": "First Order Year", + "dataType": "int64", + "sourceColumn": "FirstOrderYear", + "summarizeBy": "none" + }, + { + "name": "Last Order Year", + "dataType": "int64", + "sourceColumn": "LastOrderYear", + "summarizeBy": "none" + }, + { + "name": "Product Line", + "dataType": "string", + "sourceColumn": "ProductLine" + }, + { + "name": "Address Line 1", + "dataType": "string", + "sourceColumn": "AddressLine1" + }, + { + "name": "Address Line 2", + "dataType": "string", + "sourceColumn": "AddressLine2" + }, + { + "name": "Annual Sales", + "dataType": "decimal", + "sourceColumn": "AnnualSales", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Bank Name", + "dataType": "string", + "sourceColumn": "BankName" + }, + { + "name": "Min Payment Type", + "dataType": "int64", + "sourceColumn": "MinPaymentType", + "summarizeBy": "none" + }, + { + "name": "Min Payment Amount", + "dataType": "decimal", + "sourceColumn": "MinPaymentAmount", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Annua Revenue", + "dataType": "decimal", + "sourceColumn": "AnnualRevenue", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Year Opened", + "dataType": "int64", + "sourceColumn": "YearOpened", + "summarizeBy": "none" + } + ], + "partitions": [ + { + "name": "Reseller", + "source": { + "query": "SELECT [dbo].[DimReseller].* \t\tFROM [dbo].[DimReseller]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "QueryEditorSerialization" + }, + { + "name": "TableWidgetSerialization" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "DimReseller" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[DimReseller].* FROM [dbo].[DimReseller] " + } + ] + }, + { + "name": "Sales Territory", + "columns": [ + { + "name": "SalesTerritoryKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "SalesTerritoryKey" + }, + { + "name": "Sales Territory Region", + "dataType": "string", + "sourceColumn": "SalesTerritoryRegion", + "isDefaultLabel": true + }, + { + "name": "Sales Territory Country", + "dataType": "string", + "sourceColumn": "SalesTerritoryCountry" + }, + { + "name": "Sales Territory Group", + "dataType": "string", + "sourceColumn": "SalesTerritoryGroup" + }, + { + "name": "Sales Territory Image", + "dataType": "binary", + "sourceColumn": "SalesTerritoryImage", + "isDefaultImage": true + } + ], + "partitions": [ + { + "name": "Sales Territory", + "source": { + "query": "SELECT [dbo].[DimSalesTerritory].* \t\tFROM [dbo].[DimSalesTerritory]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "QueryEditorSerialization" + }, + { + "name": "TableWidgetSerialization" + } + ] + } + ], + "measures": [ + { + "name": "Distinct Count Sales Orders", + "expression": "[Reseller Distinct Count Sales Order] + [Internet Distinct Count Sales Order]", + "formatString": "#,0" + }, + { + "name": "Total Sales", + "expression": "[Reseller Total Sales] + [Internet Total Sales]", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Discount Amount", + "expression": "[Reseller Total Discount Amount] + [Internet Total Discount Amount]", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Products Cost", + "expression": "[Reseller Total Product Cost] + [Internet Total Product Cost]", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Tax Amount", + "expression": "[Reseller Total Tax Amount] + [Internet Total Tax Amount]", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Freight", + "expression": "[Reseller Total Freight] + [Internet Total Freight]", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Gross Profit", + "expression": "[Reseller Total Gross Profit] + [Internet Total Gross Profit]", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Units Sold", + "expression": "[Reseller Total Units] + [Internet Total Units]", + "formatString": "#,0" + }, + { + "name": "Order Lines Count", + "expression": "[Reseller Order Lines Count] + [Internet Order Lines Count]", + "formatString": "#,0" + }, + { + "name": "Total Previous Quarter Gross Profit", + "expression": "CALCULATE([Total Gross Profit], PREVIOUSQUARTER('Date'[Date]))", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Current Quarter Gross Profit", + "expression": "TOTALQTD([Total Gross Profit],'Date'[Date])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Previous Quarter Gross Profit Proportion to QTD", + "expression": "[Total Previous Quarter Gross Profit]*([Days In Current Quarter to Date]/[Days In Current Quarter])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Previous Quarter Sales", + "expression": "CALCULATE([Total Sales], PREVIOUSQUARTER('Date'[Date]))", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Current Quarter Sales", + "expression": "TOTALQTD([Total Sales],'Date'[Date])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Previous Quarter Sales Proportion to QTD", + "expression": "[Total Previous Quarter Sales]*([Days In Current Quarter to Date]/[Days In Current Quarter])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Sales - Sales Territory sliced by Employee", + "expression": "[Reseller Total Sales - Sales Territory sliced by Employee] + [Internet Total Sales]", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Current Quarter Sales Performance", + "expression": "IFERROR([Total Current Quarter Sales]/[Total Previous Quarter Sales Proportion to QTD],BLANK())", + "kpi": { + "targetExpression": "1.1", + "statusGraphic": "Three Symbols UnCircled Colored", + "statusExpression": [ + "if(ISBLANK('Sales Territory'[Total Current Quarter Sales Performance]),BLANK(),", + " If('Sales Territory'[Total Current Quarter Sales Performance]<0.8,-1,", + "\t If('Sales Territory'[Total Current Quarter Sales Performance]<1.07,0,1)", + " )", + " )", + " " + ], + "annotations": [ + { + "name": "GoalType", + "value": "StaticValue" + }, + { + "name": "KpiStatusType", + "value": "Linear" + }, + { + "name": "KpiThresholdType", + "value": "Absolute" + }, + { + "name": "KpiThresholdOrdering", + "value": "Ascending" + }, + { + "name": "KpiThresholdCount", + "value": "2" + }, + { + "name": "KpiThreshold_0", + "value": "0.8" + }, + { + "name": "KpiThreshold_1", + "value": "1.07" + } + ] + } + }, + { + "name": "Total Current Quarter Gross Profit Performance", + "expression": "IF([Total Previous Quarter Gross Profit Proportion to QTD]<>0,([Total Current Quarter Gross Profit]-[Total Previous Quarter Gross Profit Proportion to QTD])/[Total Previous Quarter Gross Profit Proportion to QTD],BLANK())", + "kpi": { + "targetExpression": "1.25", + "statusGraphic": "Three Symbols UnCircled Colored", + "statusExpression": [ + "if(ISBLANK('Sales Territory'[Total Current Quarter Gross Profit Performance]),BLANK(),", + " If('Sales Territory'[Total Current Quarter Gross Profit Performance]<0.8,-1,", + "\t If('Sales Territory'[Total Current Quarter Gross Profit Performance]<1.03,0,1)", + " )", + " )", + " " + ], + "annotations": [ + { + "name": "GoalType", + "value": "StaticValue" + }, + { + "name": "KpiStatusType", + "value": "Linear" + }, + { + "name": "KpiThresholdType", + "value": "Absolute" + }, + { + "name": "KpiThresholdOrdering", + "value": "Ascending" + }, + { + "name": "KpiThresholdCount", + "value": "2" + }, + { + "name": "KpiThreshold_0", + "value": "0.8" + }, + { + "name": "KpiThreshold_1", + "value": "1.03" + } + ] + } + } + ], + "hierarchies": [ + { + "name": "Territory", + "levels": [ + { + "name": "Group", + "ordinal": 0, + "column": "Sales Territory Group" + }, + { + "name": "Country", + "ordinal": 1, + "column": "Sales Territory Country" + }, + { + "name": "Region", + "ordinal": 2, + "column": "Sales Territory Region" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "DimSalesTerritory" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[DimSalesTerritory].* FROM [dbo].[DimSalesTerritory] " + } + ] + }, + { + "name": "Product Inventory", + "columns": [ + { + "name": "ProductKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ProductKey" + }, + { + "name": "DateKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "DateKey" + }, + { + "name": "Movement Date", + "dataType": "dateTime", + "sourceColumn": "MovementDate", + "formatString": "Short Date", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Unit Cost", + "dataType": "decimal", + "sourceColumn": "UnitCost", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Units In", + "dataType": "int64", + "sourceColumn": "UnitsIn" + }, + { + "name": "Units Out", + "dataType": "int64", + "sourceColumn": "UnitsOut" + }, + { + "name": "Units Balance", + "dataType": "int64", + "sourceColumn": "UnitsBalance", + "summarizeBy": "none" + }, + { + "type": "calculated", + "name": "Product-Date Inventory Value", + "dataType": "decimal", + "isDataTypeInferred": true, + "expression": "[Unit Cost]*[Units Balance]", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "type": "calculated", + "name": "Product-Date Optimal Inventory Value", + "dataType": "decimal", + "isDataTypeInferred": true, + "expression": "[Unit Cost]*RELATED('Product'[Reorder Point])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "type": "calculated", + "name": "Product-Date Max Inventory Value", + "dataType": "decimal", + "isDataTypeInferred": true, + "expression": "[Unit Cost]*RELATED('Product'[Safety Stock Level])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "type": "calculated", + "name": "Product-Date OverStocked", + "dataType": "int64", + "isDataTypeInferred": true, + "expression": "IF([Units Balance]>RELATED('Product'[Safety Stock Level]),1,0)" + }, + { + "type": "calculated", + "name": "Product-Date UnderStocked", + "dataType": "int64", + "isDataTypeInferred": true, + "expression": "IF([Units Balance]= 20050101) AND ([DateKey] <= 20051231))", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization", + "value": [ + "<?xml version=\"1.0\" encoding=\"UTF-16\"?><Gemini xmlns=\"TableWidgetSerialization\"><AnnotationContent><![CDATA[<?xml version=\"1.0\"?>", + "<TableWidgetGridSerialization xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">", + " <ColumnSuggestedType />", + " <ColumnFormat />", + " <ColumnAccuracy />", + " <ColumnCurrencySymbol />", + " <ColumnPositivePattern />", + " <ColumnNegativePattern />", + " <ColumnWidths>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>105</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>123</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>84</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>92</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>111</int>", + " </value>", + " </item>", + " </ColumnWidths>", + " <ColumnDisplayIndex>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>0</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>1</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>2</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>3</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>4</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>5</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>6</int>", + " </value>", + " </item>", + " </ColumnDisplayIndex>", + " <ColumnFrozen />", + " <ColumnChecked />", + " <ColumnFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <FilterExpression xsi:type=\"LogicalExpression\">", + " <Operator>AND</Operator>", + " <ExpressionList>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>GreaterThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20050101</Value>", + " </FilterExpression>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>LesserThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20051231</Value>", + " </FilterExpression>", + " </ExpressionList>", + " </FilterExpression>", + " </value>", + " </item>", + " </ColumnFilter>", + " <SelectionFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <SelectionFilter xsi:nil=\"true\" />", + " </value>", + " </item>", + " </SelectionFilter>", + " <FilterParameters>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <CommandParameters />", + " </value>", + " </item>", + " </FilterParameters>", + " <IsSortDescending>false</IsSortDescending>", + "</TableWidgetGridSerialization>]]></AnnotationContent></Gemini>" + ] + }, + { + "name": "TableWidgetSourceTable" + }, + { + "name": "QueryEditorSerialization" + } + ] + }, + { + "name": "Product Inventory 2006", + "mode": "import", + "source": { + "query": "SELECT [dbo].[FactProductInventory].* \t\tFROM [dbo].[FactProductInventory] WHERE (([DateKey] >= 20060101) AND ([DateKey] <= 20061231))", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization", + "value": [ + "<?xml version=\"1.0\" encoding=\"UTF-16\"?><Gemini xmlns=\"TableWidgetSerialization\"><AnnotationContent><![CDATA[<?xml version=\"1.0\"?>", + "<TableWidgetGridSerialization xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">", + " <ColumnSuggestedType />", + " <ColumnFormat />", + " <ColumnAccuracy />", + " <ColumnCurrencySymbol />", + " <ColumnPositivePattern />", + " <ColumnNegativePattern />", + " <ColumnWidths>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>105</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>123</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>84</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>92</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>111</int>", + " </value>", + " </item>", + " </ColumnWidths>", + " <ColumnDisplayIndex>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>0</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>1</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>2</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>3</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>4</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>5</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>6</int>", + " </value>", + " </item>", + " </ColumnDisplayIndex>", + " <ColumnFrozen />", + " <ColumnChecked />", + " <ColumnFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <FilterExpression xsi:type=\"LogicalExpression\">", + " <Operator>AND</Operator>", + " <ExpressionList>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>GreaterThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20060101</Value>", + " </FilterExpression>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>LesserThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20061231</Value>", + " </FilterExpression>", + " </ExpressionList>", + " </FilterExpression>", + " </value>", + " </item>", + " </ColumnFilter>", + " <SelectionFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <SelectionFilter xsi:nil=\"true\" />", + " </value>", + " </item>", + " </SelectionFilter>", + " <FilterParameters>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <CommandParameters />", + " </value>", + " </item>", + " </FilterParameters>", + " <IsSortDescending>false</IsSortDescending>", + "</TableWidgetGridSerialization>]]></AnnotationContent></Gemini>" + ] + }, + { + "name": "TableWidgetSourceTable" + }, + { + "name": "QueryEditorSerialization" + } + ] + }, + { + "name": "Product Inventory 2007", + "mode": "import", + "source": { + "query": "SELECT [dbo].[FactProductInventory].* \t\tFROM [dbo].[FactProductInventory] WHERE (([DateKey] >= 20070101) AND ([DateKey] <= 20071231))", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization", + "value": [ + "<?xml version=\"1.0\" encoding=\"UTF-16\"?><Gemini xmlns=\"TableWidgetSerialization\"><AnnotationContent><![CDATA[<?xml version=\"1.0\"?>", + "<TableWidgetGridSerialization xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">", + " <ColumnSuggestedType />", + " <ColumnFormat />", + " <ColumnAccuracy />", + " <ColumnCurrencySymbol />", + " <ColumnPositivePattern />", + " <ColumnNegativePattern />", + " <ColumnWidths>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>105</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>123</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>84</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>92</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>111</int>", + " </value>", + " </item>", + " </ColumnWidths>", + " <ColumnDisplayIndex>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>0</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>1</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>2</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>3</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>4</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>5</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>6</int>", + " </value>", + " </item>", + " </ColumnDisplayIndex>", + " <ColumnFrozen />", + " <ColumnChecked />", + " <ColumnFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <FilterExpression xsi:type=\"LogicalExpression\">", + " <Operator>AND</Operator>", + " <ExpressionList>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>GreaterThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20070101</Value>", + " </FilterExpression>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>LesserThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20071231</Value>", + " </FilterExpression>", + " </ExpressionList>", + " </FilterExpression>", + " </value>", + " </item>", + " </ColumnFilter>", + " <SelectionFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <SelectionFilter xsi:nil=\"true\" />", + " </value>", + " </item>", + " </SelectionFilter>", + " <FilterParameters>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <CommandParameters />", + " </value>", + " </item>", + " </FilterParameters>", + " <IsSortDescending>false</IsSortDescending>", + "</TableWidgetGridSerialization>]]></AnnotationContent></Gemini>" + ] + }, + { + "name": "TableWidgetSourceTable" + }, + { + "name": "QueryEditorSerialization" + } + ] + }, + { + "name": "Product Inventory 2008", + "mode": "import", + "source": { + "query": "SELECT [dbo].[FactProductInventory].* \t\tFROM [dbo].[FactProductInventory] WHERE (([DateKey] >= 20080101) AND ([DateKey] <= 20081231))", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization", + "value": [ + "<?xml version=\"1.0\" encoding=\"UTF-16\"?><Gemini xmlns=\"TableWidgetSerialization\"><AnnotationContent><![CDATA[<?xml version=\"1.0\"?>", + "<TableWidgetGridSerialization xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">", + " <ColumnSuggestedType />", + " <ColumnFormat />", + " <ColumnAccuracy />", + " <ColumnCurrencySymbol />", + " <ColumnPositivePattern />", + " <ColumnNegativePattern />", + " <ColumnWidths>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>105</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>123</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>84</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>92</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>111</int>", + " </value>", + " </item>", + " </ColumnWidths>", + " <ColumnDisplayIndex>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>0</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>1</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>2</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>3</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>4</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>5</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>6</int>", + " </value>", + " </item>", + " </ColumnDisplayIndex>", + " <ColumnFrozen />", + " <ColumnChecked />", + " <ColumnFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <FilterExpression xsi:type=\"LogicalExpression\">", + " <Operator>AND</Operator>", + " <ExpressionList>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>GreaterThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20080101</Value>", + " </FilterExpression>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>LesserThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20081231</Value>", + " </FilterExpression>", + " </ExpressionList>", + " </FilterExpression>", + " </value>", + " </item>", + " </ColumnFilter>", + " <SelectionFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <SelectionFilter xsi:nil=\"true\" />", + " </value>", + " </item>", + " </SelectionFilter>", + " <FilterParameters>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <CommandParameters />", + " </value>", + " </item>", + " </FilterParameters>", + " <IsSortDescending>false</IsSortDescending>", + "</TableWidgetGridSerialization>]]></AnnotationContent></Gemini>" + ] + }, + { + "name": "TableWidgetSourceTable" + }, + { + "name": "QueryEditorSerialization" + } + ] + }, + { + "name": "Product Inventory 2009", + "mode": "import", + "source": { + "query": "SELECT [dbo].[FactProductInventory].* \t\tFROM [dbo].[FactProductInventory] WHERE (([DateKey] >= 20090101) AND ([DateKey] <= 20091231))", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization", + "value": [ + "<?xml version=\"1.0\" encoding=\"UTF-16\"?><Gemini xmlns=\"TableWidgetSerialization\"><AnnotationContent><![CDATA[<?xml version=\"1.0\"?>", + "<TableWidgetGridSerialization xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">", + " <ColumnSuggestedType />", + " <ColumnFormat />", + " <ColumnAccuracy />", + " <ColumnCurrencySymbol />", + " <ColumnPositivePattern />", + " <ColumnNegativePattern />", + " <ColumnWidths>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>105</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>123</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>84</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>92</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>111</int>", + " </value>", + " </item>", + " </ColumnWidths>", + " <ColumnDisplayIndex>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>0</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>1</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>2</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>3</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>4</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>5</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>6</int>", + " </value>", + " </item>", + " </ColumnDisplayIndex>", + " <ColumnFrozen />", + " <ColumnChecked />", + " <ColumnFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <FilterExpression xsi:type=\"LogicalExpression\">", + " <Operator>AND</Operator>", + " <ExpressionList>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>GreaterThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20090101</Value>", + " </FilterExpression>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>LesserThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20091231</Value>", + " </FilterExpression>", + " </ExpressionList>", + " </FilterExpression>", + " </value>", + " </item>", + " </ColumnFilter>", + " <SelectionFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <SelectionFilter xsi:nil=\"true\" />", + " </value>", + " </item>", + " </SelectionFilter>", + " <FilterParameters>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <CommandParameters />", + " </value>", + " </item>", + " </FilterParameters>", + " <IsSortDescending>false</IsSortDescending>", + "</TableWidgetGridSerialization>]]></AnnotationContent></Gemini>" + ] + }, + { + "name": "TableWidgetSourceTable" + }, + { + "name": "QueryEditorSerialization" + } + ] + }, + { + "name": "Product Inventory 2010", + "mode": "import", + "source": { + "query": "SELECT [dbo].[FactProductInventory].* \t\tFROM [dbo].[FactProductInventory] WHERE (([DateKey] >= 20100101) AND ([DateKey] <= 20101231))", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "TableWidgetSerialization", + "value": [ + "<?xml version=\"1.0\" encoding=\"UTF-16\"?><Gemini xmlns=\"TableWidgetSerialization\"><AnnotationContent><![CDATA[<?xml version=\"1.0\"?>", + "<TableWidgetGridSerialization xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\">", + " <ColumnSuggestedType />", + " <ColumnFormat />", + " <ColumnAccuracy />", + " <ColumnCurrencySymbol />", + " <ColumnPositivePattern />", + " <ColumnNegativePattern />", + " <ColumnWidths>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>105</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>123</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>91</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>84</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>92</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>111</int>", + " </value>", + " </item>", + " </ColumnWidths>", + " <ColumnDisplayIndex>", + " <item>", + " <key>", + " <string>ProductKey</string>", + " </key>", + " <value>", + " <int>0</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <int>1</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>MovementDate</string>", + " </key>", + " <value>", + " <int>2</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitCost</string>", + " </key>", + " <value>", + " <int>3</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsIn</string>", + " </key>", + " <value>", + " <int>4</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsOut</string>", + " </key>", + " <value>", + " <int>5</int>", + " </value>", + " </item>", + " <item>", + " <key>", + " <string>UnitsBalance</string>", + " </key>", + " <value>", + " <int>6</int>", + " </value>", + " </item>", + " </ColumnDisplayIndex>", + " <ColumnFrozen />", + " <ColumnChecked />", + " <ColumnFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <FilterExpression xsi:type=\"LogicalExpression\">", + " <Operator>AND</Operator>", + " <ExpressionList>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>GreaterThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20100101</Value>", + " </FilterExpression>", + " <FilterExpression xsi:type=\"ConditionalExpression\">", + " <Operator>LesserThanEqualTo</Operator>", + " <Value xsi:type=\"xsd:double\">20101231</Value>", + " </FilterExpression>", + " </ExpressionList>", + " </FilterExpression>", + " </value>", + " </item>", + " </ColumnFilter>", + " <SelectionFilter>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <SelectionFilter xsi:nil=\"true\" />", + " </value>", + " </item>", + " </SelectionFilter>", + " <FilterParameters>", + " <item>", + " <key>", + " <string>DateKey</string>", + " </key>", + " <value>", + " <CommandParameters />", + " </value>", + " </item>", + " </FilterParameters>", + " <IsSortDescending>false</IsSortDescending>", + "</TableWidgetGridSerialization>]]></AnnotationContent></Gemini>" + ] + }, + { + "name": "TableWidgetSourceTable" + }, + { + "name": "QueryEditorSerialization" + } + ] + } + ], + "measures": [ + { + "name": "Total Units In", + "expression": "SUM([Units In])", + "formatString": "#,0" + }, + { + "name": "Total Units Out", + "expression": "SUM([Units Out])", + "formatString": "#,0" + }, + { + "name": "Total Units Movement", + "expression": "[Total Units In]-[Total Units Out]", + "formatString": "#,0" + }, + { + "name": "Total Units", + "expression": "CALCULATE(SUM([Units Balance]),LASTDATE('Product Inventory'[Movement Date]))", + "formatString": "#,0" + }, + { + "name": "Total Inventory Value", + "expression": "CALCULATE(SUM([Product-Date Inventory Value]),LASTDATE('Product Inventory'[Movement Date]))", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Inventory Optimal Value", + "expression": "CALCULATE(SUM([Product-Date Optimal Inventory Value]),LASTDATE('Product Inventory'[Movement Date]))", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Inventory Maximum Value", + "expression": "CALCULATE(SUM([Product-Date Max Inventory Value]),LASTDATE('Product Inventory'[Movement Date]))", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Inventory Value Performance", + "expression": "IF([Total Inventory Value]<[Total Inventory Optimal Value],-(1-([Total Inventory Value]/[Total Inventory Optimal Value])),([Total Inventory Value]-[Total Inventory Optimal Value])/([Total Inventory Maximum Value]-[Total Inventory Optimal Value]))", + "kpi": { + "targetExpression": "0", + "statusGraphic": "Three Symbols UnCircled Colored", + "statusExpression": [ + "if(ISBLANK('Product Inventory'[Total Inventory Value Performance]),BLANK(),", + " If('Product Inventory'[Total Inventory Value Performance]<0,", + "\t If('Product Inventory'[Total Inventory Value Performance]<-0.2,-1,0),", + "\t If('Product Inventory'[Total Inventory Value Performance]<0.6,1,", + "\t\t If('Product Inventory'[Total Inventory Value Performance]<1,0,-1)", + "\t )", + " )", + " )", + " " + ], + "annotations": [ + { + "name": "GoalType", + "value": "StaticValue" + }, + { + "name": "KpiStatusType", + "value": "Centered" + }, + { + "name": "KpiThresholdType", + "value": "Absolute" + }, + { + "name": "KpiThresholdOrdering", + "value": "Ascending" + }, + { + "name": "KpiThresholdCount", + "value": "4" + }, + { + "name": "KpiThreshold_0", + "value": "-0.2" + }, + { + "name": "KpiThreshold_1", + "value": "0" + }, + { + "name": "KpiThreshold_2", + "value": "0.6" + }, + { + "name": "KpiThreshold_3", + "value": "1" + } + ] + } + }, + { + "name": "Products OverStocked", + "expression": "CALCULATE(SUM([Product-Date OverStocked]),LASTDATE('Product Inventory'[Movement Date]))", + "kpi": { + "targetExpression": "0", + "statusGraphic": "Three Symbols UnCircled Colored", + "statusExpression": [ + "if(ISBLANK('Product Inventory'[Products OverStocked]),BLANK(),", + " If('Product Inventory'[Products OverStocked]<1,1,", + "\t If('Product Inventory'[Products OverStocked]<5,0,-1)", + " )", + " )", + " " + ], + "annotations": [ + { + "name": "GoalType", + "value": "StaticValue" + }, + { + "name": "KpiStatusType", + "value": "LinearReversed" + }, + { + "name": "KpiThresholdType", + "value": "Absolute" + }, + { + "name": "KpiThresholdOrdering", + "value": "Ascending" + }, + { + "name": "KpiThresholdCount", + "value": "2" + }, + { + "name": "KpiThreshold_0", + "value": "1" + }, + { + "name": "KpiThreshold_1", + "value": "5" + } + ] + } + }, + { + "name": "Products UnderStocked", + "expression": "CALCULATE(SUM([Product-Date UnderStocked]),LASTDATE('Product Inventory'[Movement Date]))", + "kpi": { + "targetExpression": "0", + "statusGraphic": "Three Symbols UnCircled Colored", + "statusExpression": [ + "if(ISBLANK('Product Inventory'[Products UnderStocked]),BLANK(),", + " If('Product Inventory'[Products UnderStocked]<5,1,", + "\t If('Product Inventory'[Products UnderStocked]<15,0,-1)", + " )", + " )", + " " + ], + "annotations": [ + { + "name": "GoalType", + "value": "StaticValue" + }, + { + "name": "KpiStatusType", + "value": "LinearReversed" + }, + { + "name": "KpiThresholdType", + "value": "Absolute" + }, + { + "name": "KpiThresholdOrdering", + "value": "Ascending" + }, + { + "name": "KpiThresholdCount", + "value": "2" + }, + { + "name": "KpiThreshold_0", + "value": "5" + }, + { + "name": "KpiThreshold_1", + "value": "15" + } + ] + } + }, + { + "name": "Products with Negative Stock", + "expression": "CALCULATE(SUM([Product-Date Negative Stock]),LASTDATE('Product Inventory'[Movement Date]))", + "kpi": { + "targetExpression": "0", + "statusGraphic": "Three Symbols UnCircled Colored", + "statusExpression": [ + "if(ISBLANK('Product Inventory'[Products with Negative Stock]),BLANK(),", + " If('Product Inventory'[Products with Negative Stock]<0.1,1,", + "\t If('Product Inventory'[Products with Negative Stock]<5,0,-1)", + " )", + " )", + " " + ], + "annotations": [ + { + "name": "GoalType", + "value": "StaticValue" + }, + { + "name": "KpiStatusType", + "value": "LinearReversed" + }, + { + "name": "KpiThresholdType", + "value": "Absolute" + }, + { + "name": "KpiThresholdOrdering", + "value": "Ascending" + }, + { + "name": "KpiThresholdCount", + "value": "2" + }, + { + "name": "KpiThreshold_0", + "value": "0.1" + }, + { + "name": "KpiThreshold_1", + "value": "5" + } + ] + } + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "FactProductInventory" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[FactProductInventory].* FROM [dbo].[FactProductInventory] " + } + ] + }, + { + "name": "Sales Quota", + "columns": [ + { + "name": "SalesQuotaKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "SalesQuotaKey", + "summarizeBy": "none" + }, + { + "name": "EmployeeKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "EmployeeKey", + "summarizeBy": "none" + }, + { + "name": "DateKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "DateKey", + "summarizeBy": "none" + }, + { + "name": "Calendar Year", + "dataType": "int64", + "sourceColumn": "CalendarYear", + "summarizeBy": "none" + }, + { + "name": "Calendar Quarter", + "dataType": "int64", + "sourceColumn": "CalendarQuarter", + "summarizeBy": "none" + }, + { + "name": "Sales Amount Quota", + "dataType": "decimal", + "sourceColumn": "SalesAmountQuota", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Date", + "dataType": "dateTime", + "sourceColumn": "Date", + "formatString": "Short Date", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + } + ], + "partitions": [ + { + "name": "Sales Quota", + "source": { + "query": "SELECT [dbo].[FactSalesQuota].* \t\tFROM [dbo].[FactSalesQuota]", + "dataSource": "AdventureWorksDW" + }, + "annotations": [ + { + "name": "QueryEditorSerialization" + }, + { + "name": "TableWidgetSerialization" + } + ] + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "FactSalesQuota" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[FactSalesQuota].* FROM [dbo].[FactSalesQuota] " + } + ] + }, + { + "name": "Internet Sales", + "columns": [ + { + "name": "Sales Order Number", + "dataType": "string", + "sourceColumn": "SalesOrderNumber" + }, + { + "name": "Sales Order Line Number", + "dataType": "int64", + "sourceColumn": "SalesOrderLineNumber", + "summarizeBy": "none" + }, + { + "name": "Revision Number", + "dataType": "int64", + "sourceColumn": "RevisionNumber", + "summarizeBy": "none" + }, + { + "name": "Order Quantity", + "dataType": "int64", + "sourceColumn": "OrderQuantity", + "summarizeBy": "none" + }, + { + "name": "Unit Price", + "dataType": "decimal", + "sourceColumn": "UnitPrice", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Extended Amount", + "dataType": "decimal", + "sourceColumn": "ExtendedAmount", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Unit Price Discount Pct", + "dataType": "double", + "sourceColumn": "UnitPriceDiscountPct", + "summarizeBy": "none" + }, + { + "name": "Discount Amount", + "dataType": "decimal", + "sourceColumn": "DiscountAmount", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Product Standard Cost", + "dataType": "decimal", + "sourceColumn": "ProductStandardCost", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Product Cost", + "dataType": "decimal", + "sourceColumn": "TotalProductCost", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Sales Amount", + "dataType": "decimal", + "sourceColumn": "SalesAmount", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Freight", + "dataType": "decimal", + "sourceColumn": "Freight", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Carrier Tracking Number", + "dataType": "string", + "sourceColumn": "CarrierTrackingNumber" + }, + { + "name": "Customer PO Number", + "dataType": "string", + "sourceColumn": "CustomerPONumber" + }, + { + "name": "Order Date", + "dataType": "dateTime", + "sourceColumn": "OrderDate" + }, + { + "name": "Due Date", + "dataType": "dateTime", + "sourceColumn": "DueDate" + }, + { + "name": "Ship Date", + "dataType": "dateTime", + "sourceColumn": "ShipDate" + }, + { + "name": "ProductKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ProductKey", + "summarizeBy": "none" + }, + { + "name": "OrderDateKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "OrderDateKey", + "summarizeBy": "none" + }, + { + "name": "DueDateKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "DueDateKey", + "summarizeBy": "none" + }, + { + "name": "ShipDateKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ShipDateKey", + "summarizeBy": "none" + }, + { + "name": "CustomerKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "CustomerKey", + "summarizeBy": "none" + }, + { + "name": "PromotionKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "PromotionKey", + "summarizeBy": "none" + }, + { + "name": "CurrencyKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "CurrencyKey", + "summarizeBy": "none" + }, + { + "name": "SalesTerritoryKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "SalesTerritoryKey", + "summarizeBy": "none" + }, + { + "name": "Tax Amount", + "dataType": "decimal", + "sourceColumn": "TaxAmt", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "type": "calculated", + "name": "Gross Profit", + "dataType": "decimal", + "isDataTypeInferred": true, + "expression": "[Sales Amount]-[Total Product Cost]", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + } + ], + "partitions": [ + { + "name": "Internet Sales", + "source": { + "query": "SELECT * FROM [dbo].[FactInternetSales]", + "dataSource": "AdventureWorksDW" + } + } + ], + "measures": [ + { + "name": "Internet Distinct Count Sales Order", + "expression": "DISTINCTCOUNT([Sales Order Number])", + "formatString": "#,0" + }, + { + "name": "Internet Total Sales", + "expression": "SUM([Sales Amount])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Total Discount Amount", + "expression": "SUM([Discount Amount])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Total Product Cost", + "expression": "SUM([Total Product Cost])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Total Freight", + "expression": "SUM([Freight])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Total Units", + "expression": "SUM([Order Quantity])", + "formatString": "#,0" + }, + { + "name": "Internet Order Lines Count", + "expression": "COUNT([Sales Order Line Number])", + "formatString": "#,0" + }, + { + "name": "Internet Previous Quarter Sales", + "expression": "CALCULATE([Internet Total Sales],PREVIOUSQUARTER('Date'[Date]))", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Current Quarter Sales", + "expression": "TOTALQTD([Internet Total Sales],'Date'[Date])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Previous Quarter Sales Proportion to QTD", + "expression": "[Internet Previous Quarter Sales]*([Days In Current Quarter]/[Days In Current Quarter])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Current Quarter Sales Performance", + "expression": "IFERROR([Internet Current Quarter Sales]/[Internet Previous Quarter Sales Proportion to QTD],BLANK())", + "kpi": { + "targetExpression": "1.1", + "statusGraphic": "Three Symbols UnCircled Colored", + "statusExpression": [ + "if(ISBLANK('Internet Sales'[Internet Current Quarter Sales Performance]),BLANK(),\r", + " If('Internet Sales'[Internet Current Quarter Sales Performance]<1,-1,\r", + "\t If('Internet Sales'[Internet Current Quarter Sales Performance]<1.07,0,1)\r", + " )\r", + " )\r", + " " + ], + "annotations": [ + { + "name": "GoalType", + "value": "StaticValue" + }, + { + "name": "KpiStatusType", + "value": "Linear" + }, + { + "name": "KpiThresholdType", + "value": "Absolute" + }, + { + "name": "KpiThresholdOrdering", + "value": "Ascending" + }, + { + "name": "KpiThresholdCount", + "value": "2" + }, + { + "name": "KpiThreshold_0", + "value": "1" + }, + { + "name": "KpiThreshold_1", + "value": "1.07" + } + ] + } + }, + { + "name": "Internet Total Tax Amount", + "expression": "SUM([Tax Amount])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Total Gross Profit", + "expression": "SUM([Gross Profit])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Previous Quarter Gross Profit", + "expression": "CALCULATE([Internet Total Gross Profit],PREVIOUSQUARTER('Date'[Date]))", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Current Quarter Gross Profit", + "expression": "TOTALQTD([Internet Total Gross Profit],'Date'[Date])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Previous Quarter Gross Profit Proportion to QTD", + "expression": "[Internet Previous Quarter Gross Profit]*([Days In Current Quarter to Date]/[Days In Current Quarter])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Internet Current Quarter Gross Profit Performance", + "expression": "IF([Internet Previous Quarter Gross Profit Proportion to QTD]<>0,([Internet Current Quarter Gross Profit]-[Internet Previous Quarter Gross Profit Proportion to QTD])/[Internet Previous Quarter Gross Profit Proportion to QTD],BLANK())", + "kpi": { + "targetExpression": "1.25", + "statusGraphic": "Three Symbols UnCircled Colored", + "statusExpression": [ + "if(ISBLANK('Internet Sales'[Internet Current Quarter Gross Profit Performance]),BLANK(),\r", + " If('Internet Sales'[Internet Current Quarter Gross Profit Performance]<0.8,-1,\r", + "\t If('Internet Sales'[Internet Current Quarter Gross Profit Performance]<1.03,0,1)\r", + " )\r", + " )\r", + " " + ], + "annotations": [ + { + "name": "GoalType", + "value": "StaticValue" + }, + { + "name": "KpiStatusType", + "value": "Linear" + }, + { + "name": "KpiThresholdType", + "value": "Absolute" + }, + { + "name": "KpiThresholdOrdering", + "value": "Ascending" + }, + { + "name": "KpiThresholdCount", + "value": "2" + }, + { + "name": "KpiThreshold_0", + "value": "0.8" + }, + { + "name": "KpiThreshold_1", + "value": "1.03" + } + ] + } + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "FactInternetSales" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[FactInternetSales].* FROM [dbo].[FactInternetSales] " + } + ] + }, + { + "name": "Reseller Sales", + "columns": [ + { + "name": "ProductKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ProductKey" + }, + { + "name": "OrderDateKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "OrderDateKey" + }, + { + "name": "DueDateKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "DueDateKey" + }, + { + "name": "ShipDateKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ShipDateKey" + }, + { + "name": "ResellerKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "ResellerKey" + }, + { + "name": "EmployeeKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "EmployeeKey" + }, + { + "name": "PromotionKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "PromotionKey" + }, + { + "name": "CurrencyKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "CurrencyKey" + }, + { + "name": "SalesTerritoryKey", + "dataType": "int64", + "isHidden": true, + "sourceColumn": "SalesTerritoryKey" + }, + { + "name": "Sales Order Number", + "dataType": "string", + "sourceColumn": "SalesOrderNumber" + }, + { + "name": "Sales Order Line Number", + "dataType": "int64", + "sourceColumn": "SalesOrderLineNumber", + "summarizeBy": "none" + }, + { + "name": "Revision Number", + "dataType": "int64", + "sourceColumn": "RevisionNumber", + "summarizeBy": "none" + }, + { + "name": "Order Quantity", + "dataType": "int64", + "sourceColumn": "OrderQuantity", + "summarizeBy": "none" + }, + { + "name": "Unit Price", + "dataType": "decimal", + "sourceColumn": "UnitPrice", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Extended Amount", + "dataType": "decimal", + "sourceColumn": "ExtendedAmount", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Unit Price Discount Pct", + "dataType": "double", + "sourceColumn": "UnitPriceDiscountPct", + "summarizeBy": "none" + }, + { + "name": "Discount Amount", + "dataType": "decimal", + "sourceColumn": "DiscountAmount", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Product Standard Cost", + "dataType": "decimal", + "sourceColumn": "ProductStandardCost", + "summarizeBy": "none", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Total Product Cost", + "dataType": "decimal", + "sourceColumn": "TotalProductCost", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Sales Amount", + "dataType": "decimal", + "sourceColumn": "SalesAmount", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Tax Amount", + "dataType": "decimal", + "sourceColumn": "TaxAmt", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Freight", + "dataType": "decimal", + "sourceColumn": "Freight", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Carrier Tracking Number", + "dataType": "string", + "sourceColumn": "CarrierTrackingNumber" + }, + { + "name": "Reseller PO Number", + "dataType": "string", + "sourceColumn": "CustomerPONumber" + }, + { + "name": "Order Date", + "dataType": "dateTime", + "sourceColumn": "OrderDate", + "formatString": "Short Date", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Due Date", + "dataType": "dateTime", + "sourceColumn": "DueDate", + "formatString": "Short Date", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Ship Date", + "dataType": "dateTime", + "sourceColumn": "ShipDate", + "formatString": "Short Date", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "type": "calculated", + "name": "Gross Profit", + "dataType": "decimal", + "isDataTypeInferred": true, + "expression": "[Sales Amount]-[Total Product Cost]", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + } + ], + "partitions": [ + { + "name": "Reseller Sales", + "source": { + "query": "SELECT * FROM [dbo].[FactResellerSales]", + "dataSource": "AdventureWorksDW" + } + } + ], + "measures": [ + { + "name": "Reseller Distinct Count Sales Order", + "expression": "DISTINCTCOUNT([Sales Order Number])", + "formatString": "#,0" + }, + { + "name": "Reseller Total Sales", + "expression": "SUM([Sales Amount])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Total Discount Amount", + "expression": "SUM([Discount Amount])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Total Product Cost", + "expression": "SUM([Total Product Cost])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Total Tax Amount", + "expression": "SUM([Tax Amount])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Total Freight", + "expression": "SUM([Freight])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Total Gross Profit", + "expression": "SUM([Gross Profit])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Total Units", + "expression": "SUM([Order Quantity])", + "formatString": "#,0" + }, + { + "name": "Reseller Order Lines Count", + "expression": "COUNT([Sales Order Line Number])", + "formatString": "#,0" + }, + { + "name": "Reseller Previous Quarter Gross Profit", + "expression": "CALCULATE([Reseller Total Gross Profit],PREVIOUSQUARTER('Date'[Date]))", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Current Quarter Gross Profit", + "expression": "TOTALQTD([Reseller Total Gross Profit],'Date'[Date])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Previous Quarter Gross Profit Proportion to QTD", + "expression": "[Reseller Previous Quarter Gross Profit]*([Days In Current Quarter to Date]/[Days In Current Quarter])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Previous Quarter Sales", + "expression": "CALCULATE([Reseller Total Sales],PREVIOUSQUARTER('Date'[Date]))", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Current Quarter Sales", + "expression": "TOTALQTD([Reseller Total Sales],'Date'[Date])", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Previous Quarter Sales Proportion to QTD", + "expression": "[Reseller Previous Quarter Sales]*([Days In Current Quarter to Date]/[Days In Current Quarter])" + }, + { + "name": "Reseller Total Sales - Sales Territory sliced by Employee", + "expression": "CALCULATE(SUM('Reseller Sales'[Sales Amount]),USERELATIONSHIP(Employee[EmployeeKey],'Reseller Sales'[EmployeeKey]),USERELATIONSHIP('Sales Territory'[SalesTerritoryKey],Employee[SalesTerritoryKey]))", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Total Sales - Sales Territory sliced by Reseller", + "expression": "CALCULATE(SUM('Reseller Sales'[Sales Amount]), USERELATIONSHIP(Reseller[ResellerKey], 'Reseller Sales'[ResellerKey]), USERELATIONSHIP(Geography[GeographyKey], Reseller[GeographyKey]), USERELATIONSHIP('Sales Territory'[SalesTerritoryKey], Geography[SalesTerritoryKey]))", + "formatString": "\\$#,0.00;(\\$#,0.00);\\$#,0.00", + "annotations": [ + { + "name": "Format", + "value": "" + } + ] + }, + { + "name": "Reseller Current Quarter Sales Performance", + "expression": "IFERROR([Reseller Current Quarter Sales]/[Reseller Previous Quarter Sales Proportion to QTD],BLANK())", + "kpi": { + "targetExpression": "1.1", + "statusGraphic": "Three Symbols UnCircled Colored", + "statusExpression": [ + "if(ISBLANK('Reseller Sales'[Reseller Current Quarter Sales Performance]),BLANK(),\r", + " If('Reseller Sales'[Reseller Current Quarter Sales Performance]<0.8,-1,\r", + "\t If('Reseller Sales'[Reseller Current Quarter Sales Performance]<1.07,0,1)\r", + " )\r", + " )\r", + " " + ], + "annotations": [ + { + "name": "GoalType", + "value": "StaticValue" + }, + { + "name": "KpiStatusType", + "value": "Linear" + }, + { + "name": "KpiThresholdType", + "value": "Absolute" + }, + { + "name": "KpiThresholdOrdering", + "value": "Ascending" + }, + { + "name": "KpiThresholdCount", + "value": "2" + }, + { + "name": "KpiThreshold_0", + "value": "0.8" + }, + { + "name": "KpiThreshold_1", + "value": "1.07" + } + ] + } + }, + { + "name": "Reseller Current Quarter Gross Profit Performance", + "expression": "IF([Reseller Previous Quarter Gross Profit Proportion to QTD]<>0,([Reseller Current Quarter Gross Profit]-[Reseller Previous Quarter Gross Profit Proportion to QTD])/[Reseller Previous Quarter Gross Profit Proportion to QTD],BLANK())", + "kpi": { + "targetExpression": "1.25", + "statusGraphic": "Three Symbols UnCircled Colored", + "statusExpression": [ + "if(ISBLANK('Reseller Sales'[Reseller Current Quarter Gross Profit Performance]),BLANK(),\r", + " If('Reseller Sales'[Reseller Current Quarter Gross Profit Performance]<0.8,-1,\r", + "\t If('Reseller Sales'[Reseller Current Quarter Gross Profit Performance]<1.03,0,1)\r", + " )\r", + " )\r", + " " + ], + "annotations": [ + { + "name": "GoalType", + "value": "StaticValue" + }, + { + "name": "KpiStatusType", + "value": "Linear" + }, + { + "name": "KpiThresholdType", + "value": "Absolute" + }, + { + "name": "KpiThresholdOrdering", + "value": "Ascending" + }, + { + "name": "KpiThresholdCount", + "value": "2" + }, + { + "name": "KpiThreshold_0", + "value": "0.8" + }, + { + "name": "KpiThreshold_1", + "value": "1.03" + } + ] + } + } + ], + "annotations": [ + { + "name": "_TM_ExtProp_DbSchemaName", + "value": "dbo" + }, + { + "name": "_TM_ExtProp_DbTableName", + "value": "FactResellerSales" + }, + { + "name": "_TM_ExtProp_QueryDefinition", + "value": " SELECT [dbo].[FactResellerSales].* FROM [dbo].[FactResellerSales] " + } + ] + } + ], + "relationships": [ + { + "name": "2c5177ff-b673-48e0-9168-821672c57e5e", + "fromTable": "Customer", + "fromColumn": "GeographyKey", + "toTable": "Geography", + "toColumn": "GeographyKey" + }, + { + "name": "e278ab89-4b93-42e3-b40c-636fdd8d681c", + "fromTable": "Employee", + "fromColumn": "SalesTerritoryKey", + "toTable": "Sales Territory", + "toColumn": "SalesTerritoryKey", + "isActive": false + }, + { + "name": "27dae602-f0b8-43f8-940b-43fb315458bb", + "fromTable": "Geography", + "fromColumn": "SalesTerritoryKey", + "toTable": "Sales Territory", + "toColumn": "SalesTerritoryKey", + "isActive": false + }, + { + "name": "9b8024a2-e51d-4a2b-9a8f-6a2199d1d2ea", + "fromTable": "Product", + "fromColumn": "ProductSubcategoryKey", + "toTable": "Product Subcategory", + "toColumn": "ProductSubcategoryKey" + }, + { + "name": "46425cb9-382b-4dfb-9b79-63bc5082c42b", + "fromTable": "Product Subcategory", + "fromColumn": "ProductCategoryKey", + "toTable": "Product Category", + "toColumn": "ProductCategoryKey" + }, + { + "name": "b32d6ef8-a309-4c10-8d36-0f0e2ae84901", + "fromTable": "Reseller", + "fromColumn": "GeographyKey", + "toTable": "Geography", + "toColumn": "GeographyKey" + }, + { + "name": "602b2378-4717-4122-b97e-95f36c15dc85", + "fromTable": "Product Inventory", + "fromColumn": "DateKey", + "toTable": "Date", + "toColumn": "DateKey" + }, + { + "name": "7dbfc7d9-a935-432d-b5c6-a53d129fbd16", + "fromTable": "Product Inventory", + "fromColumn": "ProductKey", + "toTable": "Product", + "toColumn": "ProductKey" + }, + { + "name": "39981e17-197f-4647-a8d8-850cbe2aea09", + "fromTable": "Sales Quota", + "fromColumn": "DateKey", + "toTable": "Date", + "toColumn": "DateKey" + }, + { + "name": "d96cf292-44da-4a47-837c-173bf1f49c18", + "fromTable": "Sales Quota", + "fromColumn": "EmployeeKey", + "toTable": "Employee", + "toColumn": "EmployeeKey" + }, + { + "name": "877c4e4a-6f61-43c8-ae8b-b748a6400407", + "fromTable": "Internet Sales", + "fromColumn": "CurrencyKey", + "toTable": "Currency", + "toColumn": "CurrencyKey" + }, + { + "name": "90d94b82-0243-4632-b9f7-99de63279961", + "fromTable": "Internet Sales", + "fromColumn": "CustomerKey", + "toTable": "Customer", + "toColumn": "CustomerKey" + }, + { + "name": "3db0e485-88a9-44d9-9a12-657c8ef0f881", + "fromTable": "Internet Sales", + "fromColumn": "OrderDateKey", + "toTable": "Date", + "toColumn": "DateKey" + }, + { + "name": "f5617b1d-9840-4978-8860-f337cb5f852d", + "fromTable": "Internet Sales", + "fromColumn": "DueDateKey", + "toTable": "Date", + "toColumn": "DateKey", + "isActive": false + }, + { + "name": "8cd93710-86b7-47a6-b512-230bc4c3e73d", + "fromTable": "Internet Sales", + "fromColumn": "ShipDateKey", + "toTable": "Date", + "toColumn": "DateKey", + "isActive": false + }, + { + "name": "a5016faf-9af5-4750-92ff-505d05aefe68", + "fromTable": "Internet Sales", + "fromColumn": "ProductKey", + "toTable": "Product", + "toColumn": "ProductKey" + }, + { + "name": "b3d9edf1-1e10-436b-b870-80029b0ee4f3", + "fromTable": "Internet Sales", + "fromColumn": "PromotionKey", + "toTable": "Promotion", + "toColumn": "PromotionKey" + }, + { + "name": "d9761f6e-1fec-476d-9eee-9e1511044619", + "fromTable": "Internet Sales", + "fromColumn": "SalesTerritoryKey", + "toTable": "Sales Territory", + "toColumn": "SalesTerritoryKey" + }, + { + "name": "1b277ca4-d6fc-4366-b164-2fd3c56cfd24", + "fromTable": "Reseller Sales", + "fromColumn": "CurrencyKey", + "toTable": "Currency", + "toColumn": "CurrencyKey" + }, + { + "name": "100ca454-655f-4e46-a040-cfa2ca981f88", + "fromTable": "Reseller Sales", + "fromColumn": "OrderDateKey", + "toTable": "Date", + "toColumn": "DateKey" + }, + { + "name": "1f6426cb-30d0-4d70-bbd5-5da59ce7292b", + "fromTable": "Reseller Sales", + "fromColumn": "DueDateKey", + "toTable": "Date", + "toColumn": "DateKey", + "isActive": false + }, + { + "name": "1c37fcb7-a454-4b11-8389-9a97d5d09f4c", + "fromTable": "Reseller Sales", + "fromColumn": "ShipDateKey", + "toTable": "Date", + "toColumn": "DateKey", + "isActive": false + }, + { + "name": "262def50-5047-491a-8fc6-e96a9d66a80b", + "fromTable": "Reseller Sales", + "fromColumn": "EmployeeKey", + "toTable": "Employee", + "toColumn": "EmployeeKey" + }, + { + "name": "adbcdd01-4156-4b47-9c94-5f6283c9c20a", + "fromTable": "Reseller Sales", + "fromColumn": "ProductKey", + "toTable": "Product", + "toColumn": "ProductKey" + }, + { + "name": "03b67804-b82a-433a-9589-f768a6eb3945", + "fromTable": "Reseller Sales", + "fromColumn": "PromotionKey", + "toTable": "Promotion", + "toColumn": "PromotionKey" + }, + { + "name": "431b1361-7b09-4540-91d3-fda884108451", + "fromTable": "Reseller Sales", + "fromColumn": "ResellerKey", + "toTable": "Reseller", + "toColumn": "ResellerKey" + }, + { + "name": "b62a7abc-f954-41a1-ac0a-bce7fdd5eaa7", + "fromTable": "Reseller Sales", + "fromColumn": "SalesTerritoryKey", + "toTable": "Sales Territory", + "toColumn": "SalesTerritoryKey" + } + ], + "perspectives": [ + { + "name": "Inventory", + "tables": [ + { + "name": "Product Inventory", + "columns": [ + { + "name": "Units In" + }, + { + "name": "Product-Date OverStocked" + }, + { + "name": "Units Balance" + }, + { + "name": "Product-Date Negative Stock" + }, + { + "name": "Unit Cost" + }, + { + "name": "DateKey" + }, + { + "name": "Product-Date Inventory Value" + }, + { + "name": "Movement Date" + }, + { + "name": "Product-Date UnderStocked" + }, + { + "name": "Units Out" + }, + { + "name": "ProductKey" + }, + { + "name": "Product-Date Optimal Inventory Value" + }, + { + "name": "Product-Date Max Inventory Value" + } + ], + "measures": [ + { + "name": "Total Inventory Value Performance" + }, + { + "name": "Total Units Out" + }, + { + "name": "Total Units" + }, + { + "name": "Total Units Movement" + }, + { + "name": "Products with Negative Stock" + }, + { + "name": "Products UnderStocked" + }, + { + "name": "Total Inventory Value" + }, + { + "name": "Total Units In" + }, + { + "name": "Total Inventory Maximum Value" + }, + { + "name": "Total Inventory Optimal Value" + }, + { + "name": "Products OverStocked" + } + ] + }, + { + "name": "Date", + "columns": [ + { + "name": "Month Name" + }, + { + "name": "Calendar Quarter" + }, + { + "name": "Month" + }, + { + "name": "Week Of Year" + }, + { + "name": "Calendar Year" + }, + { + "name": "Fiscal Quarter" + }, + { + "name": "Day Of Month" + }, + { + "name": "Fiscal Year" + }, + { + "name": "Day Name Of Week" + }, + { + "name": "Day Of Year" + }, + { + "name": "DateKey" + }, + { + "name": "Date" + }, + { + "name": "Fiscal Semester" + }, + { + "name": "Day Number Of Week" + }, + { + "name": "Calendar Semester" + } + ], + "measures": [ + { + "name": "Days In Current Quarter to Date" + }, + { + "name": "Days In Current Quarter" + } + ] + }, + { + "name": "Product", + "columns": [ + { + "name": "Product SubCategory Name" + }, + { + "name": "Style" + }, + { + "name": "Model Name" + }, + { + "name": "Product Name" + }, + { + "name": "Product Start Date" + }, + { + "name": "Weight Unit Code" + }, + { + "name": "Safety Stock Level" + }, + { + "name": "Product Id" + }, + { + "name": "Standard Cost" + }, + { + "name": "Color" + }, + { + "name": "Days To Manufacture" + }, + { + "name": "Dealer Price" + }, + { + "name": "ProductKey" + }, + { + "name": "LargePhoto" + }, + { + "name": "Size" + }, + { + "name": "Is Finished Goods" + }, + { + "name": "Description" + }, + { + "name": "Product Line" + }, + { + "name": "Size Unit Code" + }, + { + "name": "List Price" + }, + { + "name": "Class" + }, + { + "name": "Size Range" + }, + { + "name": "Reorder Point" + }, + { + "name": "Product Status" + }, + { + "name": "Weight" + }, + { + "name": "ProductSubcategoryKey" + }, + { + "name": "Product Category Name" + }, + { + "name": "Product End Date" + } + ] + }, + { + "name": "Product Subcategory", + "columns": [ + { + "name": "Product Subcategory Name" + }, + { + "name": "ProductSubcategoryKey" + }, + { + "name": "ProductCategoryKey" + } + ] + }, + { + "name": "Product Category", + "columns": [ + { + "name": "Product Category Name" + }, + { + "name": "ProductCategoryKey" + } + ] + } + ] + }, + { + "name": "Internet Operation", + "tables": [ + { + "name": "Date", + "columns": [ + { + "name": "Month Name" + }, + { + "name": "Calendar Quarter" + }, + { + "name": "Month" + }, + { + "name": "Week Of Year" + }, + { + "name": "Calendar Year" + }, + { + "name": "Fiscal Quarter" + }, + { + "name": "Day Of Month" + }, + { + "name": "Fiscal Year" + }, + { + "name": "Day Name Of Week" + }, + { + "name": "Day Of Year" + }, + { + "name": "DateKey" + }, + { + "name": "Date" + }, + { + "name": "Fiscal Semester" + }, + { + "name": "Day Number Of Week" + }, + { + "name": "Calendar Semester" + } + ], + "measures": [ + { + "name": "Days In Current Quarter to Date" + }, + { + "name": "Days In Current Quarter" + } + ] + }, + { + "name": "Internet Sales", + "columns": [ + { + "name": "Carrier Tracking Number" + }, + { + "name": "Order Date" + }, + { + "name": "Sales Order Line Number" + }, + { + "name": "CustomerKey" + }, + { + "name": "Gross Profit" + }, + { + "name": "Due Date" + }, + { + "name": "Sales Order Number" + }, + { + "name": "Discount Amount" + }, + { + "name": "Sales Amount" + }, + { + "name": "PromotionKey" + }, + { + "name": "Customer PO Number" + }, + { + "name": "ProductKey" + }, + { + "name": "Unit Price" + }, + { + "name": "Freight" + }, + { + "name": "Total Product Cost" + }, + { + "name": "CurrencyKey" + }, + { + "name": "ShipDateKey" + }, + { + "name": "Product Standard Cost" + }, + { + "name": "Extended Amount" + }, + { + "name": "Order Quantity" + }, + { + "name": "Revision Number" + }, + { + "name": "SalesTerritoryKey" + }, + { + "name": "Tax Amount" + }, + { + "name": "OrderDateKey" + }, + { + "name": "Unit Price Discount Pct" + }, + { + "name": "Ship Date" + }, + { + "name": "DueDateKey" + } + ], + "measures": [ + { + "name": "Internet Total Gross Profit" + }, + { + "name": "Internet Previous Quarter Sales Proportion to QTD" + }, + { + "name": "Internet Current Quarter Gross Profit Performance" + }, + { + "name": "Internet Current Quarter Sales" + }, + { + "name": "Internet Current Quarter Sales Performance" + }, + { + "name": "Internet Total Product Cost" + }, + { + "name": "Internet Distinct Count Sales Order" + }, + { + "name": "Internet Previous Quarter Gross Profit" + }, + { + "name": "Internet Total Sales" + }, + { + "name": "Internet Previous Quarter Gross Profit Proportion to QTD" + }, + { + "name": "Internet Order Lines Count" + }, + { + "name": "Internet Previous Quarter Sales" + }, + { + "name": "Internet Total Freight" + }, + { + "name": "Internet Total Units" + }, + { + "name": "Internet Total Tax Amount" + }, + { + "name": "Internet Current Quarter Gross Profit" + }, + { + "name": "Internet Total Discount Amount" + } + ] + }, + { + "name": "Sales Territory", + "columns": [ + { + "name": "Sales Territory Region" + }, + { + "name": "SalesTerritoryKey" + }, + { + "name": "Sales Territory Country" + }, + { + "name": "Sales Territory Group" + }, + { + "name": "Sales Territory Image" + } + ], + "measures": [ + { + "name": "Total Gross Profit" + }, + { + "name": "Distinct Count Sales Orders" + }, + { + "name": "Total Sales - Sales Territory sliced by Employee" + }, + { + "name": "Total Current Quarter Sales" + }, + { + "name": "Total Previous Quarter Sales" + }, + { + "name": "Total Tax Amount" + }, + { + "name": "Total Current Quarter Sales Performance" + }, + { + "name": "Total Freight" + }, + { + "name": "Total Sales" + }, + { + "name": "Total Previous Quarter Gross Profit Proportion to QTD" + }, + { + "name": "Order Lines Count" + }, + { + "name": "Total Discount Amount" + }, + { + "name": "Total Previous Quarter Sales Proportion to QTD" + }, + { + "name": "Total Products Cost" + }, + { + "name": "Total Units Sold" + }, + { + "name": "Total Current Quarter Gross Profit Performance" + }, + { + "name": "Total Current Quarter Gross Profit" + }, + { + "name": "Total Previous Quarter Gross Profit" + } + ] + }, + { + "name": "Product", + "columns": [ + { + "name": "Product SubCategory Name" + }, + { + "name": "Style" + }, + { + "name": "Model Name" + }, + { + "name": "Product Name" + }, + { + "name": "Product Start Date" + }, + { + "name": "Weight Unit Code" + }, + { + "name": "Safety Stock Level" + }, + { + "name": "Product Id" + }, + { + "name": "Standard Cost" + }, + { + "name": "Color" + }, + { + "name": "Days To Manufacture" + }, + { + "name": "Dealer Price" + }, + { + "name": "ProductKey" + }, + { + "name": "LargePhoto" + }, + { + "name": "Size" + }, + { + "name": "Is Finished Goods" + }, + { + "name": "Description" + }, + { + "name": "Product Line" + }, + { + "name": "Size Unit Code" + }, + { + "name": "List Price" + }, + { + "name": "Class" + }, + { + "name": "Size Range" + }, + { + "name": "Reorder Point" + }, + { + "name": "Product Status" + }, + { + "name": "Weight" + }, + { + "name": "ProductSubcategoryKey" + }, + { + "name": "Product Category Name" + }, + { + "name": "Product End Date" + } + ] + }, + { + "name": "Promotion", + "columns": [ + { + "name": "Promotion Name" + }, + { + "name": "Max Quantity" + }, + { + "name": "Promotion Type" + }, + { + "name": "Promotion Start Date" + }, + { + "name": "Min Quantity" + }, + { + "name": "Promotion Category" + }, + { + "name": "DiscountPct" + }, + { + "name": "PromotionKey" + }, + { + "name": "Promotion End Date" + } + ] + }, + { + "name": "Product Subcategory", + "columns": [ + { + "name": "Product Subcategory Name" + }, + { + "name": "ProductSubcategoryKey" + }, + { + "name": "ProductCategoryKey" + } + ] + }, + { + "name": "Geography", + "columns": [ + { + "name": "City" + }, + { + "name": "State Province Name" + }, + { + "name": "Country Region Code" + }, + { + "name": "State Province Code" + }, + { + "name": "SalesTerritoryKey" + }, + { + "name": "GeographyKey" + }, + { + "name": "Country Region Name" + }, + { + "name": "Postal Code" + } + ] + }, + { + "name": "Customer", + "columns": [ + { + "name": "CustomerKey" + }, + { + "name": "Number of Children At Home" + }, + { + "name": "Middle Name" + }, + { + "name": "Name Style" + }, + { + "name": "Date Of First Purchase" + }, + { + "name": "Address Line 2" + }, + { + "name": "GeographyKey" + }, + { + "name": "Yearly Income" + }, + { + "name": "Marital Status" + }, + { + "name": "Phone" + }, + { + "name": "Email Address" + }, + { + "name": "Gender" + }, + { + "name": "Occupation" + }, + { + "name": "Address Line 1" + }, + { + "name": "Total Cars Owned" + }, + { + "name": "Total Children" + }, + { + "name": "Suffix" + }, + { + "name": "First Name" + }, + { + "name": "Birth Date" + }, + { + "name": "Education" + }, + { + "name": "Last Name" + }, + { + "name": "Commute Distance" + }, + { + "name": "Customer Id" + }, + { + "name": "Title" + }, + { + "name": "Owns House" + } + ] + }, + { + "name": "Currency", + "columns": [ + { + "name": "CurrencyKey" + }, + { + "name": "Currency Code" + }, + { + "name": "CurrencyName" + } + ] + }, + { + "name": "Product Category", + "columns": [ + { + "name": "Product Category Name" + }, + { + "name": "ProductCategoryKey" + } + ] + } + ] + }, + { + "name": "Reseller Operation", + "tables": [ + { + "name": "Date", + "columns": [ + { + "name": "Month Name" + }, + { + "name": "Calendar Quarter" + }, + { + "name": "Month" + }, + { + "name": "Week Of Year" + }, + { + "name": "Calendar Year" + }, + { + "name": "Fiscal Quarter" + }, + { + "name": "Day Of Month" + }, + { + "name": "Fiscal Year" + }, + { + "name": "Day Name Of Week" + }, + { + "name": "Day Of Year" + }, + { + "name": "DateKey" + }, + { + "name": "Date" + }, + { + "name": "Fiscal Semester" + }, + { + "name": "Day Number Of Week" + }, + { + "name": "Calendar Semester" + } + ], + "measures": [ + { + "name": "Days In Current Quarter to Date" + }, + { + "name": "Days In Current Quarter" + } + ] + }, + { + "name": "Reseller Sales", + "columns": [ + { + "name": "Sales Order Line Number" + }, + { + "name": "Carrier Tracking Number" + }, + { + "name": "Order Date" + }, + { + "name": "Due Date" + }, + { + "name": "Gross Profit" + }, + { + "name": "Sales Order Number" + }, + { + "name": "Discount Amount" + }, + { + "name": "Sales Amount" + }, + { + "name": "PromotionKey" + }, + { + "name": "ProductKey" + }, + { + "name": "Reseller PO Number" + }, + { + "name": "Unit Price" + }, + { + "name": "Freight" + }, + { + "name": "ResellerKey" + }, + { + "name": "DueDateKey" + }, + { + "name": "EmployeeKey" + }, + { + "name": "Total Product Cost" + }, + { + "name": "CurrencyKey" + }, + { + "name": "ShipDateKey" + }, + { + "name": "Product Standard Cost" + }, + { + "name": "Extended Amount" + }, + { + "name": "Order Quantity" + }, + { + "name": "Revision Number" + }, + { + "name": "SalesTerritoryKey" + }, + { + "name": "Tax Amount" + }, + { + "name": "OrderDateKey" + }, + { + "name": "Unit Price Discount Pct" + }, + { + "name": "Ship Date" + } + ], + "measures": [ + { + "name": "Reseller Total Tax Amount" + }, + { + "name": "Reseller Distinct Count Sales Order" + }, + { + "name": "Reseller Previous Quarter Gross Profit Proportion to QTD" + }, + { + "name": "Reseller Total Discount Amount" + }, + { + "name": "Reseller Current Quarter Sales" + }, + { + "name": "Reseller Total Gross Profit" + }, + { + "name": "Reseller Order Lines Count" + }, + { + "name": "Reseller Previous Quarter Sales Proportion to QTD" + }, + { + "name": "Reseller Total Product Cost" + }, + { + "name": "Reseller Previous Quarter Sales" + }, + { + "name": "Reseller Total Sales" + }, + { + "name": "Reseller Current Quarter Gross Profit Performance" + }, + { + "name": "Reseller Current Quarter Sales Performance" + }, + { + "name": "Reseller Total Units" + }, + { + "name": "Reseller Total Freight" + }, + { + "name": "Reseller Total Sales - Sales Territory sliced by Reseller" + }, + { + "name": "Reseller Total Sales - Sales Territory sliced by Employee" + }, + { + "name": "Reseller Current Quarter Gross Profit" + }, + { + "name": "Reseller Previous Quarter Gross Profit" + } + ] + }, + { + "name": "Sales Territory", + "columns": [ + { + "name": "Sales Territory Region" + }, + { + "name": "SalesTerritoryKey" + }, + { + "name": "Sales Territory Country" + }, + { + "name": "Sales Territory Group" + }, + { + "name": "Sales Territory Image" + } + ], + "measures": [ + { + "name": "Total Gross Profit" + }, + { + "name": "Distinct Count Sales Orders" + }, + { + "name": "Total Previous Quarter Sales" + }, + { + "name": "Total Previous Quarter Gross Profit Proportion to QTD" + }, + { + "name": "Order Lines Count" + }, + { + "name": "Total Discount Amount" + }, + { + "name": "Total Previous Quarter Sales Proportion to QTD" + }, + { + "name": "Total Products Cost" + }, + { + "name": "Total Units Sold" + }, + { + "name": "Total Current Quarter Gross Profit Performance" + }, + { + "name": "Total Current Quarter Gross Profit" + }, + { + "name": "Total Previous Quarter Gross Profit" + }, + { + "name": "Total Sales - Sales Territory sliced by Employee" + }, + { + "name": "Total Current Quarter Sales" + }, + { + "name": "Total Tax Amount" + }, + { + "name": "Total Current Quarter Sales Performance" + }, + { + "name": "Total Freight" + }, + { + "name": "Total Sales" + } + ] + }, + { + "name": "Product", + "columns": [ + { + "name": "Product SubCategory Name" + }, + { + "name": "Style" + }, + { + "name": "Model Name" + }, + { + "name": "Product Name" + }, + { + "name": "Product Start Date" + }, + { + "name": "Weight Unit Code" + }, + { + "name": "Safety Stock Level" + }, + { + "name": "Product Id" + }, + { + "name": "Standard Cost" + }, + { + "name": "Color" + }, + { + "name": "Days To Manufacture" + }, + { + "name": "Dealer Price" + }, + { + "name": "ProductKey" + }, + { + "name": "LargePhoto" + }, + { + "name": "Size" + }, + { + "name": "Is Finished Goods" + }, + { + "name": "Description" + }, + { + "name": "Product Line" + }, + { + "name": "Size Unit Code" + }, + { + "name": "List Price" + }, + { + "name": "Class" + }, + { + "name": "Size Range" + }, + { + "name": "Reorder Point" + }, + { + "name": "Product Status" + }, + { + "name": "Weight" + }, + { + "name": "ProductSubcategoryKey" + }, + { + "name": "Product Category Name" + }, + { + "name": "Product End Date" + } + ] + }, + { + "name": "Promotion", + "columns": [ + { + "name": "Promotion Name" + }, + { + "name": "Max Quantity" + }, + { + "name": "Promotion Type" + }, + { + "name": "Promotion Start Date" + }, + { + "name": "Min Quantity" + }, + { + "name": "Promotion Category" + }, + { + "name": "DiscountPct" + }, + { + "name": "PromotionKey" + }, + { + "name": "Promotion End Date" + } + ] + }, + { + "name": "Product Subcategory", + "columns": [ + { + "name": "Product Subcategory Name" + }, + { + "name": "ProductSubcategoryKey" + }, + { + "name": "ProductCategoryKey" + } + ] + }, + { + "name": "Employee", + "columns": [ + { + "name": "ParentEmployeeKey" + }, + { + "name": "Middle Name" + }, + { + "name": "NameStyle" + }, + { + "name": "Hire Date" + }, + { + "name": "Marital Status" + }, + { + "name": "Pay Frequency" + }, + { + "name": "Phone" + }, + { + "name": "Email" + }, + { + "name": "Gender" + }, + { + "name": "Vacation Hours" + }, + { + "name": "Employee Id" + }, + { + "name": "Is Current" + }, + { + "name": "Login" + }, + { + "name": "First Name" + }, + { + "name": "Is Salaried" + }, + { + "name": "Base Rate" + }, + { + "name": "Birth Date" + }, + { + "name": "Sick Leave Hours" + }, + { + "name": "Last Name" + }, + { + "name": "SalesTerritoryKey" + }, + { + "name": "Status" + }, + { + "name": "Emergency Contact Name" + }, + { + "name": "Title" + }, + { + "name": "Department Name" + }, + { + "name": "Emergency Contact Phone" + }, + { + "name": "EmployeeKey" + }, + { + "name": "End Date" + }, + { + "name": "Is Sales Person" + }, + { + "name": "Employee Photo" + }, + { + "name": "Start Date" + } + ] + }, + { + "name": "Geography", + "columns": [ + { + "name": "City" + }, + { + "name": "State Province Name" + }, + { + "name": "Country Region Code" + }, + { + "name": "State Province Code" + }, + { + "name": "SalesTerritoryKey" + }, + { + "name": "GeographyKey" + }, + { + "name": "Country Region Name" + }, + { + "name": "Postal Code" + } + ] + }, + { + "name": "Reseller", + "columns": [ + { + "name": "Year Opened" + }, + { + "name": "Order Month" + }, + { + "name": "Business Type" + }, + { + "name": "Annual Sales" + }, + { + "name": "Number Employees" + }, + { + "name": "Reseller Id" + }, + { + "name": "Address Line 2" + }, + { + "name": "GeographyKey" + }, + { + "name": "Reseller Phone" + }, + { + "name": "ResellerKey" + }, + { + "name": "Min Payment Type" + }, + { + "name": "Address Line 1" + }, + { + "name": "Bank Name" + }, + { + "name": "Annua Revenue" + }, + { + "name": "Reseller Name" + }, + { + "name": "Min Payment Amount" + }, + { + "name": "Product Line" + }, + { + "name": "Last Order Year" + }, + { + "name": "First Order Year" + }, + { + "name": "Order Frequency" + } + ] + }, + { + "name": "Sales Quota", + "columns": [ + { + "name": "Calendar Quarter" + }, + { + "name": "Sales Amount Quota" + }, + { + "name": "Calendar Year" + }, + { + "name": "Date" + }, + { + "name": "DateKey" + }, + { + "name": "EmployeeKey" + }, + { + "name": "SalesQuotaKey" + } + ] + }, + { + "name": "Currency", + "columns": [ + { + "name": "CurrencyKey" + }, + { + "name": "Currency Code" + }, + { + "name": "CurrencyName" + } + ] + }, + { + "name": "Product Category", + "columns": [ + { + "name": "Product Category Name" + }, + { + "name": "ProductCategoryKey" + } + ] + } + ] + } + ], + "roles": [ + { + "name": "Users", + "description": "All allowed users to query the model", + "modelPermission": "read" + }, + { + "name": "Admins", + "description": "All administrators", + "modelPermission": "administrator" + }, + { + "name": "Analysts", + "description": "All users responsible for the status of the model", + "modelPermission": "readRefresh" + }, + { + "name": "Operators", + "description": "All users responsible for updating the data", + "modelPermission": "refresh" + } + ] + } +} \ No newline at end of file diff --git a/AsPartitionProcessing/AsPartitionProcessing.SampleClient/App.config b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/App.config new file mode 100644 index 0000000..624d5ce --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/App.config @@ -0,0 +1,24 @@ + + + + +
+ + + + + + + + + localhost + + + AsPartitionProcessing + + + True + + + + diff --git a/AsPartitionProcessing/AsPartitionProcessing.SampleClient/AsPartitionProcessing.SampleClient.csproj b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/AsPartitionProcessing.SampleClient.csproj new file mode 100644 index 0000000..62ae3f1 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/AsPartitionProcessing.SampleClient.csproj @@ -0,0 +1,88 @@ + + + + + Debug + AnyCPU + {C45B329D-F606-4F89-A41A-785C247F24B2} + Exe + Properties + AsPartitionProcessing.SampleClient + AsPartitionProcessing.SampleClient + v4.5.2 + 512 + true + + + + AnyCPU + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + + + AnyCPU + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + + + + False + ..\..\..\..\..\..\..\Program Files (x86)\Microsoft SQL Server\130\SDK\Assemblies\Microsoft.AnalysisServices.DLL + + + False + ..\..\..\..\..\..\..\Program Files (x86)\Microsoft SQL Server\130\SDK\Assemblies\Microsoft.AnalysisServices.Core.DLL + + + False + ..\..\..\..\..\..\..\Program Files (x86)\Microsoft SQL Server\130\SDK\Assemblies\Microsoft.AnalysisServices.Tabular.DLL + + + + + + + + + + + + + + + True + True + Settings.settings + + + + + + SettingsSingleFileGenerator + Settings.Designer.cs + + + + + {fb937281-b06d-47fb-9846-e97b0287afce} + AsPartitionProcessing + + + + + \ No newline at end of file diff --git a/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Program.cs b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Program.cs new file mode 100644 index 0000000..9c4a0e4 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Program.cs @@ -0,0 +1,248 @@ +using System; +using System.Collections.Generic; +using Microsoft.AnalysisServices.Tabular; + + +namespace AsPartitionProcessing.SampleClient +{ + class Program + { + const bool UseDatabase = true; + + static void Main(string[] args) + { + try + { + List modelsConfig; + if (!UseDatabase) + { + modelsConfig = InitializeAdventureWorksInline(); + } + else + { + modelsConfig = InitializeFromDatabase(); + } + + foreach (ModelConfiguration modelConfig in modelsConfig) + { + if (!modelConfig.IntegratedAuth) //For Azure AS + { + Console.WriteLine(); + Console.Write("User name for AS server: "); + modelConfig.UserName = Console.ReadLine(); + Console.Write("Password for AS server: "); + modelConfig.Password = ReadPassword(); + } + + //Most important method: + PartitionProcessor.PerformProcessing(modelConfig, LogMessage); + } + } + catch (Exception exc) + { + Console.ForegroundColor = ConsoleColor.Red; + Console.WriteLine(); + Console.WriteLine(exc.Message, null); + } + + Console.WriteLine("Press any key to exit."); + Console.ReadKey(); + } + + private static List InitializeAdventureWorksInline() + { + ModelConfiguration partitionedModel = new ModelConfiguration( + modelConfigurationID: 1, + analysisServicesServer: "localhost", + analysisServicesDatabase: "AdventureWorks", + initialSetUp: true, + incrementalOnline: true, + incrementalParallelTables: true, + integratedAuth: true, + userName: "", + password: "", + tableConfigurations: + new List + { + new TableConfiguration( + tableConfigurationID: 1, + analysisServicesTable: "Internet Sales", + partitioningConfigurations: + new List + { + new PartitioningConfiguration( + partitioningConfigurationID: 1, + granularity: Granularity.Monthly, + numberOfPartitionsFull: 12, + numberOfPartitionsForIncrementalProcess: 3, + maxDate: Convert.ToDateTime("2012-12-01"), + sourceTableName: "[dbo].[FactInternetSales]", + sourcePartitionColumn: "OrderDateKey" + ) + } + ), + new TableConfiguration( + tableConfigurationID: 2, + analysisServicesTable: "Reseller Sales", + partitioningConfigurations: + new List + { + new PartitioningConfiguration( + partitioningConfigurationID: 2, + granularity: Granularity.Yearly, + numberOfPartitionsFull: 3, + numberOfPartitionsForIncrementalProcess: 1, + maxDate: Convert.ToDateTime("2012-12-01"), + sourceTableName: "[dbo].[FactResellerSales]", + sourcePartitionColumn: "OrderDateKey" + ) + } + ) + } + ); + + #region Not needed as sample includes pre-prepared version of AdventureWorks + + ////This section not to be used normally - just to get started with AdventureWorks. It removes existing partitions that come in AdventureWorks and creates a template one to align with assumptions listed at top of PartitionProcessor.cs file. + //if (partitionedModel.InitialSetUp) + //{ + // Console.WriteLine("Initialize AdventureWorks template partitions? [y/n]"); + // if (Console.ReadLine().ToLower() == "y") + // InitializeAdventureWorksDatabase(partitionedModel); + //} + + #endregion + + return new List { partitionedModel }; + } + + private static List InitializeFromDatabase() + { + ConfigDatabaseConnectionInfo connectionInfo = new ConfigDatabaseConnectionInfo(); + + connectionInfo.Server = Settings.Default.ConfigServer; + connectionInfo.Database = Settings.Default.ConfigDatabase; + connectionInfo.IntegratedAuth = Settings.Default.ConfigDatabaseIntegratedAuth; + + if (!Settings.Default.ConfigDatabaseIntegratedAuth) + { + Console.Write("User name for config database: "); + connectionInfo.UserName = Console.ReadLine(); + Console.Write("Password for config database: "); + connectionInfo.Password = ReadPassword(); + } + + return ConfigDatabaseHelper.ReadConfig(connectionInfo); + } + + private static void LogMessage(string message, ModelConfiguration partitionedModel) + { + //Can provide custom logger here + try + { + if (UseDatabase) + ConfigDatabaseHelper.LogMessage(message, partitionedModel); + + Console.WriteLine(message); + } + catch (Exception exc) + { + Console.WriteLine(exc.Message); + Console.WriteLine("Press any key to exit."); + Console.ReadKey(); + Environment.Exit(0); //Avoid recursion if errored connecting to db + } + } + + public static string ReadPassword() + { + string password = ""; + ConsoleKeyInfo info = Console.ReadKey(true); + while (info.Key != ConsoleKey.Enter) + { + if (info.Key != ConsoleKey.Backspace) + { + Console.Write("*"); + password += info.KeyChar; + } + else if (info.Key == ConsoleKey.Backspace) + { + if (!string.IsNullOrEmpty(password)) + { + // remove one character from the list of password characters + password = password.Substring(0, password.Length - 1); + // get the location of the cursor + int pos = Console.CursorLeft; + // move the cursor to the left by one character + Console.SetCursorPosition(pos - 1, Console.CursorTop); + // replace it with space + Console.Write(" "); + // move the cursor to the left by one character again + Console.SetCursorPosition(pos - 1, Console.CursorTop); + } + } + info = Console.ReadKey(true); + } + // add a new line because user pressed enter at the end of password + Console.WriteLine(); + return password; + } + + #region Not needed as sample includes pre-prepared version of AdventureWorks + + private static void InitializeAdventureWorksDatabase(ModelConfiguration parameters) + { + //In order to align with assumptions listed in PartitionProcessor.cs, need to: + //1. Delete existing partitions in InternetSales and ResellerSales + //2. Create template partition (again, see comments at top of PartitionProcessor.cs) + + Console.WriteLine("Initializing AdventureWorks ..."); + + using (Server server = new Server()) + { + //Connect and get main objects + string serverConnectionString; + if (parameters.IntegratedAuth) + serverConnectionString = $"Provider=MSOLAP;Data Source={parameters.AnalysisServicesServer};"; + else + { + serverConnectionString = $"Provider=MSOLAP;Data Source={parameters.AnalysisServicesServer};User ID={parameters.UserName};Password={parameters.Password};Persist Security Info=True;Impersonation Level=Impersonate;"; + } + server.Connect(serverConnectionString); + + Database database = server.Databases.FindByName(parameters.AnalysisServicesDatabase); + if (database == null) + { + throw new Microsoft.AnalysisServices.ConnectionException($"Could not connect to database {parameters.AnalysisServicesDatabase}."); + } + + InitializeAdventureWorksTable(database, "Internet Sales", "[dbo].[FactInternetSales]"); + InitializeAdventureWorksTable(database, "Reseller Sales", "[dbo].[FactResellerSales]"); + + database.Update(Microsoft.AnalysisServices.UpdateOptions.ExpandFull); + server.Disconnect(); + } + } + + private static void InitializeAdventureWorksTable(Database database, string analysisServicesTableName, string sourceFactTableName) + { + Table table = database.Model.Tables.Find(analysisServicesTableName); + if (table == null) + { + throw new Microsoft.AnalysisServices.ConnectionException($"Could not connect to table {analysisServicesTableName}."); + } + table.Partitions.Clear(); + Partition templatePartition = new Partition(); + templatePartition.Name = analysisServicesTableName; + table.Partitions.Add(templatePartition); + templatePartition.Source = new QueryPartitionSource() + { + DataSource = database.Model.DataSources[0], //Assuming this is only data source (SqlServer localhost) + Query = $"SELECT * FROM {sourceFactTableName}" + }; + } + + #endregion + } +} + diff --git a/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Properties/AssemblyInfo.cs b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Properties/AssemblyInfo.cs new file mode 100644 index 0000000..652f509 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Properties/AssemblyInfo.cs @@ -0,0 +1,36 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// General Information about an assembly is controlled through the following +// set of attributes. Change these attribute values to modify the information +// associated with an assembly. +[assembly: AssemblyTitle("AsPartitionProcessing.SampleClient")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("Microsoft Corporation")] +[assembly: AssemblyProduct("AsPartitionProcessing.SampleClient")] +[assembly: AssemblyCopyright("Copyright © Microsoft Corporation 2016")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// Setting ComVisible to false makes the types in this assembly not visible +// to COM components. If you need to access a type in this assembly from +// COM, set the ComVisible attribute to true on that type. +[assembly: ComVisible(false)] + +// The following GUID is for the ID of the typelib if this project is exposed to COM +[assembly: Guid("c45b329d-f606-4f89-a41a-785c247f24b2")] + +// Version information for an assembly consists of the following four values: +// +// Major Version +// Minor Version +// Build Number +// Revision +// +// You can specify all the values or you can default the Build and Revision Numbers +// by using the '*' as shown below: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Settings.Designer.cs b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Settings.Designer.cs new file mode 100644 index 0000000..15ddb4b --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Settings.Designer.cs @@ -0,0 +1,62 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace AsPartitionProcessing.SampleClient { + + + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "14.0.0.0")] + internal sealed partial class Settings : global::System.Configuration.ApplicationSettingsBase { + + private static Settings defaultInstance = ((Settings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new Settings()))); + + public static Settings Default { + get { + return defaultInstance; + } + } + + [global::System.Configuration.UserScopedSettingAttribute()] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Configuration.DefaultSettingValueAttribute("localhost")] + public string ConfigServer { + get { + return ((string)(this["ConfigServer"])); + } + set { + this["ConfigServer"] = value; + } + } + + [global::System.Configuration.UserScopedSettingAttribute()] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Configuration.DefaultSettingValueAttribute("AsPartitionProcessing")] + public string ConfigDatabase { + get { + return ((string)(this["ConfigDatabase"])); + } + set { + this["ConfigDatabase"] = value; + } + } + + [global::System.Configuration.UserScopedSettingAttribute()] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Configuration.DefaultSettingValueAttribute("True")] + public bool ConfigDatabaseIntegratedAuth { + get { + return ((bool)(this["ConfigDatabaseIntegratedAuth"])); + } + set { + this["ConfigDatabaseIntegratedAuth"] = value; + } + } + } +} diff --git a/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Settings.settings b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Settings.settings new file mode 100644 index 0000000..14e4cff --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing.SampleClient/Settings.settings @@ -0,0 +1,15 @@ + + + + + + localhost + + + AsPartitionProcessing + + + True + + + \ No newline at end of file diff --git a/AsPartitionProcessing/AsPartitionProcessing.sln b/AsPartitionProcessing/AsPartitionProcessing.sln new file mode 100644 index 0000000..af53563 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing.sln @@ -0,0 +1,73 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio 14 +VisualStudioVersion = 14.0.25420.1 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "AsPartitionProcessing", "AsPartitionProcessing\AsPartitionProcessing.csproj", "{FB937281-B06D-47FB-9846-E97B0287AFCE}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "AsPartitionProcessing.SampleClient", "AsPartitionProcessing.SampleClient\AsPartitionProcessing.SampleClient.csproj", "{C45B329D-F606-4F89-A41A-785C247F24B2}" +EndProject +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{0B23151E-8A6B-44AA-B670-797D1EB8B3C0}" + ProjectSection(SolutionItems) = preProject + AdventureWorksDW.bak = AdventureWorksDW.bak + CreateDatabaseObjects.sql = CreateDatabaseObjects.sql + SampleConfiguration.sql = SampleConfiguration.sql + EndProjectSection +EndProject +Project("{6870E480-7721-4708-BFB8-9AE898AA21B3}") = "AsPartitionProcessing.AdventureWorks", "AsPartitionProcessing.AdventureWorks\AsPartitionProcessing.AdventureWorks.smproj", "{7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Debug|x86 = Debug|x86 + Development|Any CPU = Development|Any CPU + Development|x86 = Development|x86 + Release|Any CPU = Release|Any CPU + Release|x86 = Release|x86 + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Debug|Any CPU.Build.0 = Debug|Any CPU + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Debug|x86.ActiveCfg = Debug|Any CPU + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Debug|x86.Build.0 = Debug|Any CPU + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Development|Any CPU.ActiveCfg = Debug|Any CPU + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Development|Any CPU.Build.0 = Debug|Any CPU + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Development|x86.ActiveCfg = Debug|Any CPU + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Development|x86.Build.0 = Debug|Any CPU + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Release|Any CPU.ActiveCfg = Release|Any CPU + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Release|Any CPU.Build.0 = Release|Any CPU + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Release|x86.ActiveCfg = Release|Any CPU + {FB937281-B06D-47FB-9846-E97B0287AFCE}.Release|x86.Build.0 = Release|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Debug|Any CPU.Build.0 = Debug|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Debug|x86.ActiveCfg = Debug|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Debug|x86.Build.0 = Debug|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Development|Any CPU.ActiveCfg = Debug|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Development|Any CPU.Build.0 = Debug|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Development|x86.ActiveCfg = Debug|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Development|x86.Build.0 = Debug|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Release|Any CPU.ActiveCfg = Release|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Release|Any CPU.Build.0 = Release|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Release|x86.ActiveCfg = Release|Any CPU + {C45B329D-F606-4F89-A41A-785C247F24B2}.Release|x86.Build.0 = Release|Any CPU + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Debug|Any CPU.ActiveCfg = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Debug|Any CPU.Build.0 = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Debug|Any CPU.Deploy.0 = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Debug|x86.ActiveCfg = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Debug|x86.Build.0 = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Debug|x86.Deploy.0 = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Development|Any CPU.ActiveCfg = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Development|x86.ActiveCfg = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Development|x86.Build.0 = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Development|x86.Deploy.0 = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Release|Any CPU.ActiveCfg = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Release|Any CPU.Build.0 = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Release|Any CPU.Deploy.0 = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Release|x86.ActiveCfg = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Release|x86.Build.0 = Development|x86 + {7274EFCC-E7DF-40AD-83DF-1DFD5B954E67}.Release|x86.Deploy.0 = Development|x86 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/AsPartitionProcessing/AsPartitionProcessing/AsPartitionProcessing.csproj b/AsPartitionProcessing/AsPartitionProcessing/AsPartitionProcessing.csproj new file mode 100644 index 0000000..d32727a --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing/AsPartitionProcessing.csproj @@ -0,0 +1,73 @@ + + + + + Debug + AnyCPU + {FB937281-B06D-47FB-9846-E97B0287AFCE} + Library + Properties + AsPartitionProcessing + AsPartitionProcessing + v4.5.2 + 512 + + + + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + + + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + bin\Release\AsPartitionProcessing.XML + + + + False + ..\..\..\..\..\..\..\Program Files (x86)\Microsoft SQL Server\130\SDK\Assemblies\Microsoft.AnalysisServices.DLL + + + False + ..\..\..\..\..\..\..\Program Files (x86)\Microsoft SQL Server\130\SDK\Assemblies\Microsoft.AnalysisServices.Core.DLL + + + False + ..\..\..\..\..\..\..\Program Files (x86)\Microsoft SQL Server\130\SDK\Assemblies\Microsoft.AnalysisServices.Tabular.DLL + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/AsPartitionProcessing/AsPartitionProcessing/ConfigDatabaseConnectionInfo.cs b/AsPartitionProcessing/AsPartitionProcessing/ConfigDatabaseConnectionInfo.cs new file mode 100644 index 0000000..879d99a --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing/ConfigDatabaseConnectionInfo.cs @@ -0,0 +1,35 @@ +using System; + +namespace AsPartitionProcessing +{ + /// + /// Information required to connect to the configuration and logging database. + /// + public class ConfigDatabaseConnectionInfo + { + /// + /// Database server name. + /// + public string Server { get; set; } + + /// + /// Name of the database. + /// + public string Database { get; set; } + + /// + /// User name used for connection. + /// + public string UserName { get; set; } + + /// + /// Password used for connection. + /// + public string Password { get; set; } + + /// + /// Whether connection to be made using integrated authentication or SQL authentication. + /// + public bool IntegratedAuth { get; set; } + } +} diff --git a/AsPartitionProcessing/AsPartitionProcessing/ConfigDatabaseHelper.cs b/AsPartitionProcessing/AsPartitionProcessing/ConfigDatabaseHelper.cs new file mode 100644 index 0000000..69cd1b9 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing/ConfigDatabaseHelper.cs @@ -0,0 +1,195 @@ +using System; +using System.Data; +using System.Data.SqlClient; +using System.Collections.Generic; + +namespace AsPartitionProcessing +{ + /// + /// Class containing helper methods for reading and writing to the configuration and logging database. + /// + public static class ConfigDatabaseHelper + { + /// + /// Read configuration information from the database. + /// + /// Information required to connect to the configuration and logging database. + /// Collection of partitioned models with configuration information. + public static List ReadConfig(ConfigDatabaseConnectionInfo connectionInfo) + { + using (SqlConnection connection = new SqlConnection(GetConnectionString(connectionInfo))) + { + connection.Open(); + using (SqlCommand command = new SqlCommand()) + { + command.Connection = connection; + command.CommandType = CommandType.Text; + command.CommandText = @" + SELECT [ModelConfigurationID] + ,[AnalysisServicesServer] + ,[AnalysisServicesDatabase] + ,[InitialSetUp] + ,[IncrementalOnline] + ,[IncrementalParallelTables] + ,[IntegratedAuth] + ,[TableConfigurationID] + ,[AnalysisServicesTable] + ,[Partitioned] + ,[PartitioningConfigurationID] + ,[Granularity] + ,[NumberOfPartitionsFull] + ,[NumberOfPartitionsForIncrementalProcess] + ,[MaxDate] + ,[SourceTableName] + ,[SourcePartitionColumn] + FROM [dbo].[vPartitioningConfiguration] + ORDER BY + [ModelConfigurationID], + [TableConfigurationID], + [PartitioningConfigurationID];"; + + List modelConfigs = new List(); + ModelConfiguration modelConfig = null; + int currentModelConfigurationID = -1; + + SqlDataReader reader = command.ExecuteReader(); + while (reader.Read()) + { + TableConfiguration tableConfig = null; + int currentTableConfigurationID = -1; + + if (modelConfig == null || currentModelConfigurationID != Convert.ToInt32(reader["ModelConfigurationID"])) + { + modelConfig = new ModelConfiguration(); + modelConfig.TableConfigurations = new List(); + modelConfigs.Add(modelConfig); + + modelConfig.ModelConfigurationID = Convert.ToInt32(reader["ModelConfigurationID"]); + modelConfig.AnalysisServicesServer = Convert.ToString(reader["AnalysisServicesServer"]); + modelConfig.AnalysisServicesDatabase = Convert.ToString(reader["AnalysisServicesDatabase"]); + modelConfig.InitialSetUp = Convert.ToBoolean(reader["InitialSetUp"]); + modelConfig.IncrementalOnline = Convert.ToBoolean(reader["IncrementalOnline"]); + modelConfig.IncrementalParallelTables = Convert.ToBoolean(reader["IncrementalParallelTables"]); + modelConfig.IntegratedAuth = Convert.ToBoolean(reader["IntegratedAuth"]); + modelConfig.ConfigDatabaseConnectionInfo = connectionInfo; + + currentModelConfigurationID = modelConfig.ModelConfigurationID; + } + + if (tableConfig == null || currentTableConfigurationID != Convert.ToInt32(reader["TableConfigurationID"])) + { + tableConfig = new TableConfiguration(); + tableConfig.PartitioningConfigurations = new List(); + modelConfig.TableConfigurations.Add(tableConfig); + + tableConfig.TableConfigurationID = Convert.ToInt32(reader["TableConfigurationID"]); + tableConfig.AnalysisServicesTable = Convert.ToString(reader["AnalysisServicesTable"]); + + currentTableConfigurationID = tableConfig.TableConfigurationID; + } + + if (Convert.ToBoolean(reader["Partitioned"])) + { + tableConfig.PartitioningConfigurations.Add( + new PartitioningConfiguration( + Convert.ToInt32(reader["PartitioningConfigurationID"]), + (Granularity)Convert.ToInt32(reader["Granularity"]), + Convert.ToInt32(reader["NumberOfPartitionsFull"]), + Convert.ToInt32(reader["NumberOfPartitionsForIncrementalProcess"]), + Convert.ToDateTime(reader["MaxDate"]), + Convert.ToString(reader["SourceTableName"]), + Convert.ToString(reader["SourcePartitionColumn"]) + ) + ); + } + } + + return modelConfigs; + } + } + } + + /// + /// Delete all existing logs from the database. Useful in demo scenarios to initialize the database. + /// + /// Information required to connect to the configuration and logging database. + public static void ClearLogTable(ConfigDatabaseConnectionInfo connectionInfo) + { + using (var connection = new SqlConnection(GetConnectionString(connectionInfo))) + { + connection.Open(); + using (var command = new SqlCommand()) + { + command.Connection = connection; + command.CommandType = CommandType.Text; + command.CommandText = "DELETE FROM [dbo].[PartitionedModelLog];"; + command.ExecuteNonQuery(); + } + } + } + + /// + /// Log a message to the databsae. + /// + /// Message to be logged. + /// Partitioned model with configuration information. + public static void LogMessage(string message, ModelConfiguration partitionedModel) + { + using (var connection = new SqlConnection(GetConnectionString(partitionedModel.ConfigDatabaseConnectionInfo))) + { + connection.Open(); + using (var command = new SqlCommand()) + { + command.Connection = connection; + command.CommandType = CommandType.Text; + command.CommandText = @" + INSERT INTO [dbo].[PartitionedModelLog] + ([ModelConfigurationID] + ,[ExecutionID] + ,[LogDateTime] + ,[Message]) + VALUES + (@ModelConfigurationID + ,@ExecutionID + ,@LogDateTime + ,@Message);"; + + SqlParameter parameter; + + parameter = new SqlParameter("@ModelConfigurationID", SqlDbType.Int); + parameter.Value = partitionedModel.ModelConfigurationID; + command.Parameters.Add(parameter); + + parameter = new SqlParameter("@ExecutionID", SqlDbType.Char, 36); + parameter.Value = partitionedModel.ExecutionID; + command.Parameters.Add(parameter); + + parameter = new SqlParameter("@LogDateTime", SqlDbType.DateTime); + parameter.Value = DateTime.Now; + command.Parameters.Add(parameter); + + parameter = new SqlParameter("@Message", SqlDbType.VarChar, 4000); + parameter.Value = message; + command.Parameters.Add(parameter); + + command.ExecuteNonQuery(); + } + } + } + + private static string GetConnectionString(ConfigDatabaseConnectionInfo connectionInfo) + { + string connectionString; + if (connectionInfo.IntegratedAuth) + { + connectionString = $"Server={connectionInfo.Server};Database={connectionInfo.Database};Integrated Security=SSPI;"; + } + else + { + connectionString = $"Server={connectionInfo.Server};Database={connectionInfo.Database};User ID={connectionInfo.UserName};Password={connectionInfo.Password};"; + } + + return connectionString; + } + } +} diff --git a/AsPartitionProcessing/AsPartitionProcessing/LogMessageEventArgs.cs b/AsPartitionProcessing/AsPartitionProcessing/LogMessageEventArgs.cs new file mode 100644 index 0000000..772f934 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing/LogMessageEventArgs.cs @@ -0,0 +1,14 @@ +using System; + +namespace AsPartitionProcessing +{ + public class LogMessageEventArgs : EventArgs + { + public string Message { get; set; } + + public LogMessageEventArgs(string message) + { + Message = message; + } + } +} diff --git a/AsPartitionProcessing/AsPartitionProcessing/ModelConfiguration.cs b/AsPartitionProcessing/AsPartitionProcessing/ModelConfiguration.cs new file mode 100644 index 0000000..9eb2358 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing/ModelConfiguration.cs @@ -0,0 +1,118 @@ +using System; +using System.Collections.Generic; + +namespace AsPartitionProcessing +{ + /// + /// Configuration information for a partitioned AS tabular model. + /// + public class ModelConfiguration + { + /// + /// ID of the ModelConfiguration table. + /// + public int ModelConfigurationID { get; set; } + + /// + /// Name of the Analysis Services instance. Can be SSAS or an Azure AS URL. + /// + public string AnalysisServicesServer { get; set; } + + /// + /// Name of the Analysis Services database. + /// + public string AnalysisServicesDatabase { get; set; } + + /// + /// True for initial set up to create partitions and process them sequentially. False for incremental processing. + /// + public bool InitialSetUp { get; set; } + + /// + /// When initialSetUp=false, determines if processing is performed as an online operation, which may require more memory, but users can still query the model. + /// + public bool IncrementalOnline { get; set; } + + /// + /// When initialSetUp=false, determines if separate tables are processed in parallel. Partitions within a table are always processed in parallel. + /// + public bool IncrementalParallelTables { get; set; } + + /// + /// Should always set to true for SSAS implementations that will run under the current process account. For Azure AS, normally set to false. + /// + public bool IntegratedAuth { get; set; } + + /// + /// Only applies when integratedAuth=false. Used for Azure AD UPNs to connect to Azure AS. + /// + public string UserName { get; set; } + + /// + /// Only applies when integratedAuth=false. Used for Azure AD UPNs to connect to Azure AS. + /// + public string Password { get; set; } + + /// + /// Collection of partitioned tables containing configuration information. + /// + public List TableConfigurations { get; set; } + + /// + /// Connection information to connect to the configuration and logging database. + /// + public ConfigDatabaseConnectionInfo ConfigDatabaseConnectionInfo { get; set; } + + /// + /// GUID generated to the execution run. + /// + public string ExecutionID { get; set; } + + /// + /// Parameters normally from configuration database to determine partitioning ranges and design. + /// + /// ID of the ModelConfiguration table. + /// Name of the Analysis Services instance. Can be SSAS or an Azure AS URL. + /// Name of the Analysis Services database. + /// True for initial set up to create partitions and process them sequentially. False for incremental processing. + /// When initialSetUp=false, determines if processing is performed as an online operation, which may require more memory, but users can still query the model. + /// When initialSetUp=false, determines if separate tables are processed in parallel. Partitions within a table are always processed in parallel. + /// Should always set to true for SSAS implementations that will run under the current process account. For Azure AS, normally set to false. + /// Only applies when integratedAuth=false. Used for Azure AD UPNs to connect to Azure AS. + /// Only applies when integratedAuth=false. Used for Azure AD UPNs to connect to Azure AS. + /// Collection of partitioned tables containing configuration information. + public ModelConfiguration( + int modelConfigurationID, + string analysisServicesServer, + string analysisServicesDatabase, + bool initialSetUp, + bool incrementalOnline, + bool incrementalParallelTables, + bool integratedAuth, + string userName, + string password, + List tableConfigurations + ) + { + ModelConfigurationID = modelConfigurationID; + AnalysisServicesServer = analysisServicesServer; + AnalysisServicesDatabase = analysisServicesDatabase; + InitialSetUp = initialSetUp; + IncrementalOnline = incrementalOnline; + IncrementalParallelTables = incrementalParallelTables; + IntegratedAuth = integratedAuth; + UserName = userName; + Password = password; + TableConfigurations = tableConfigurations; + ExecutionID = Guid.NewGuid().ToString(); + } + + /// + /// Default constructor. + /// + public ModelConfiguration() + { + ExecutionID = Guid.NewGuid().ToString(); + } + } +} diff --git a/AsPartitionProcessing/AsPartitionProcessing/PartitionProcessor.cs b/AsPartitionProcessing/AsPartitionProcessing/PartitionProcessor.cs new file mode 100644 index 0000000..35618ee --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing/PartitionProcessor.cs @@ -0,0 +1,367 @@ +using System; +using System.Collections.Generic; +using Microsoft.AnalysisServices.Tabular; + + +//----------- +//ASSUMPTIONS +//Rolling window. Removes oldest partition on increment +//Depends on date keys in source to be integers formatted as yyyymmdd +//Source queries take the form "SELECT * FROM WHERE FLOOR( / 100) = " (monthly) +//Template partition exists with same name as table +//Non-template partitions have name of the format yyyy (yearly), yyyymm (monthly), yyyymmdd (daily) +//----------- + + +namespace AsPartitionProcessing +{ + /// + /// Delegate to allow client to pass in a custom logging method + /// + /// The message to be logged + /// Configuration info for the model + public delegate void LogMessageDelegate(string message, ModelConfiguration modelConfiguration); + + /// + /// Processor of partitions in AS tabular models + /// + public static class PartitionProcessor + { + private static ModelConfiguration _modelConfiguration; + private static LogMessageDelegate _messageLogger; + + /// + /// Partitions tables in a tabular model based on configuration + /// + /// Configuration info for the model + /// Pointer to logging method + public static void PerformProcessing(ModelConfiguration modelConfiguration, LogMessageDelegate messageLogger) + { + _modelConfiguration = modelConfiguration; + _messageLogger = messageLogger; + + Server server = new Server(); + try + { + Database database; + Connect(server, out database); + + Console.ForegroundColor = ConsoleColor.White; + LogMessage($"Start: {DateTime.Now.ToString("hh:mm:ss tt")}", false); + LogMessage($"Server: {_modelConfiguration.AnalysisServicesServer}", false); + LogMessage($"Database: {_modelConfiguration.AnalysisServicesDatabase}", false); + Console.ForegroundColor = ConsoleColor.Yellow; + + foreach (TableConfiguration tableConfiguration in _modelConfiguration.TableConfigurations) + { + Table table = database.Model.Tables.Find(tableConfiguration.AnalysisServicesTable); + if (table == null) + { + throw new Microsoft.AnalysisServices.ConnectionException($"Could not connect to table {tableConfiguration.AnalysisServicesTable}."); + } + + if (tableConfiguration.PartitioningConfigurations.Count == 0) + { + //Non-partitioned table. Process at table level. + LogMessage("", false); + LogMessage($"Non-partitioned processing for table {tableConfiguration.AnalysisServicesTable}", false); + LogMessage(new String('-', tableConfiguration.AnalysisServicesTable.Length + 37), false); + + if (_modelConfiguration.IncrementalOnline) + { + LogMessage($"Process table {tableConfiguration.AnalysisServicesTable} /Full", true); + table.RequestRefresh(RefreshType.Full); + } + else + { + LogMessage($"Process table {tableConfiguration.AnalysisServicesTable} /DataOnly", true); + table.RequestRefresh(RefreshType.DataOnly); + } + } + else + { + //Non-partitioned table. Process based on partitioning configuration(s). + Partition templatePartition = table.Partitions.Find(tableConfiguration.AnalysisServicesTable); + if (templatePartition == null) + { + throw new Microsoft.AnalysisServices.ConnectionException($"Table {tableConfiguration.AnalysisServicesTable} does not contain a partition with the same name to act as the template partition."); + } + + foreach (PartitioningConfiguration partitioningConfiguration in tableConfiguration.PartitioningConfigurations) + { + LogMessage("", false); + LogMessage($"Rolling-window partitioning for table {tableConfiguration.AnalysisServicesTable}", false); + LogMessage(new String('-', tableConfiguration.AnalysisServicesTable.Length + 38), false); + + //Figure out what processing needs to be done + List partitionKeysCurrent = GetPartitionKeysTable(table, partitioningConfiguration.Granularity); + List partitionKeysNew = GetPartitionKeys(false, partitioningConfiguration, partitioningConfiguration.Granularity); + List partitionKeysForProcessing = GetPartitionKeys(true, partitioningConfiguration, partitioningConfiguration.Granularity); + DisplayPartitionRange(partitionKeysCurrent, true, partitioningConfiguration.Granularity); + DisplayPartitionRange(partitionKeysNew, false, partitioningConfiguration.Granularity); + LogMessage("", false); + LogMessage("=>Actions & progress:", false); + + //Check for old partitions that need to be removed + foreach (string partitionKey in partitionKeysCurrent) + { + if (Convert.ToInt32(partitionKey) < Convert.ToInt32(partitionKeysNew[0])) + { + LogMessage($"Remove old partition {DateFormatPartitionKey(partitionKey, partitioningConfiguration.Granularity)}", true); + table.Partitions.Remove(partitionKey); + } + } + + //Process partitions + string selectQueryTemplate; + switch (partitioningConfiguration.Granularity) + { + case Granularity.Daily: + selectQueryTemplate = "SELECT * FROM {0} WHERE {1} = {2} ORDER BY {1}"; + break; + case Granularity.Monthly: + selectQueryTemplate = "SELECT * FROM {0} WHERE FLOOR({1} / 100) = {2} ORDER BY {1}"; + break; + default: //Granularity.Yearly: + selectQueryTemplate = "SELECT * FROM {0} WHERE FLOOR({1} / 10000) = {2} ORDER BY {1}"; + break; + } + + foreach (string partitionKey in partitionKeysForProcessing) + { + Partition partitionToProcess = table.Partitions.Find(partitionKey); + + if (partitionToProcess == null) + { + //Doesn't exist so create it + partitionToProcess = new Partition(); + templatePartition.CopyTo(partitionToProcess); + partitionToProcess.Name = partitionKey; + ((QueryPartitionSource)partitionToProcess.Source).Query = String.Format(selectQueryTemplate, partitioningConfiguration.SourceTableName, partitioningConfiguration.SourcePartitionColumn, partitionKey); + table.Partitions.Add(partitionToProcess); + LogMessage($"Create new partition {DateFormatPartitionKey(partitionKey, partitioningConfiguration.Granularity)}", true); + + if (!_modelConfiguration.InitialSetUp) + { + IncrementalProcessPartition(partitionKey, partitionToProcess, partitioningConfiguration.Granularity); + } + } + else if (!_modelConfiguration.InitialSetUp) + { + //Existing partition for processing + IncrementalProcessPartition(partitionKey, partitionToProcess, partitioningConfiguration.Granularity); + } + + if (_modelConfiguration.InitialSetUp) + { + if (partitionToProcess.State != ObjectState.Ready) + { + //Process new partitions sequentially during initial setup so don't run out of memory + LogMessage($"Sequentially process {DateFormatPartitionKey(partitionKey, partitioningConfiguration.Granularity)} /DataOnly", true); + partitionToProcess.RequestRefresh(RefreshType.DataOnly); + database.Model.SaveChanges(); + } + else + { + //Partition already exists during initial setup (and is fully processed), so ignore it + LogMessage($"Partition {DateFormatPartitionKey(partitionKey, partitioningConfiguration.Granularity)} already exists and is processed", true); + } + } + } + } + + //Ensure template partition doesn't contain any data + if (_modelConfiguration.InitialSetUp) + { + ((QueryPartitionSource)templatePartition.Source).Query = String.Format("SELECT * FROM {0} WHERE 0=1", tableConfiguration.PartitioningConfigurations[0].SourceTableName); //assuming the same for all partitioning configurations + templatePartition.RequestRefresh(RefreshType.DataOnly); + } + } + + //If processing tables sequentially (but all partitions being done in parallel), then save changes now + if (!_modelConfiguration.IncrementalParallelTables) + { + LogMessage($"Save changes for table {tableConfiguration.AnalysisServicesTable} ...", true); + database.Model.SaveChanges(); + } + } + + //Commit the data changes, and bring model back online if necessary + + LogMessage("", false); + LogMessage("Final operations", false); + LogMessage(new String('-', 16), false); + + if (_modelConfiguration.IncrementalParallelTables) + { + LogMessage("Save changes ...", true); + database.Model.SaveChanges(); + } + + if (_modelConfiguration.InitialSetUp || (!_modelConfiguration.InitialSetUp && !_modelConfiguration.IncrementalOnline)) + { + LogMessage("Recalc model to bring back online ...", true); + + database.Model.RequestRefresh(RefreshType.Calculate); + database.Model.SaveChanges(); + } + + Console.ForegroundColor = ConsoleColor.White; + LogMessage("", false); + LogMessage("Finish: " + DateTime.Now.ToString("hh:mm:ss tt"), false); + } + catch (Exception exc) + { + Console.ForegroundColor = ConsoleColor.Red; + LogMessage("", false); + LogMessage($"Exception occurred: {DateTime.Now.ToString("hh:mm:ss tt")}", false); + LogMessage($"Exception message: {exc.Message}", false); + LogMessage($"Inner exception message: {exc.InnerException.Message}", false); + } + finally + { + try + { + _modelConfiguration = null; + _messageLogger = null; + if (server != null) server.Disconnect(); + } + catch { } + } + } + + private static void IncrementalProcessPartition(string partitionKey, Partition partitionToProcess, Granularity granularity) + { + if (_modelConfiguration.IncrementalOnline) + { + LogMessage($"Parallel process partition {DateFormatPartitionKey(partitionKey, granularity)} /Full", true); + partitionToProcess.RequestRefresh(RefreshType.Full); + } + else + { + LogMessage($"Parallel process partition {DateFormatPartitionKey(partitionKey, granularity)} /DataOnly", true); + partitionToProcess.RequestRefresh(RefreshType.DataOnly); + } + } + + private static void LogMessage(string message, bool indented) + { + _messageLogger($"{(indented ? new String(' ', 3) : "")}{message}", _modelConfiguration); + } + + private static string DateFormatPartitionKey(string partitionKey, Granularity granularity) + { + string returnVal = partitionKey.Substring(0, 4); + + try + { + if (granularity == Granularity.Monthly || granularity == Granularity.Daily) + { + returnVal += "-" + partitionKey.Substring(4, 2); + } + + if (granularity == Granularity.Daily) + { + returnVal += "-" + partitionKey.Substring(6, 2); + } + } + catch (ArgumentOutOfRangeException exc) + { + throw new InvalidOperationException($"Failed to derive date from partition key. Check the key {partitionKey} matches {Convert.ToString(granularity)} granularity."); + } + + return returnVal; + } + + private static void DisplayPartitionRange(List partitionKeys, bool current, Granularity granularity) + { + LogMessage("", false); + + if (partitionKeys.Count > 0) + { + LogMessage($"=>{(current ? "Current" : "New")} partition range ({Convert.ToString(granularity)}):", false); + LogMessage($"MIN partition: {DateFormatPartitionKey(partitionKeys[0], granularity)}", true); + LogMessage($"MAX partition: {DateFormatPartitionKey(partitionKeys[partitionKeys.Count - 1], granularity)}", true); + LogMessage($"Partition count: {partitionKeys.Count}", true); + } + else + { + LogMessage("=>Table not yet partitioned", false); + } + } + + private static void Connect(Server server, out Database database) + { + //Connect and get main objects + string serverConnectionString; + if (_modelConfiguration.IntegratedAuth) + serverConnectionString = $"Provider=MSOLAP;Data Source={_modelConfiguration.AnalysisServicesServer};"; + else + { + serverConnectionString = $"Provider=MSOLAP;Data Source={_modelConfiguration.AnalysisServicesServer};User ID={_modelConfiguration.UserName};Password={_modelConfiguration.Password};Persist Security Info=True;Impersonation Level=Impersonate;"; + } + server.Connect(serverConnectionString); + + database = server.Databases.FindByName(_modelConfiguration.AnalysisServicesDatabase); + if (database == null) + { + throw new Microsoft.AnalysisServices.ConnectionException($"Could not connect to database {_modelConfiguration.AnalysisServicesDatabase}."); + } + } + + private static List GetPartitionKeys(bool forProcessing, PartitioningConfiguration partitioningConfiguration, Granularity granularity) + { + //forProcessing: false to return complete target set of partitions, true to return partitons to be processed (may be less if incremental mode). + + List partitionKeys = new List(); + int numberOfPartitions = (forProcessing && !_modelConfiguration.InitialSetUp ? partitioningConfiguration.NumberOfPartitionsForIncrementalProcess : partitioningConfiguration.NumberOfPartitionsFull); + + for (int i = numberOfPartitions - 1; i >= 0; i--) + { + DateTime periodToAdd; + switch (granularity) + { + case Granularity.Daily: + periodToAdd = partitioningConfiguration.MaxDate.AddDays(-i); + partitionKeys.Add(Convert.ToString((periodToAdd.Year * 100 + periodToAdd.Month) * 100 + periodToAdd.Day)); + break; + case Granularity.Monthly: + periodToAdd = partitioningConfiguration.MaxDate.AddMonths(-i); + partitionKeys.Add(Convert.ToString(periodToAdd.Year * 100 + periodToAdd.Month)); + break; + default: //Granularity.Yearly: + periodToAdd = partitioningConfiguration.MaxDate.AddYears(-i); + partitionKeys.Add(Convert.ToString(periodToAdd.Year)); + break; + } + } + partitionKeys.Sort(); + + return partitionKeys; + } + + private static List GetPartitionKeysTable(Table table, Granularity granularity) + { + List partitionKeysExisting = new List(); + + foreach (Partition partition in table.Partitions) + { + //Ignore partitions that don't follow the convention yyyy, yyyymm or yyyymmdd + int partitionKey; + if ( + ( (partition.Name.Length == 4 && granularity == Granularity.Yearly) || + (partition.Name.Length == 6 && granularity == Granularity.Monthly) || + (partition.Name.Length == 8 && granularity == Granularity.Daily) + ) && int.TryParse(partition.Name, out partitionKey) + ) + { + partitionKeysExisting.Add(Convert.ToString(partitionKey)); + } + } + partitionKeysExisting.Sort(); + + return partitionKeysExisting; + } + } +} + diff --git a/AsPartitionProcessing/AsPartitionProcessing/PartitioningConfiguration.cs b/AsPartitionProcessing/AsPartitionProcessing/PartitioningConfiguration.cs new file mode 100644 index 0000000..0fdfaf6 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing/PartitioningConfiguration.cs @@ -0,0 +1,85 @@ +using System; + +namespace AsPartitionProcessing +{ + /// + /// Configuration information for partitioning of a table within an AS tabular model. + /// + public class PartitioningConfiguration + { + /// + /// ID of the PartitioningConfiguration table. + /// + public int PartitioningConfigurationID { get; set; } + + /// + /// Partition granularity, which can be Yearly, Monthly or Daily. + /// + public Granularity Granularity { get; set; } + + /// + /// Count of all partitions in the rolling window. For example, a rolling window of 10 years partitioned by month would result in 120 partitions. + /// + public int NumberOfPartitionsFull { get; set; } + + /// + /// Count of “hot partitions” where the data can change. For example, it may be necessary to refresh the most recent 3 months of data every day. This only applies to the most recent partitions. + /// + public int NumberOfPartitionsForIncrementalProcess { get; set; } + + /// + /// The maximum date that needs to be accounted for in the partitioned table. Represents the upper boundary of the rolling window. + /// + public DateTime MaxDate { get; set; } + + /// + /// Name of the source table in the relational database. + /// + public string SourceTableName { get; set; } + + /// + /// Name of the source column from the table in the relational database. + /// + public string SourcePartitionColumn { get; set; } + + /// + /// Initialize partitioning configuration for partitioned table. Normally populated from a configuration database. + /// + /// Parent model. + /// ID of the PartitioningConfiguration table. + /// Partition granularity, which can be Yearly, Monthly or Daily. + /// Count of all partitions in the rolling window. For example, a rolling window of 10 years partitioned by month would result in 120 partitions. + /// Count of “hot partitions” where the data can change. For example, it may be necessary to refresh the most recent 3 months of data every day. This only applies to the most recent partitions. + /// The maximum date that needs to be accounted for in the partitioned table. Represents the upper boundary of the rolling window. + /// Name of the source table in the relational database. + /// Name of the source column from the table in the relational database. + public PartitioningConfiguration( + int partitioningConfigurationID, + Granularity granularity, + int numberOfPartitionsFull, + int numberOfPartitionsForIncrementalProcess, + DateTime maxDate, + string sourceTableName, + string sourcePartitionColumn + ) + { + PartitioningConfigurationID = partitioningConfigurationID; + Granularity = granularity; + NumberOfPartitionsFull = numberOfPartitionsFull; + NumberOfPartitionsForIncrementalProcess = numberOfPartitionsForIncrementalProcess; + MaxDate = maxDate; + SourceTableName = sourceTableName; + SourcePartitionColumn = sourcePartitionColumn; + } + } + + /// + /// Enumeration of supported partition granularities. + /// + public enum Granularity + { + Daily = 0, + Monthly = 1, + Yearly = 2 + } +} diff --git a/AsPartitionProcessing/AsPartitionProcessing/Properties/AssemblyInfo.cs b/AsPartitionProcessing/AsPartitionProcessing/Properties/AssemblyInfo.cs new file mode 100644 index 0000000..9180916 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing/Properties/AssemblyInfo.cs @@ -0,0 +1,36 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// General Information about an assembly is controlled through the following +// set of attributes. Change these attribute values to modify the information +// associated with an assembly. +[assembly: AssemblyTitle("AsPartitionProcessing")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("Microsoft Corporation")] +[assembly: AssemblyProduct("AsPartitionProcessing")] +[assembly: AssemblyCopyright("Copyright © Microsoft Corporation 2016")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// Setting ComVisible to false makes the types in this assembly not visible +// to COM components. If you need to access a type in this assembly from +// COM, set the ComVisible attribute to true on that type. +[assembly: ComVisible(false)] + +// The following GUID is for the ID of the typelib if this project is exposed to COM +[assembly: Guid("fb937281-b06d-47fb-9846-e97b0287afce")] + +// Version information for an assembly consists of the following four values: +// +// Major Version +// Minor Version +// Build Number +// Revision +// +// You can specify all the values or you can default the Build and Revision Numbers +// by using the '*' as shown below: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/AsPartitionProcessing/AsPartitionProcessing/TableConfiguration.cs b/AsPartitionProcessing/AsPartitionProcessing/TableConfiguration.cs new file mode 100644 index 0000000..97ca5c8 --- /dev/null +++ b/AsPartitionProcessing/AsPartitionProcessing/TableConfiguration.cs @@ -0,0 +1,51 @@ +using System; +using System.Collections.Generic; + +namespace AsPartitionProcessing +{ + /// + /// Configuration information for a table within an AS tabular model. + /// + public class TableConfiguration + { + /// + /// ID of the TableConfiguration table. + /// + public int TableConfigurationID { get; set; } + + /// + /// Name of the partitioned table in the tabular model. + /// + public string AnalysisServicesTable { get; set; } + + /// + /// Collection of partitioning configurations. + /// + public List PartitioningConfigurations { get; set; } + + /// + /// Initialize configuration info for table. Normally populated from a configuration database. + /// + /// Parent model. + /// ID of the TableConfiguration table. + /// Name of the partitioned table in the tabular model. + /// Collection of partitioning configurations. + public TableConfiguration( + int tableConfigurationID, + string analysisServicesTable, + List partitioningConfigurations + ) + { + TableConfigurationID = tableConfigurationID; + AnalysisServicesTable = analysisServicesTable; + PartitioningConfigurations = partitioningConfigurations; + } + + /// + /// Default constructor. + /// + public TableConfiguration() + { + } + } +} diff --git a/AsPartitionProcessing/Automated Partition Management for Analysis Services Tabular Models.docx b/AsPartitionProcessing/Automated Partition Management for Analysis Services Tabular Models.docx new file mode 100644 index 0000000..0948a60 Binary files /dev/null and b/AsPartitionProcessing/Automated Partition Management for Analysis Services Tabular Models.docx differ diff --git a/AsPartitionProcessing/Automated Partition Management for Analysis Services Tabular Models.pdf b/AsPartitionProcessing/Automated Partition Management for Analysis Services Tabular Models.pdf new file mode 100644 index 0000000..75c6e99 Binary files /dev/null and b/AsPartitionProcessing/Automated Partition Management for Analysis Services Tabular Models.pdf differ diff --git a/AsPartitionProcessing/CreateDatabaseObjects.sql b/AsPartitionProcessing/CreateDatabaseObjects.sql new file mode 100644 index 0000000..149c2cc --- /dev/null +++ b/AsPartitionProcessing/CreateDatabaseObjects.sql @@ -0,0 +1,126 @@ +CREATE DATABASE [AsPartitionProcessing] +GO +USE [AsPartitionProcessing] +GO + +CREATE TABLE [dbo].[ModelConfiguration]( + [ModelConfigurationID] [int] NOT NULL, + [AnalysisServicesServer] [varchar](255) NOT NULL, + [AnalysisServicesDatabase] [varchar](255) NOT NULL, + [InitialSetUp] [bit] NOT NULL, + [IncrementalOnline] [bit] NOT NULL, + [IncrementalParallelTables] [bit] NOT NULL, + [IntegratedAuth] [bit] NOT NULL, + CONSTRAINT [PK_ModelConfiguration] PRIMARY KEY CLUSTERED +( + [ModelConfigurationID] ASC +)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] +) ON [PRIMARY] +GO + +CREATE TABLE [dbo].[PartitioningConfiguration]( + [PartitioningConfigurationID] [int] NOT NULL, + [TableConfigurationID] [int] NOT NULL, + [Granularity] [tinyint] NOT NULL, + [NumberOfPartitionsFull] [int] NOT NULL, + [NumberOfPartitionsForIncrementalProcess] [int] NOT NULL, + [MaxDate] [date] NOT NULL, + [MinDate] AS (case when [Granularity]=(0) then dateadd(day,( -[NumberOfPartitionsFull])+(1),[MaxDate]) when [Granularity]=(1) then CONVERT([date],format(dateadd(month,( -[NumberOfPartitionsFull])+(1),[MaxDate]),'yyyy-MMM-01')) when [Granularity]=(2) then CONVERT([date],format(dateadd(year,( -[NumberOfPartitionsFull])+(1),[MaxDate]),'yyyy-01-01')) else [MaxDate] end), + [SourceTableName] [varchar](255) NOT NULL, + [SourcePartitionColumn] [varchar](255) NOT NULL, + CONSTRAINT [PK_PartitioningConfiguration] PRIMARY KEY CLUSTERED +( + [PartitioningConfigurationID] ASC +)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] +) ON [PRIMARY] +GO + +CREATE TABLE [dbo].[ProcessingLog]( + [PartitioningLogID] [int] IDENTITY(1,1) NOT NULL, + [ModelConfigurationID] [int] NOT NULL, + [ExecutionID] [char](36) NOT NULL, + [LogDateTime] [datetime] NOT NULL, + [Message] [varchar](8000) NOT NULL, + CONSTRAINT [PK_ProcessingLog] PRIMARY KEY CLUSTERED +( + [PartitioningLogID] ASC +)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] +) ON [PRIMARY] +GO + +CREATE TABLE [dbo].[TableConfiguration]( + [TableConfigurationID] [int] NOT NULL, + [ModelConfigurationID] [int] NOT NULL, + [AnalysisServicesTable] [varchar](255) NOT NULL, + CONSTRAINT [PK_TableConfiguration] PRIMARY KEY CLUSTERED +( + [TableConfigurationID] ASC +)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] +) ON [PRIMARY] +GO + +ALTER TABLE [dbo].[PartitioningConfiguration] WITH CHECK ADD CONSTRAINT [FK_PartitioningConfiguration_TableConfiguration] FOREIGN KEY([TableConfigurationID]) +REFERENCES [dbo].[TableConfiguration] ([TableConfigurationID]) +GO + +ALTER TABLE [dbo].[PartitioningConfiguration] CHECK CONSTRAINT [FK_PartitioningConfiguration_TableConfiguration] +GO + +ALTER TABLE [dbo].[ProcessingLog] WITH CHECK ADD CONSTRAINT [FK_ProcessingLog_ModelConfiguration] FOREIGN KEY([ModelConfigurationID]) +REFERENCES [dbo].[ModelConfiguration] ([ModelConfigurationID]) +GO + +ALTER TABLE [dbo].[ProcessingLog] CHECK CONSTRAINT [FK_ProcessingLog_ModelConfiguration] +GO + +ALTER TABLE [dbo].[TableConfiguration] WITH CHECK ADD CONSTRAINT [FK_TableConfiguration_ModelConfiguration] FOREIGN KEY([ModelConfigurationID]) +REFERENCES [dbo].[ModelConfiguration] ([ModelConfigurationID]) +GO + +ALTER TABLE [dbo].[TableConfiguration] CHECK CONSTRAINT [FK_TableConfiguration_ModelConfiguration] +GO + +ALTER TABLE [dbo].[PartitioningConfiguration] WITH CHECK ADD CONSTRAINT [CK_PartitioningConfiguration_Granularity] CHECK (([Granularity]=(2) OR [Granularity]=(1) OR [Granularity]=(0))) +GO + +ALTER TABLE [dbo].[PartitioningConfiguration] CHECK CONSTRAINT [CK_PartitioningConfiguration_Granularity] +GO + +ALTER TABLE [dbo].[PartitioningConfiguration] WITH CHECK ADD CONSTRAINT [CK_PartitioningConfiguration_NumberOfPartitionsForIncrementalProcess] CHECK (([NumberOfPartitionsForIncrementalProcess]<=[NumberOfPartitionsFull])) +GO + +ALTER TABLE [dbo].[PartitioningConfiguration] CHECK CONSTRAINT [CK_PartitioningConfiguration_NumberOfPartitionsForIncrementalProcess] +GO + + + + +CREATE VIEW [dbo].[vPartitioningConfiguration] +AS +SELECT m.[ModelConfigurationID] + ,m.[AnalysisServicesServer] + ,m.[AnalysisServicesDatabase] + ,m.[InitialSetUp] + ,m.[IncrementalOnline] + ,m.[IncrementalParallelTables] + ,m.[IntegratedAuth] + ,t.[TableConfigurationID] + ,t.[AnalysisServicesTable] + ,CASE + WHEN p.[TableConfigurationID] IS NULL THEN 0 + ELSE 1 + END [Partitioned] + ,p.[PartitioningConfigurationID] + ,p.[Granularity] + ,p.[NumberOfPartitionsFull] + ,p.[NumberOfPartitionsForIncrementalProcess] + ,p.[MaxDate] + ,p.[MinDate] + ,p.[SourceTableName] + ,p.[SourcePartitionColumn] + FROM [dbo].[ModelConfiguration] m +INNER JOIN [dbo].[TableConfiguration] t ON m.[ModelConfigurationID] = t.[ModelConfigurationID] +LEFT JOIN [dbo].[PartitioningConfiguration] p ON t.[TableConfigurationID] = p.[TableConfigurationID] +GO + + diff --git a/AsPartitionProcessing/README.md b/AsPartitionProcessing/README.md new file mode 100644 index 0000000..e902756 --- /dev/null +++ b/AsPartitionProcessing/README.md @@ -0,0 +1,8 @@ +Microsoft BI technical whitepaper: [Automated Partition Management for Analysis Services Tabular Models](Automated%20Partition%20Management%20for%20Analysis%20Services%20Tabular%20Models.pdf) + +Analysis Services tabular models can store data in a highly-compressed, in-memory cache for optimized query performance. This provides fast user interactivity over large data sets. Large datasets normally require table partitioning to accelerate and optimize the data-load process. Partitioning enables incremental loads, increases parallelization, and reduces memory consumption. The Tabular Object Model (TOM) serves as an API to create and manage partitions. Model Compatibility Level 1200 or above is required. + +The AsPartitionProcessing TOM code sample is +* Intended to be generic and configuration driven requiring minimal code changes. +* Works for both Azure Analysis Services and SQL Server Analysis Services tabular models. +* Can be leveraged in many ways including from an SSIS script task, Azure Functions and others. diff --git a/AsPartitionProcessing/SampleConfiguration.sql b/AsPartitionProcessing/SampleConfiguration.sql new file mode 100644 index 0000000..0633804 --- /dev/null +++ b/AsPartitionProcessing/SampleConfiguration.sql @@ -0,0 +1,44 @@ +INSERT INTO [dbo].[ModelConfiguration] +VALUES( + 1 --[ModelConfigurationID] + ,'localhost' --[AnalysisServicesServer] + ,'AdventureWorks' --[AnalysisServicesDatabase] + ,1 --[InitialSetUp] + ,1 --[IncrementalOnline] + ,1 --[IncrementalParallelTables] + ,1 --[IntegratedAuth] +); + +INSERT INTO [dbo].[TableConfiguration] +VALUES( + 1 --[TableConfigurationID] + ,1 --[ModelConfigurationID] + ,'Internet Sales' --[AnalysisServicesTable] +), +( + 2 --[TableConfigurationID] + ,1 --[ModelConfigurationID] + ,'Reseller Sales' --[AnalysisServicesTable] +); + +INSERT INTO [dbo].[PartitioningConfiguration] +VALUES( + 1 --[PartitioningConfigurationID] + ,1 --[TableConfigurationID] + ,1 --[Granularity] 1=Monthly + ,12 --[NumberOfPartitionsFull] + ,3 --[NumberOfPartitionsForIncrementalProcess] + ,'2012-12-01' --[MaxDate] + ,'[dbo].[FactInternetSales]'--[SourceTableName] + ,'OrderDateKey' --[SourcePartitionColumn] +), +( + 2 --[PartitioningConfigurationID] + ,2 --[TableConfigurationID] + ,2 --[Granularity] 2=Yearly + ,3 --[NumberOfPartitionsFull] + ,1 --[NumberOfPartitionsForIncrementalProcess] + ,'2012-12-01' --[MaxDate] + ,'[dbo].[FactResellerSales]'--[SourceTableName] + ,'OrderDateKey' --[SourcePartitionColumn] +); diff --git a/AsPerfMon/ASPerfMon.sln b/AsPerfMon/ASPerfMon.sln new file mode 100644 index 0000000..7894e48 --- /dev/null +++ b/AsPerfMon/ASPerfMon.sln @@ -0,0 +1,22 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio 14 +VisualStudioVersion = 14.0.25420.1 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ASPerfMon", "ASPerfMon\ASPerfMon.csproj", "{B2442578-2C46-47D2-B5FB-57096C234552}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {B2442578-2C46-47D2-B5FB-57096C234552}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {B2442578-2C46-47D2-B5FB-57096C234552}.Debug|Any CPU.Build.0 = Debug|Any CPU + {B2442578-2C46-47D2-B5FB-57096C234552}.Release|Any CPU.ActiveCfg = Release|Any CPU + {B2442578-2C46-47D2-B5FB-57096C234552}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/AsPerfMon/AsPerfMon.png b/AsPerfMon/AsPerfMon.png new file mode 100644 index 0000000..dbc2171 Binary files /dev/null and b/AsPerfMon/AsPerfMon.png differ diff --git a/AsPerfMon/AsPerfMon/ASPerfMon.Designer.cs b/AsPerfMon/AsPerfMon/ASPerfMon.Designer.cs new file mode 100644 index 0000000..daa17e8 --- /dev/null +++ b/AsPerfMon/AsPerfMon/ASPerfMon.Designer.cs @@ -0,0 +1,94 @@ +namespace ASPerfMon +{ + partial class ASPerfMon + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + System.Windows.Forms.DataVisualization.Charting.ChartArea chartArea1 = new System.Windows.Forms.DataVisualization.Charting.ChartArea(); + System.Windows.Forms.DataVisualization.Charting.Legend legend1 = new System.Windows.Forms.DataVisualization.Charting.Legend(); + System.Windows.Forms.DataVisualization.Charting.Series series1 = new System.Windows.Forms.DataVisualization.Charting.Series(); + System.ComponentModel.ComponentResourceManager resources = new System.ComponentModel.ComponentResourceManager(typeof(ASPerfMon)); + this.chartControl = new System.Windows.Forms.DataVisualization.Charting.Chart(); + this.btnConnect = new System.Windows.Forms.Button(); + ((System.ComponentModel.ISupportInitialize)(this.chartControl)).BeginInit(); + this.SuspendLayout(); + // + // chartControl + // + chartArea1.Name = "ChartArea1"; + this.chartControl.ChartAreas.Add(chartArea1); + this.chartControl.Dock = System.Windows.Forms.DockStyle.Fill; + legend1.Name = "Legend1"; + this.chartControl.Legends.Add(legend1); + this.chartControl.Location = new System.Drawing.Point(0, 0); + this.chartControl.Name = "chartControl"; + series1.ChartArea = "ChartArea1"; + series1.Legend = "Legend1"; + series1.Name = "Series1"; + this.chartControl.Series.Add(series1); + this.chartControl.Size = new System.Drawing.Size(948, 645); + this.chartControl.TabIndex = 0; + this.chartControl.Text = "chart1"; + this.chartControl.GetToolTipText += new System.EventHandler(this.chartControl_GetToolTipText); + // + // btnConnect + // + this.btnConnect.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right))); + this.btnConnect.Location = new System.Drawing.Point(788, 567); + this.btnConnect.Name = "btnConnect"; + this.btnConnect.Size = new System.Drawing.Size(127, 44); + this.btnConnect.TabIndex = 6; + this.btnConnect.Text = "Connect"; + this.btnConnect.UseVisualStyleBackColor = true; + this.btnConnect.Click += new System.EventHandler(this.btnConnect_Click); + // + // ASPerfMon + // + this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); + this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; + this.BackColor = System.Drawing.Color.White; + this.ClientSize = new System.Drawing.Size(948, 645); + this.Controls.Add(this.btnConnect); + this.Controls.Add(this.chartControl); + this.Icon = ((System.Drawing.Icon)(resources.GetObject("$this.Icon"))); + this.Name = "ASPerfMon"; + this.Text = "AS PerfMon"; + this.FormClosing += new System.Windows.Forms.FormClosingEventHandler(this.ASPerfMon_FormClosing); + this.Load += new System.EventHandler(this.ASPerfMon_Load); + this.Shown += new System.EventHandler(this.ASPerfMon_Shown); + ((System.ComponentModel.ISupportInitialize)(this.chartControl)).EndInit(); + this.ResumeLayout(false); + + } + + #endregion + + private System.Windows.Forms.DataVisualization.Charting.Chart chartControl; + private System.Windows.Forms.Button btnConnect; + } +} + diff --git a/AsPerfMon/AsPerfMon/ASPerfMon.cs b/AsPerfMon/AsPerfMon/ASPerfMon.cs new file mode 100644 index 0000000..f92a8f3 --- /dev/null +++ b/AsPerfMon/AsPerfMon/ASPerfMon.cs @@ -0,0 +1,394 @@ +using System; +using System.Collections; +using System.Collections.Generic; +using System.Windows.Forms; +using System.Windows.Forms.DataVisualization.Charting; +using System.Timers; +using Microsoft.AnalysisServices; +using Tom = Microsoft.AnalysisServices.Tabular; +using System.Xml; +using System.Drawing; + +namespace ASPerfMon +{ + public partial class ASPerfMon : Form + { + public ASPerfMon() + { + InitializeComponent(); + } + + private Tom.Server _server = new Tom.Server(); + private System.Timers.Timer _timer; + private const int _smallestFont = 12; + private string _serverConnectionString; + private DateTime _connectionTime; + + //-------------------------------------------------- + //120 X axis markers, one for each array item. + //Each item holds a dictionary with lookup key of series name (e.g. database name), which returns a SeriesPoint object. + Dictionary[] _seriesData = new Dictionary[120]; + + class SeriesPoint + { + public string XAxisLabel; + public long MemoryUsedBytes; + public long MemoryUsedMegabytes + { + get + { + return MemoryUsedBytes / 1024 / 1024; + } + } + + public SeriesPoint(string xAxisCategoryName) + { + this.XAxisLabel = xAxisCategoryName; + this.MemoryUsedBytes = 0; + } + } + + private void ASPerfMon_Load(object sender, EventArgs e) + { + InitializeChart(false); + } + + private void InitializeChart(bool withSampleSeries) + { + chartControl.ChartAreas[0].AxisX.MajorGrid.Enabled = false; + chartControl.ChartAreas[0].AxisX.Interval = 5; + chartControl.ChartAreas[0].AxisY.IsMarksNextToAxis = true; + chartControl.ChartAreas[0].AxisY.LabelStyle.Format = "{0:n0}"; + chartControl.ChartAreas[0].AxisY.Title = "Memory Usage MB"; + chartControl.Palette = ChartColorPalette.Pastel; + chartControl.ChartAreas[0].AxisY.TitleFont = new Font(Font.FontFamily, _smallestFont + 2); + chartControl.Legends[0].Font = new Font(Font.FontFamily, _smallestFont); + chartControl.Legends[0].LegendItemOrder = LegendItemOrder.ReversedSeriesOrder; + + //initialize the chart with blanks + Dictionary pointsSample; + if (withSampleSeries) + pointsSample = GetNewXAxisMarkerPointsFromAs(); + else + { + pointsSample = new Dictionary(); + } + + chartControl.Series.Clear(); + if (withSampleSeries) + { + for (int i = _seriesData.Length - 1; i >= 0; i--) + { + foreach (KeyValuePair entry in pointsSample)//to get series + { + entry.Value.XAxisLabel = " "; + entry.Value.MemoryUsedBytes = 0; + + //add the series if not there yet + if (chartControl.Series.FindByName(entry.Key) == null) + { + Series series = new Series(entry.Key); + chartControl.Series.Add(series); + } + chartControl.Series[entry.Key].Points.AddXY(" ", 0); + } + _seriesData[i] = pointsSample; + } + PaintChart(); + } + else + { + chartControl.Series.Add(""); + for (int i = 0; i < _seriesData.Length; i++) + { + chartControl.Series[0].Points.AddXY(" ", 0); + } + chartControl.Invalidate(); + } + + _timer = new System.Timers.Timer(Settings.Default.SampleInterval); + _timer.Elapsed += OnTimedEvent; + _timer.AutoReset = true; + } + + private void PaintChart() + { + //set dynamic scale + long maxValue = 0; + for (int i = _seriesData.Length - 1; i >= 0; i--) + { + long pointsStack = 0; + foreach (SeriesPoint point in _seriesData[i].Values) + { + pointsStack += Math.Abs(point.MemoryUsedMegabytes); + } + + if (pointsStack > maxValue) + maxValue = pointsStack; + } + chartControl.ChartAreas[0].AxisY.IsStartedFromZero = true; + chartControl.ChartAreas[0].AxisY.Minimum = double.NaN; + chartControl.ChartAreas[0].AxisY.Maximum = double.NaN; + chartControl.ChartAreas[0].RecalculateAxesScale(); + chartControl.Invalidate(); + } + + delegate void SetTimerCallback(Object source, ElapsedEventArgs e); + private void OnTimedEvent(Object source, ElapsedEventArgs e) + { + try + { + if (chartControl.InvokeRequired) + { + SetTimerCallback callback = new SetTimerCallback(OnTimedEvent); + //todo safer invoke look up bism + try + { + Invoke(callback, new object[] { source, e }); + } + catch { } + } + else + { + //Todo delete this once http stability fix is done + if ((DateTime.Now - _connectionTime).TotalMinutes > 8) + { + _server.Disconnect(); + _server.Connect(_serverConnectionString); + _connectionTime = DateTime.Now; + } + + _seriesData[0] = GetNewXAxisMarkerPointsFromAs(); + + //rebind + chartControl.Series.Clear(); + + //for each X axis marker + for (int i = _seriesData.Length - 1; i > 0; i--) + { + //push back one category + _seriesData[i] = _seriesData[i - 1]; + + //foreach series for the X axis marker we are populating: ... + foreach (KeyValuePair entry in _seriesData[i]) + { + //add the series if not there yet + if (chartControl.Series.FindByName(entry.Key) == null) + { + Series series = new Series(entry.Key); + series.ChartType = SeriesChartType.StackedColumn; + chartControl.Series.Add(series); + } + + //add the data point for the series + DataPoint point = new DataPoint(); + point.SetValueXY(entry.Value.XAxisLabel, entry.Value.MemoryUsedMegabytes); + point.ToolTip = string.Format($"{entry.Value.XAxisLabel} - {entry.Key}: {string.Format("{0:#,###0}", entry.Value.MemoryUsedMegabytes)} MB"); + chartControl.Series[entry.Key].Points.Add(point); + } + } + PaintChart(); + } + } + catch (Exception exc) + { + //Workaround for timeout over HTTP. Try to reconnect - todo delete + try + { + System.Diagnostics.Debug.WriteLine($"Exception occurred at {DateTime.Now}: {exc.Message}"); + _server.Disconnect(); + _server.Connect(_serverConnectionString); + _connectionTime = DateTime.Now; + } + catch + { + _timer.Enabled = false; + MessageBox.Show($"Error: {exc.Message}", "AS PerfMon", MessageBoxButtons.OK, MessageBoxIcon.Error); + } + } + } + + private Dictionary GetNewXAxisMarkerPointsFromAs() + { + Dictionary points = new Dictionary(); + string xAxisLabel = DateTime.Now.ToString("hh:mm:ss tt"); + string commandStatement = String.Format("SELECT [OBJECT_PARENT_PATH], [OBJECT_MEMORY_NONSHRINKABLE] FROM $SYSTEM.DISCOVER_OBJECT_MEMORY_USAGE"); + XmlNodeList rows = ExecuteXmlaCommand(_server, commandStatement); + + foreach (XmlNode row in rows) + { + long result, label; + if (long.TryParse(row.LastChild.InnerText, out result) && result > 0) + { + string objectName = ""; + string[] pathMembers = row.ChildNodes[0].InnerText.Split('.'); + + if (pathMembers.Length > 2 && _server.Databases.ContainsName(pathMembers[2])) + { + //Database name identified + objectName = pathMembers[2]; + } + else + { + string firstMember = row.ChildNodes[0].InnerText; + + //Ignore if number or blank. Assuming this is a double counted, shared allocation. + if (!long.TryParse(firstMember, out label) && firstMember != "") + { + objectName = firstMember; + } + } + + if (objectName != "" && objectName != "Global") //todo: delete global condition + { + if (!points.ContainsKey(objectName)) + points.Add(objectName, new SeriesPoint(xAxisLabel)); + + points[objectName].MemoryUsedBytes += Math.Abs(result); + } + } + else if (result > 0) + { + System.Diagnostics.Debug.WriteLine("We have a problem parsing"); + } + } + return points; + } + + public static XmlNodeList ExecuteXmlaCommand(Microsoft.AnalysisServices.Core.Server amoServer, string commandStatement) + { + XmlWriter xmlWriter = amoServer.StartXmlaRequest(XmlaRequestType.Undefined); + WriteSoapEnvelopeWithCommandStatement(xmlWriter, amoServer.SessionID, commandStatement); + System.Xml.XmlReader xmlReader = amoServer.EndXmlaRequest(); + xmlReader.MoveToContent(); + string fullEnvelopeResponseFromServer = xmlReader.ReadOuterXml(); + xmlReader.Close(); + + XmlDocument documentResponse = new XmlDocument(); + documentResponse.LoadXml(fullEnvelopeResponseFromServer); + XmlNamespaceManager nsmgr = new XmlNamespaceManager(documentResponse.NameTable); + nsmgr.AddNamespace("myns1", "urn:schemas-microsoft-com:xml-analysis"); + nsmgr.AddNamespace("myns2", "urn:schemas-microsoft-com:xml-analysis:rowset"); + XmlNodeList rows = documentResponse.SelectNodes("//myns1:ExecuteResponse/myns1:return/myns2:root/myns2:row", nsmgr); + return rows; + } + + public static void WriteSoapEnvelopeWithCommandStatement(XmlWriter xmlWriter, string sessionId, string commandStatement) + { + //-------------------------------------------------------------------------------- + // This is a sample of the XMLA request we'll write: + // + // + //
+ // + //
+ // + // + // + // + // ... + // + // + // + // + // + //
+ //-------------------------------------------------------------------------------- + xmlWriter.WriteStartElement("Envelope", "http://schemas.xmlsoap.org/soap/envelope/"); + xmlWriter.WriteStartElement("Header"); + if (sessionId != null) + { + xmlWriter.WriteStartElement("Session", "urn:schemas-microsoft-com:xml-analysis"); + xmlWriter.WriteAttributeString("soap", "mustUnderstand", "http://schemas.xmlsoap.org/soap/envelope/", "1"); + xmlWriter.WriteAttributeString("SessionId", sessionId); + xmlWriter.WriteEndElement(); // + } + xmlWriter.WriteEndElement(); // + xmlWriter.WriteStartElement("Body"); + xmlWriter.WriteStartElement("Execute", "urn:schemas-microsoft-com:xml-analysis"); + xmlWriter.WriteStartElement("Command"); + xmlWriter.WriteElementString("Statement", commandStatement); + xmlWriter.WriteEndElement(); // + xmlWriter.WriteStartElement("Properties"); + xmlWriter.WriteEndElement(); // + xmlWriter.WriteEndElement(); // + xmlWriter.WriteEndElement(); // + xmlWriter.WriteEndElement(); // + } + + private void btnConnect_Click(object sender, EventArgs e) + { + Connect(); + } + + private void Connect() + { + try + { + Connect connForm = new Connect(); + connForm.StartPosition = FormStartPosition.CenterParent; + connForm.ShowDialog(); + + if (connForm.DialogResult == DialogResult.OK) + { + _timer.Enabled = false; + + if (connForm.IntegratedAuth) + _serverConnectionString = $"Provider=MSOLAP;Data Source={connForm.ServerName};"; + else + _serverConnectionString = $"Provider=MSOLAP;Data Source={connForm.ServerName};User ID={connForm.UserName};Password={connForm.Passwrod};Persist Security Info=True;Impersonation Level=Impersonate;"; + + _server = new Tom.Server(); + _server.Connect(_serverConnectionString); + _connectionTime = DateTime.Now; + if (_server.ServerProperties.Count == 0) + { + throw new ConnectionException("User is not AS admin."); + } + + chartControl.Titles.Clear(); + chartControl.Titles.Add(connForm.ServerName); + chartControl.Titles[0].Font = new Font(Font.FontFamily, _smallestFont + 4); + + InitializeChart(true); + _timer.Interval = connForm.SampleInterval; + _timer.Enabled = true; + + Settings.Default.ServerName = connForm.ServerName; + Settings.Default.UserName = connForm.UserName; + Settings.Default.SampleInterval = connForm.SampleInterval; + Settings.Default.IntegratedAuth = connForm.IntegratedAuth; + Settings.Default.Save(); + } + } + catch (Exception exc) + { + MessageBox.Show($"Cannot connect.\n{exc.Message}", "AS PerfMon", MessageBoxButtons.OK, MessageBoxIcon.Error); + } + } + + private void ASPerfMon_FormClosing(object sender, FormClosingEventArgs e) + { + Disconnect(); + } + + private void Disconnect() + { + try + { + if (_server != null) _server.Disconnect(); + } + catch { } + } + + private void chartControl_GetToolTipText(object sender, ToolTipEventArgs e) + { + //Event handler has to be hooked up in order to display tooltip (!) + } + + private void ASPerfMon_Shown(object sender, EventArgs e) + { + Connect(); + } + } +} diff --git a/AsPerfMon/AsPerfMon/ASPerfMon.csproj b/AsPerfMon/AsPerfMon/ASPerfMon.csproj new file mode 100644 index 0000000..b2d2a49 --- /dev/null +++ b/AsPerfMon/AsPerfMon/ASPerfMon.csproj @@ -0,0 +1,160 @@ + + + + + Debug + AnyCPU + {B2442578-2C46-47D2-B5FB-57096C234552} + WinExe + Properties + ASPerfMon + ASPerfMon + v4.5.2 + 512 + true + publish\ + true + Disk + false + Foreground + 7 + Days + false + false + true + 0 + 1.0.0.%2a + false + false + true + + + AnyCPU + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + + + AnyCPU + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + + + Chart.ico + + + + False + ..\..\..\..\..\..\..\Program Files (x86)\Microsoft SQL Server\130\SDK\Assemblies\Microsoft.AnalysisServices.DLL + + + False + ..\..\..\..\..\..\..\Program Files (x86)\Microsoft SQL Server\130\SDK\Assemblies\Microsoft.AnalysisServices.Core.DLL + + + False + ..\..\..\..\..\..\..\Program Files (x86)\Microsoft SQL Server\130\SDK\Assemblies\Microsoft.AnalysisServices.Tabular.DLL + + + False + ..\..\..\..\..\..\..\Program Files (x86)\Microsoft SQL Server\130\SDK\Assemblies\Microsoft.AnalysisServices.Tabular.Json.DLL + + + + + + + + + + + + + + + + + Form + + + ASPerfMon.cs + + + Form + + + Connect.cs + + + + + True + True + Settings.settings + + + ASPerfMon.cs + + + Connect.cs + + + ResXFileCodeGenerator + Resources.Designer.cs + Designer + + + True + Resources.resx + True + + + + SettingsSingleFileGenerator + Settings.Designer.cs + + + True + Settings.settings + True + + + SettingsSingleFileGenerator + Settings.Designer.cs + + + + + + + + + + + False + Microsoft .NET Framework 4.5.2 %28x86 and x64%29 + true + + + False + .NET Framework 3.5 SP1 + false + + + + + \ No newline at end of file diff --git a/AsPerfMon/AsPerfMon/ASPerfMon.resx b/AsPerfMon/AsPerfMon/ASPerfMon.resx new file mode 100644 index 0000000..0e3ed82 --- /dev/null +++ b/AsPerfMon/AsPerfMon/ASPerfMon.resx @@ -0,0 +1,2937 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + + + 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 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d513d3edd3d3nQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3ed + d3d3nXd3d513d3edAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHd3d513d3edd3d3nXd3d50AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d513d3edd3d3nQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eHV4eHgnAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB3d3edd3d3nXd3d513d3edAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHd3d513d3edd3d3nXd3d50AAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d513d3ed + d3d3nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB3d3edd3d3nXd3d513d3edAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ14eHh1eHh4JwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHd3d513d3edd3d3nXd3d50AAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + d3d3nXd3d513d3edd3d3nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB3d3edd3d3nXd3d513d3edAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHd3d513d3edd3d3nXd3d50AAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHid + eHh4dXh4eCcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAd3d3nXd3d513d3edd3d3nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3edd3d3nXd3d513d3edAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHd3d513d3ed + d3d3nXd3d50AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAd3d3nXd3d513d3edd3d3nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eHV4eHgnAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB4eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ13d3fZd3d32Xd3d9l3d3fZ + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXd3d9l3d3fZd3d32Xd3d9l4eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHidd3d32Xd3d9l3d3fZd3d32Xh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ13d3fZd3d32Xd3d9l3d3fZ + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHh1eHh4JwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXd3d9l3d3fZd3d32Xd3d9l4eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHidd3d32Xd3d9l3d3fZd3d32Xh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ13d3fZ + d3d32Xd3d9l3d3fZeHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXd3d9l3d3fZd3d32Xd3d9l4eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4dXh4eCcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHidd3d32Xd3d9l3d3fZ + d3d32Xh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ13d3fZd3d32Xd3d9l3d3fZeHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXd3d9l3d3fZd3d32Xd3d9l4eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHidd3d32Xd3d9l3d3fZ + d3d32Xh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHh1eHh4JwAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ13d3fZd3d32Xd3d9l3d3fZeHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXd3d9l3d3fZd3d32Xd3d9l4eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + d3d32Xd3d9l3d3fZd3d32Xh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ13d3fZd3d32Xd3d9l3d3fZeHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHh1 + eHh4JwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHh1eHh4JwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHid + eHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ14eHh1eHh4JwAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ14eHh1eHh4JwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHid + eHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHh1eHh4JwAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHid + eHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADvZwk972cJzO9nCevvZwmu72cJbu9nCS/vZwkB + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAO9nCdPvZwn/72cJ/+9nCf/vZwn/72cJ/+9nCezvZwmu72cJbu9oCy7vaQwBAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA72cJzO9nCf/vZwn/72cJ/+9nCf/vZwn/ + 72cJ/+9nCf/vZwn/72gL/+9pDezvag6u72sQbu9sEi/vbRMBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAADvZwk572cJ3O9nCf/vZwn/72cJ/+9nCf/vZwn/72cJ/+9oCv/vaQz/72oO/+9rD//wbBH/ + 8G0S//BuE+zwbxWu8HAXbvBxGC/wchoBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHid + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADvZwkB72cJLu9nCW7vZwmu + 72cJ7O9nCf/vZwr/72gL/+9pDf/vag//8GsQ//BsEv/wbRP/8G4U//BwFv/wcRj/8HIZ//BzG+zxdB2u + 8HUebvB2IC/xdyIBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADvZwkB72cJLu9oCm7vaQyu72oO7O9rEP/wbBH/ + 8G0T//BuFP/wbxX/8HAX//BxGf/wchr/8XMc//F0Hv/xdR//8XYh//F3IuzxeCSu8XkmbvF6Jy/xfCkB + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3edd3d3nXd3d513d3edeHh42Xh4eNl4eHjZ + eHh42QAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAADvaQ0B72sPLu9sEW7wbhOu8G8V7PBwFv/wcRj/8HIa//BzG//xdB3/ + 8XUf//F2IP/xdyL/8Xgj//F5Jf/xeif/8nso//J8KuzyfSyu8n4tbvJ/Ly/ygDEBAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHd3d513d3edd3d3nXd3d514eHjZeHh42Xh4eNl4eHjZAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAADvbRMB8G8WLvBwF27wchuu8XMc7PF0Hv/xdR//8Xch//F4I//xeST/8Xom//F7KP/yfCn/ + 8n0r//J+Lf/yfy7/8oAw//KBMuzygjOu8oM1bvKENy/yhTgBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d513d3edd3d3nXh4eNl4eHjZ + eHh42Xh4eNkAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADwchoB + 8HQdLvB1H27xdyKt8Xgk7PF5Jf/xeif/8nsp//J8Kv/yfSz/8n4u//J/L//ygDH/8oEz//KCNP/zgzb/ + 84U4//OGOebzhzto84c8AQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB3d3edd3d3nXd3d513d3edeHh42Xh4eNl4eHjZeHh42QAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADxdyIB8XklLvF6J27yfCqt + 8n0r7PJ+Lf/yfy//8oAw//KBMv/ygjT/84M1//OEN//zhTn/84Y6//OHPP/ziD6884k+IAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHid + eHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADxfCoB8X0sLvF/Lm7ygDGt8oIz6/KDNP/zhDb/ + 84U4//OGOf/zhzv/84g9//OJPv/zikDy84tBaPOLQgEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAADygDEB8oI0LvKDNm3zhTmt84Y68/OHPP/ziD7/84k///OKQf/0i0P/ + 9IxEvPONRSAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADDALg4 + wwC4z8MAuOHDALiFwwC4GQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAADyhjof84g9vPOJP//zikD/9ItC//SMRP/0jUX/9I5H8vSPSGj0j0kBAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMMAuNXDALj/wwC4/8MAuP/DALj5wwC4ocMAuDAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADzhzwB84k/Z/OLQfL0jEP/ + 9I1F//SORv/0j0j/9JBJ//SRS7z0kUwgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + wwC408MAuP/DALj/wwC4/8MAuP/DALj/wwC4/sMAuL7DALhMwwC4AQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA84pBH/SMRLz0jUb/9I5H//SPSf/0kEr/9JFM//SSTvL0k09o + 9JRQAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADDALg0wwC46sMAuP/DALj/wwC4/8MAuP/DALj/ + wwC4/8MAuP/DALjYwwC4aMMAuAoAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + 84xDAfOORmj0j0jy9JBK//SRS//0kk3/9ZNP//WUUP/1lVK89JVTIAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAADDALgKwwC4acMAuNjDALj/wwC4/8MAuP/DALj/wwC4/8MAuP/DALj/wwC47MMAuIXCALgZ + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAPSPSB/0kEu89JFM//SSTv/1lFD/ + 9ZVR//WWU//1l1Xy9ZhWaPWYVwEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAA + 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 + 96x2cPeteEX3rnobAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHd3d513d3edd3d3nXd3d514eHjZeHh42Xh4eNl4eHjZAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAClCbYKogu2aaAMttmfDLb/ngy2/5wNtv+bDbb/mg62/5kOtv+YDrb/ + lw+16pUPtTsAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d513d3ed + d3d3nXh4eNl4eHjZeHh42Xh4eNkAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + ogq2AZ8Mtk2cDba/mg22/5kOtv+YDrb/lw+1/5YPtf+UELX/kxC17pEQtRMAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACaDbUxlw+2opYPtfmVD7X/ + kxC1/5IQtf+REbX/kBG1kAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAlQ+1GpMQtZ6REbX/kBG1/48Rtf+OErX5jRK1JAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + kRC1B48Rtd6OErX/jRK1/4wTtf+KE7WsAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAjRK1V4wStf+LE7X/iRO1/4gTtf6HE7Q7 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHid + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAACLErQBihO1yIkTtf+HE7X/hhO1/4UUtMgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACHE7Q8hhO1/oUUtP+EFLT/ + gxW0/4IVtFcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHid + eHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAACEFLStgxS0/4IVtP+BFbT/fxa03n8VtAcAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIIUtCSBFbT5 + gBa0/34WtP99FrT/fBa0dAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHid + eHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAH4WtJB+FrT/fBe0/3sXtP96GLTueRezEwAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + fBazE3sXtO56F7T/eRi0/3gYtP93GLOQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHid + eHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeRizdHgYtP93GbT/dhm0/3QZtPl0GbMk + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB3GLMHdhm03nUZtP9zGrT/chqz/3Ebs6wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABzGrNXcxqz/3Ebs/9wG7P/ + bxuz/m4bszsAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHEaswFxG7PIbxuz/24cs/9tHLP/bByzyAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAG4bszxtHLP+ + bByz/2sds/9qHbP/aB2zVwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGsds61qHbP/aR6z/2ces/9mHrPeZh6yBwAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHd3d513d3ed + d3d3nXd3d514eHjZeHh42Xh4eNl4eHjZAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + aR2yJGges/lmHrP/ZR+z/2Qfs/9jH7J0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d513d3edd3d3nXh4eNl4eHjZeHh42Xh4eNkAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAZR6ykGQfs/9jH7P/YiCz/2Egsu5gILIS + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3ed + d3d3nXd3d513d3edeHh42Xh4eNl4eHjZeHh42QAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAABjH7ITYiCz7mEgsv9gIbL/XyGy/10hspAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHd3d513d3edd3d3nXd3d514eHjZeHh42Xh4eNl4eHjZ + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABgILJ0XyGy/14hsv9cIrL/ + WyKy+VsisiQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAF4hsgddIrLeXCKy/1oisv9ZI7L/WCOyrAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHid + eHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFoisldZI7L/ + WCOy/1cksv9WJLL+VSSxOwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAWCKxAVcjsshWJLL/VSSy/1Qlsv9SJbLHAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHid + eHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + VSSxPFQlsv5TJbL/UiWy/1Amsv9PJrFXAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUiWyrVEmsv9PJrH/Tiex/00nsd5MJ7EH + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHid + eHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAABPJrEkTyax+U0nsf9MJ7H/Syix/0oosXQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABMJ7GQSyix/0oosf9JKLH/ + SCmx7kcosRIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAEonsRNJKLHuSCmx/0cpsf9FKrH/RCqxkAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEcpsXRGKbH/ + RSqx/0Mqsf9CK7H5QSqwJAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAARSmwB0Qqsd5CK7H/QSux/0Arsf8/LLGsAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + QSuwV0Arsf8/LLH/Piyw/z0tsP48LLA7AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/K7ABPiyxyD0ssP88LbD/Oy2w/zkusMcAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAA8LLA7Oy2w/jousP84LrD/Ny6w/zYusFcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA5LrCsOC6w/zYvsP81L7D/ + NDCw3jIvrwcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHid + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAADYusCQ1L7D5NC+w/zMwsP8yMLD/MDGwrC4xr0MsMq8DAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADMvr5AyMLD/ + MTGw/zAxsP8uMbD/LTKw/ywyr+orM6+YKDOvQyU0rwMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3edd3d3nXd3d513d3edeHh42Xh4eNl4eHjZ + eHh42QAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMjCvEzAxsO4vMbD/LjKw/ywysP8rM6//KjOv/ykzr/8nNK// + JjSv6iU1r5giNa5DHzauAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHd3d513d3edd3d3nXd3d514eHjZeHh42Xh4eNl4eHjZAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + LzGvNS0ysOErMq//KjOv/ykzr/8oNK//JjSv/yU1r/8kNa//IzWv/yI2r/8gNq/qHzevmBw3rkMaOK4D + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d513d3edd3d3nXh4eNl4eHjZ + eHh42Xh4eNkAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAALDGvAysyr0MoNK+YJzSv6iY0r/8kNa// + IzWv/yI2r/8hNq//IDev/x43r/8dN6//HDiv/xs4r+oZOa6YFjmuQxQ6rgMAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB3d3edd3d3nXd3d513d3edeHh42Xh4eNl4eHjZeHh42QAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAnM68DJTSvQyI2r5ghNq/qIDav/x83r/8dN6//HDiv/xs4r/8aOa7/ + GDmu/xc5rv8WOq7/FTqu6hQ7rpgRO61DDzytAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHid + eHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAACI1rgMgNq5DHDivmBs4r+oaOK7/GTmu/xg5rv8WOq7/FTqu/xQ6rv8TO67/Ejuu/xE8rv8QPK7q + Dz2umAw9rUMJPq0DAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHDeuAxo4rkMXOq6Y + FTqu6hQ6rv8TO67/Ejuu/xI8rv8QPK7/Dzyu/w49rv8NPa7/Cz6u/wo+ruoJP62YBj+tQwVArQMAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAWOa4DFDquQxI8rpgRPK7qDzyu/w49rv8NPa7/ + DD6u/ws+rv8JPq3/CD+t/wc/rf8GQK3/BECt4QNArTUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAABE7rgMPPK1DDD2umAs+ruoKPq7/CD+t/wc/rf8GQK3/BUCt/wRArf8CQa3/ + AUGtzgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + Cz2tAwk+rUMGP62YBUCt6gRArf8DQa3/AUGt/wBCrf8AQq3UAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGP60DBECtQwFBrZgAQq3l + AEKtygFBrTsAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHid + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHid + eHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHid + eHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHid + eHh4nXh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4dXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHh1 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHgneHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eCcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB4eHh1eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHh1 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eCd4eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eCcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eHV4eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHh1 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4J3h4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eCcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4dXh4eJ14eHideHh4nXh4eJ14eHh1 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB4eHgneHh4nXh4eJ14eHideHh4nXh4eCcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHh1eHh4nXh4eJ14eHh1 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eCd4eHideHh4nXh4eCcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eHV4eHh1 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4J3h4eCcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA//////////////////////////////// + //////////////////////////////////////////////////////////8P//D//w//8P/z//////// + D//w//8P//D/8P///////w//8P//D//w//A///////8P//D//w//8P/wD///AAAAAAAAAAAAAAAAAAP/ + /wAAAAAAAAAAAAAAAAAA//8AAAAAAAAAAAAAAAAAAP//AAAAAAAAAAAAAAAAAAP//w////////////// + //AP//8P///////////////wP///D///////////////8P///w////////////////P///8P//////// + ////////////D////////////////////w////////////////////8P////////////////////D/// + /////////////////w////////////////////8P/Af/////////////////D/wAf/////////////// + /w/8AAf///////////////8P/AAAf///////////////D/4AAAf//////////////w//4AAAf/////// + //////AP//4AAAf////////////wD///4AAAf///////////8A////4AAB////////////AP////4AAP + ////////////D/////4AA////////////w//////4AH///////////8P/B////4Af///////////D/wH + ////AD///////////w/8AP///8AP//////////8P/AA////gB///////////D/4AD///+AH///////// + /w//gAP///wA//////////8P//AAf///AD//////////D//8AB///4Af/////////w///wAH///gB/// + wD////8P///AAf//8AP/8AA/////D///+AA///wA/AAAP////w////4AD//+AAAAAD////8P////gAP/ + /4AAAAD/////D////+AA///AAAA/////8A/////8AB//8AAP//////AP/////wAH//gD///////wD/// + ///AA///////////8A//////8AH///////////8P//////4B////////////D///////gP////////// + /w///////8D///////////8P///////gf///////////D///////4H///////////w////////A///// + //////8P///////4H///////////D///////+B///////////w////////wP//////////8P///////8 + D///////////D////////gf//////////w////////4H//////////8P////////A///////////D/// + /////wP//////////w////////+B//////////8P////////wP/////////wD////////8D///////// + 8A/////////gf/////////AP////////4H/////////wD/////////A//////////w/////////wP/// + //////8P////////+B//////////D/////////gf/////////w/////////8D/////////8P//////// + /gf/////////D/////////4H/////////w//////////A/////////8P/////////wP/////////D/// + //////+B/////////w//////////gf////////8P/////////8D/////////D//////////A//////// + /w//////////4H////////8P//////////A/////////D//////////wD////////w//////////+AH/ + //////AP//////////gAP//////wD//////////8AAf/////8A///////////gAA//////AP//////// + ///AAB//////D///////////+AAD/////w////////////8AAH////8P////////////4AA/////D/// + //////////wAP////w//////////////gD////8P//////////////A/////D/////////////////// + /w////////////////////8P////////////////////D////////////////////w////////////// + //////8P////////////////////D////////////////////w////////////////////8P//////// + ////////////D///////////////////8AD///////////////////AA///////////////////4Af// + ////////////////+AH///////////////////wD///////////////////8A/////////////////// + /gf///////////////////4H////////////////////D////////////////////w////////////// + //////+f////////////////////n/////////////////////////////////////////////////// + //////////////////////////////////////////////////////////////////////////////// + //////////////////////////////////////////////////////////8oAAAAYAAAAMAAAAABACAA + AAAAAICUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAd3d3nXd3d512dnacAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAdnZ2nHd3d513d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAdnZ2nHd3d512dnacAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAd3d3nXd3d512dnacAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4dHh4eCp3d3cCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d512dnacAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAdnZ2nHd3d513d3ecAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAdnZ2nHd3d512dnacAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d512dnacAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJl3d3d0eHh4KHh4eAMAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + dnZ2nHZ2dpx2dnacAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + dnZ2nHZ2dpx2dnacAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + dnZ2nHZ2dpx2dnacAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + dnZ2nHZ2dpx2dnacAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ec + d3d3mnd3d3J3d3coAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ13d3eceHh4nXh4eJ14eHidd3d3nHh4eJ13d3eceHh4nXh4eJ13d3ec + eHh4nXh4eJ13d3eceHh4nXh4eJ13d3ecd3d32Xd3d9l2dnbYeHh4nXh4eJ13d3eceHh4nXh4eJ14eHid + d3d3nHh4eJ14eHidd3d3nHh4eJ14eHiddnZ22Hd3d9l3d3fZd3d3nHh4eJ14eHidd3d3nHh4eJ14eHid + d3d3nHh4eJ14eHidd3d3nHh4eJ14eHiddnZ22Hd3d9l2dnbYeHh4nXh4eJ13d3eceHh4nXh4eJ13d3ec + eHh4nXh4eJ13d3eceHh4nXh4eJ13d3ecd3d32Xd3d9l2dnbYeHh4nXh4eJ13d3eceHh4nXh4eJ13d3ec + eHh4nXh4eJ13d3eceHh4nXh4eJ13d3eceHh4nXh4eJ13d3eceHh4dHh4eCp3d3cCAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3eceHh4nXh4eJ14eHid + d3d3nHh4eJ13d3eceHh4nXh4eJ13d3eceHh4nXh4eJ13d3eceHh4nXh4eJ13d3ecd3d32Xd3d9l2dnbY + eHh4nXh4eJ13d3eceHh4nXh4eJ14eHidd3d3nHh4eJ14eHidd3d3nHh4eJ14eHiddnZ22Hd3d9l3d3fZ + d3d3nHh4eJ14eHidd3d3nHh4eJ14eHidd3d3nHh4eJ14eHidd3d3nHh4eJ14eHiddnZ22Hd3d9l2dnbY + eHh4nXh4eJ13d3eceHh4nXh4eJ13d3eceHh4nXh4eJ13d3eceHh4nXh4eJ13d3ecd3d32Xd3d9l2dnbY + eHh4nXh4eJ13d3eceHh4nXh4eJ13d3eceHh4nXh4eJ13d3eceHh4nXh4eJ13d3eceHh4nXh4eJ13d3ec + eHh4nXh4eJV3d3dMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + d3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ec + d3d3nHd3d5x3d3ecdnZ22HZ2dth2dnbYd3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ec + d3d3nHd3d5x3d3eddnZ22HZ2dth2dnbYd3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ec + d3d3nHd3d5x3d3eddnZ22HZ2dth2dnbYd3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ec + d3d3nHd3d5x3d3ecdnZ22HZ2dth2dnbYd3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ec + d3d3nHd3d5x3d3ecd3d3nHd3d5x3d3ecd3d3dHd3dyp3d3cCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3eceHh4mnh4eHJ3d3coAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ec + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJl3d3d0 + eHh4KHh4eAMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4dHh4eCp3d3cCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ec + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAO9nCQTuZghM + 72cJaO9nCS7uZggOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAO5mCE7uZgj87mYI/u5mCPzuZgjc7mYIqe5nCWruZworAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAO9nCUvuZgj772cJ/+9nCf/uZgj+ + 72cJ/+9nCf/uaAv+72oN6O9rD6rvbBFr724TMfBvFQoAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + 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 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA8X0tK/F/L2rygTKo8oM13POEN/zzhjn/8oc7/vOIPv/zikD4 + 84tCd/OMQwoAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ec + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMMAuATCALdMwwC4XcMAuBUAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + 8oI0DvKENy3yhjp+8og98fOJP//zikH/84xD/fONRcPzjkczAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + 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 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x2dnac + eHh42Xh4eNl3d3fYAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAACjCrYBoAu1O50MtqSbDbb4mQ61/pcOtv+WD7X/lA+1+5IQtWkAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACaDbUblw61iZUPteOTELT+ + kRC0/pARtOWOEbQZAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ec + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAJMPtRuQEbXSjxG0/o0Stf6MErWMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACOEbVVjBK0/ooTtf+JE7X2 + iBK0IQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAiRK0wocTtP6FE7T+hBS0poMUswMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAhhO0P4UUtPaDFLT/gRWz+IAVtD0AAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + gxSzAYIVtKmAFbT/fhaz/n0WtL18FrQEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ec + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAH4Vsyd9FrPwexez/noXs/t5F7NYAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHwWswF6F7OL + eRiz/ncYtP92GbTYdRizCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB4GLMTdhmz7HQZtP9zGrP/cRqzbQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + d3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcxqzbnEas/1wG7L+ + bhuy5W0bshoAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAcBqyDm8bs9NtHLP/axyy/mods4sAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ed + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGwcs1ZqHbP+aR2y/mces+9mHrIo + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + dnZ2nHZ2dpx2dnacd3d32Hd3d9h3d3fYAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAGkdsgZnHrK7Zh6y/mQfsv5iH7KqAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d512dnaceHh42Xh4eNl3d3fYAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABkHrI6Yx+y+2Egsv9gILL7XyCxOQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x2dnac + eHh42Xh4eNl3d3fYAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + YCCyql4hsv9dIbL/WyKxu1shsgYAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAXSGxKFwise9aIrH+WCOx/lcjsVYAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ec + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFkisYtXI7L/ + VSSx/lQksdNTJLENAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAFYjsRpUJLHlUyWx/lElsf1QJbFuAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABRJbFtUCax/k4msf9NJ7Ds + TCexEwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAABOJrEITSex2Usnsf9KKLD+SCixikcosQEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAASiewWEkosPtHKbD+RSmw70UpsCcAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ec + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + RyiwBEYpsb5EKrD+Qiqx/0ErsKhAKrABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEMqsD1BK7D4QCux/z4ssPY9LLA/AAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEArsAM+K7Cn + PSyw/jstsP46La/BAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAA8LK8hOi2w9jgusP83Lq/+NS+vVQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAANy6wjDYvsP40L6/+ + MjCw0jAwryQtMa8DAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ec + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAANS6vGTMwr+UxMK/+LzGv/i4xr/IsMq+6KjOvZiYzrhcAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + d3d3nXd3d512dnaceHh42Xh4eNl3d3fYAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADAwr2guMa/6LTKv/ysyr/8pM67+ + KDOv/yY0r/okNK6+ITWuZh82riIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d512dnaceHh42Xh4eNl3d3fYAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAC8wrwQtMa9XKjKvvSgzr+8nNK7+JTSv/yM1r/8iNa7+IDav/h43r+8cN669GjiuZhc5rh8VOq0D + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAdnZ2nHZ2dpx2dnac + d3d32Hd3d9h3d3fYAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACgzriIlNK5mIjWuviA2rvofNq7+ + HTeu/hw4rv4aOK7+GDmu/hc5rfIVOq26EzutZhA7rRcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAACA1rhcdN65mGziuuhk5rvIXOa3+FTqu/xQ6rv8TO63+ETuu/xA8rvoOPK2+ + Cz2tZgg+rSIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ec + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHDeuAxk4rh8WOa1m + EzquvRI7ru8QPK3+Dzyu/w09rv8MPa3+Cj6t/gg/re8GP629BECtVwNArQQAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABI7rSIPPK1mDD2tvgo+rfoJPq3+Bz+t/gY/rP4EQKz+ + AkCs+gJArEsAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAo9rRcHP6xmBUCtugNArfIBQaz+AEKt+wFArU4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABj+tAwNArR8BQKxiAUGtSwJArQQAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ec + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ecAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ13d3ecAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nHd3d5x3d3ec + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4dHh4eJ13d3eceHh4nXh4eJ13d3eceHh4nXh4eJ14eHh0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4Knh4eJl3d3eceHh4nXh4eJ13d3eceHh4nXh4eJl4eHgq + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3And3d3R3d3ec + d3d3nHd3d5x3d3ecd3d3nHd3d3R3d3cCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eCh3d3eaeHh4nXh4eJ13d3eceHh4mnh4eCgAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eAN3d3dyeHh4nXh4eJ13d3ec + eHh4cnh4eAMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB3d3cod3d3nHd3d5x3d3ecd3d3KAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4dHh4eJ13d3d0AAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4Knh4eJV3d3cqAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3And3d0x3d3cCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA//////////////// + ////////////////////////////////////H/4//H/4/4//////H/4//H/4/4P/////H/4//H/4/4H/ + /AAAAAAAAAAAAAA//AAAAAAAAAAAAAA//AAAAAAAAAAAAAA//H///////////4H//H///////////4P/ + /H///////////4///H///////////////H///////////////H///////////////H////////////// + /H8H/////////////H8A/////////////H8AB////////////H8AAH///////////H/gAA////////// + 4H//AAB/////////4H//4AAP////////4H///gAH/////////H////AB/////////H8P//4A//////// + /H8D///AP////////H8Af//gH////////H8AH//4B////////H/AB//8A////////H/4Af//AP////// + /H/8AD//gH//gP///H//gA//4B/4AP///H//4AP/8AwAAP///H//+AB//AAAAP///H///wA//gAAD/// + 4H///8AH/4AH////4H////AB/8B/////4H////wB/////////H////+A/////////H/////g//////// + /H/////wf////////H/////4P////////H/////4P////////H/////4H////////H/////8H/////// + /H/////8D////////H/////+D////////H//////B////////H//////B////////H//////g/////// + 4H//////g///////4H//////wf//////4H//////4P///////H//////4P///////H//////8H////// + /H//////8H///////H//////+D///////H//////+B///////H///////B///////H///////A////// + /H///////g///////H///////g///////H///////wf//////H///////4H//////H///////4B///// + 4H///////8AP////4H///////8AA////4H////////gAP////H////////8AB////H/////////AAP// + /H/////////8AP///H//////////gP///H//////////4P///H///////////////H////////////// + /H///////////////H///////////////H///////////////H///////////////H////////////// + 4A//////////////4A//////////////4A//////////////8B//////////////8B////////////// + +D///////////////H///////////////H///////////////H////////////////////////////// + //////////////////////////////////////////////////////////////////////////////// + KAAAAEgAAACQAAAAAQAgAAAAAABgVAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHZ2dnV3d3d1dnZ2HQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAdnZ2WHd3d3V2dnY6AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB2dnY6 + d3d3dXZ2dlgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHZ2dh13d3d1dnZ2dQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHd3dxp4eHg6d3d3BQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHd3d513d3edd3d3JwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + d3d3dXd3d513d3dOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOd3d3nXd3d3UAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHd3dyd3d3edd3d3nQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHh4eCd4eHiceHh4hHh4eDp4eHgFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB3d3cneHh4Tnd3d054eHhOeHh4Tnd3d054eHhOd3d3Tnh4eE53d3dOeHh4Tnd3d053d3dO + d3d3TnZ2drp3d3e7d3d3aXd3d053d3dOeHh4Tnd3d054eHhOeHh4Tnd3d053d3dOd3d3n3d3d7t3d3eE + d3d3Tnd3d054eHhOeHh4Tnd3d054eHhOd3d3Tnd3d053d3eEd3d3u3d3d593d3dOd3d3Tnh4eE54eHhO + d3d3Tnh4eE53d3dOd3d3Tnd3d2l3d3e7dnZ2und3d053d3dOd3d3Tnh4eE53d3dOeHh4Tnd3d2J4eHid + d3d3nHh4eJ14eHiEd3d3Onh4eAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHhO + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXd3d9l3d3fZ + d3d3q3h4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHidd3d3ynd3d9l3d3e7eHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ13d3e7d3d32Xd3d8p4eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXd3d6x3d3fZd3d32Xh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nHh4eH54eHgUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXd3d5N4eHh1 + eHh4dXd3d3V4eHh1d3d3dXh4eHV3d3d1eHh4dXd3d3V3d3d1d3d3dXZ2dqJ3d3eid3d3gHd3d3V3d3d1 + eHh4dXd3d3V4eHh1eHh4dXd3d3V3d3d1d3d3l3d3d6J3d3eMd3d3dXd3d3V4eHh1eHh4dXd3d3V4eHh1 + d3d3dXd3d3V3d3eMd3d3ond3d5d3d3d1d3d3dXh4eHV4eHh1d3d3dXh4eHV3d3d1d3d3dXd3d4B3d3ei + dnZ2ond3d3V3d3d1d3d3dXh4eHV3d3d1eHh4dXd3d394eHidd3d3nHh4eJ14eHiZd3d3YXh4eBkAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHhOeHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eCd4eHideHh4l3h4eGF4eHgXAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB4eHhOeHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHh4eCR4eHhheHh4GQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB3d3dOeHh4nXd3d3UAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHhO + eHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXd3d3UAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHhOeHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAA + AAAAAO9nCSHvZwmM72cJaO9nCSnvZwkHAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXd3d3UAAAAAAAAAAAAAAAAAAAAAAAAAAO9nCYbuZgj+ + 72cJ/+5mCP7vZwng72gKqO5pDWfvaxAs720TAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB3d3dOeHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAAAAAAAO9nCSDvZwmj72cJ4e9nCfrvZwn/ + 72gM/+9qDv/wbBH7724T4/BwF6jwchlo8HMdKfB1IAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAdnZ2HXd3dyd3d3dp + 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 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXd3d3UAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIwStEqKErX9hxO1/oYTtEkAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHhOeHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIgStAGGE7S5hBS0/4IVtM6AFbQIAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXd3d3UAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAACCFLQ0gBW0+H4Ws/58FrRlAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB4eHhOeHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAfBeznXoXtP94GLTkdhizDwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHhO + eHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eBezHHYZtPR0GbP+chqzgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXd3d3UAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHIas4BwG7P/ + bhuy8G0bsyAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAG4bsxJsHLPiah2z/2gds50AAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAdnZ2WHd3d3V3d3efeHh4ynd3d5cAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABpHbJkZh6y/mQfs/ljH7IzAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + d3d3dXd3d513d3e7eHh42Xh4eKIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAABlHrIGYx+y0GEgsv9fIbK3XSGyAwAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAdnZ2Ond3d053d3eE + eHh4u3d3d4wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAXyCyTF0hsvxbIrH9WSKySgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXh4eHUAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + WyGxAlkisrhXI7L/VSSyz1MksQcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXd3d3UAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFUjsTJTJbH5 + USWx/k8msWUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB4eHhOeHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABPJrGcTSex/0snseRKJ7EP + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB3d3dOeHh4nXd3d3UAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABLJ7AfSSix8UcpsP5FKbCAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHhO + eHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAARSmwgEMqsf9BK7HwQCuwIAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHhOeHh4nXh4eHUAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAQiqwEUArsOI9LLD/PC2wnQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXd3d3UAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAADwssGU6LbD+OC6v/DUurzAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADgtsAU2L7DR + NC+w/zIwr8EuMa8vKjKvBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + dnZ2Ond3d053d3eEeHh4u3d3d4wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + 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 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAANArQUCQK0WAUCtAQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXd3d3UAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHhOeHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB3d3dOeHh4nXd3d3UAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB4eHhOeHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3Gnh4eCd3d3di + eHh4nXd3d394eHgneHh4JAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4Onh4eJx4eHideHh4nXh4eJ14eHid + eHh4YQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3BXh4eIR3d3eceHh4nXd3d5x4eHiXeHh4GQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eDp4eHideHh4nXh4eJ14eHhhAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHh4eAV4eHiEeHh4nXh4eJl4eHgXAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3c6 + eHh4nHd3d2EAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHgEeHh4fnh4eBkAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4FAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAP///////////wAAAP///////////wAAAP//x/j/H+Px/wAAAP//x/j/H+Pw + fwAAAPAAAAAAAAAAHwAAAPAAAAAAAAAADwAAAPAAAAAAAAAAHwAAAPH////////wfwAAAPH////////x + /wAAAPH//////////wAAAPH//////////wAAAPH//////////wAAAPHwf////////wAAAPHwB/////// + /wAAAPHwAH///////wAAAMH8AAf//////wAAAMH/wAB//////wAAAMH//AA//////wAAAPH//+AP//// + /wAAAPHw//wH/////wAAAPHwH/8B/////wAAAPHwB/+A/////wAAAPH8Af/gP////wAAAPH/AH/wH/4P + /wAAAPH/4B/8B8AP/wAAAPH/+AP+AAAP/wAAAPH//gD/gAAf/wAAAMH//4A/4A///wAAAMH//+Af8f// + /wAAAMH///wP/////wAAAPH///8P/////wAAAPH///+H/////wAAAPH///+D/////wAAAPH////D//// + /wAAAPH////h/////wAAAPH////h/////wAAAPH////w/////wAAAPH////w/////wAAAMH////4f/// + /wAAAMH////4P////wAAAMH////8P////wAAAPH////8H////wAAAPH////+H////wAAAPH/////D/// + /wAAAPH/////D////wAAAPH/////h////wAAAPH/////h////wAAAPH/////w////wAAAPH/////wP// + /wAAAMH/////4B///wAAAMH/////4AP//wAAAMH/////+AD//wAAAPH//////wAP/wAAAPH//////+AP + /wAAAPH///////4P/wAAAPH///////+P/wAAAPH//////////wAAAPH//////////wAAAPH///////// + /wAAAPH//////////wAAAMB//////////wAAAMB//////////wAAAMB//////////wAAAOD///////// + /wAAAOD//////////wAAAPH//////////wAAAPH//////////wAAAPv//////////wAAAP////////// + /wAAAP///////////wAAAP///////////wAAAP///////////wAAACgAAABAAAAAgAAAAAEAIAAAAAAA + AEIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3ed + d3d3nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d50AAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHd3d513d3edAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3ed + d3d3nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eHV4eHgnAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAd3d3nXd3d50AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHd3d513d3ed + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3edd3d3nQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAd3d3nXd3d50AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eHV4eHgn + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXd3d9l3d3fZeHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ13d3fZd3d32Xh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHidd3d32Xd3d9l4eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXd3d9l3d3fZeHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eHV4eHgnAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ13d3fZd3d32Xh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHidd3d32Xd3d9l4eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXd3d9l3d3fZeHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ13d3fZd3d32Xh4eJ14eHid + eHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHh1eHh4JwAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nXh4eHV4eHgnAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4dXh4eCcAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAA + 72cJt+9nCeXvZwmm72cJZ+9nCicAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ0AAAAA + AAAAAAAAAAAAAAAAAAAAAO9nCbjvZwn/72cJ/+9nCf/vaAv/72oO5u9sEabvbhRn8HAXJwAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA72cJJ+9nCWbvZwmm72kN5u9rEP/wbRP/ + 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 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAI8RtU+MErX/ihO16ogStA4AAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAiBO0wIUTtP+DFLSH + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAIMUtDSBFbT9fxa09n0WtB4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAfRazpHoXtP94GLOkAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHid + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHkXsx52GbT2dBmz/XIaszQAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB4eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + chqziHAbs/9tHLPAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAG4bsw9rHLPqaR2z/2cesk8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3edd3d3nXh4eNl4eHjZAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAZx6ya2Ufs/9iH7LYYR+yBAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXd3d514eHjZ + eHh42QAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGMfsgRgILLY + XiGy/1whsmsAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAXCGyT1oisv9XI7LqViOxDgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABVJLHAUyWy/1ElsYcAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUSWxNE8msf1MJ7H2 + SyexHgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAABLJ7GkSCix/0YpsaQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAARimwHkQqsfZBK7H9QCuwNAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + 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 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACD6tNwRArYwBQa3fAEGttgAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHidAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHid + eHh4nQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXh4eJ0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eJ14eHidAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHideHh4nQAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eHV4eHid + eHh4nXh4eJ14eHideHh4dQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB4eHgneHh4nXh4eJ14eHideHh4nXh4eCcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eHV4eHideHh4nXh4eHUAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB4eHgneHh4nXh4eJ14eHgn + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAHh4eHV4eHh1AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB4eHgneHh4JwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA////////////////////////P8/z/Pz///8/z/P8/D/wAAAA + AAAAD/AAAAAAAAAP8////////D/z///////8//P/////////8//////////z//////////Pg//////// + 8+AP///////z8AD//////8P/AA//////w//wA//////z//8A//////Ph/+B/////8+B/+B/////z4B/8 + D/////P8A/8D////8/8A/4H8B//z/8A/4AAH//P/8A/wAA//w//+AfwD///D//+A//////P//+D///// + 8///+H/////z///8f/////P///w/////8////j/////z///+H/////P///8f////8////w/////D//// + h////8P///+H////8////8P////z////4/////P////h////8/////H////z////8P////P////4//// + 8/////h////z/////B///8P////8A///w/////8Af//z/////+AP//P//////Af/8///////h//z//// + //////P/////////8//////////z//////////P/////////wP/////////A/////////+H///////// + 4f/////////z//////////P///////////////////////////////////////////////////8oAAAA + MAAAAGAAAAABACAAAAAAAIAlAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAdnZ2TnZ2dicAAAAAAAAAAAAAAAAAAAAA + AAAAAHZ2did2dnZOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3TnZ2dicAAAAAAAAAAAAAAAAAAAAA + AAAAAHZ2did3d3dOAAAAAAAAAAAAAAAAAAAAAHd3dx14eHgLAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAdnZ2nHZ2dk4AAAAA + AAAAAAAAAAAAAAAAAAAAAHZ2dk52dnacAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3nXZ2dk4AAAAA + AAAAAAAAAAAAAAAAAAAAAHZ2dk53d3ecAAAAAAAAAAAAAAAAAAAAAHd3d054eHiRd3d3Tnd3dwoAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eJ14eHideHh4nXh4eJ14eHideHh4nXh4eJ14eHid + d3d32Xd3d7t4eHideHh4nXh4eJ14eHideHh4nXd3d7t3d3fZeHh4nXh4eJ14eHideHh4nXh4eJ14eHid + d3d32Xd3d7t4eHideHh4nXh4eJ14eHideHh4nXd3d7t3d3fZeHh4nXh4eJ14eHideHh4nXh4eJ14eHid + eHh4nXh4eJJ4eHhDAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXd3d3V3d3dOeHh4Tnd3d053d3dO + eHh4Tnd3d053d3dOdnZ2bHd3d113d3dOeHh4Tnd3d053d3dOd3d3Tnd3d112dnZsd3d3Tnd3d053d3dO + eHh4Tnd3d053d3dOd3d3bHd3d113d3dOeHh4Tnd3d054eHhOd3d3Tnd3d113d3dsd3d3Tnd3d054eHhO + d3d3Tnd3d3V4eHidd3d3kXd3d054eHgLAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXd3d04AAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAHd3d0R4eHhOd3d3CwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + eHh4nXh4eE4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAeHh4nXd3d04AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXd3d04AAAAAAAAAAAAAAADuZghn72cJpO5mCGXvZwol + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eE4AAAAAAAAAAAAAAADvZwln + 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 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXh4eE4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4nXd3d04AAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHd3dx13d3dOeHh4nXd3d3V3d3dE + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHh4eAt4eHiR + eHh4nXh4eJ14eHhOAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAB3d3dOeHh4nXd3d5F3d3cLAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAB3d3cKeHh4knd3d04AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeHh4Q3h4eAsAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAA////////AAD/8+fnzz8AAP/z5+fPDwAA4AAAAAAHAADgAAAAAAcAAOf/////HwAA + 5///////AADn//////8AAOcP/////wAA5wB/////AACHgAf///8AAIf4Af///wAA5z/A////AADnD/g/ + //8AAOcB/B///wAA58B/B/j/AADn8B+CAP8AAOf8B+AA/wAAh/+A8B//AACH/+D///8AAOf/+H///wAA + 5//8f///AADn//4///8AAOf//j///wAA5///H///AACH//8f//8AAIf//4///wAA5///h///AADn///H + //8AAOf//8P//wAA5///4///AADn///x//8AAOf///B//wAAh///+A//AACH///8Af8AAOf///+A/wAA + 5/////D/AADn//////8AAOf//////wAA5///////AACD//////8AAIP//////wAAw///////AADH//// + //8AAOf//////wAA////////AAD///////8AAP///////wAAKAAAACAAAABAAAAAAQAgAAAAAACAEAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB3d3ed + AAAAAAAAAAAAAAAAAAAAAHd3d50AAAAAAAAAAAAAAAAAAAAAd3d3nQAAAAAAAAAAAAAAAAAAAAB3d3ed + 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 + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD//////3ve58AAAAPf///n3////9j////YD/// + nwH//9jwf//YPD//3g8OH9+DgB+f4OH/3/h//9/+f//f/j//3/8//5//H//f/5//3/+P/9//z//f/8P/ + n//gf9//+B/f//8f3////9////+P////j////9///////////////ygAAAAYAAAAMAAAAAEAIAAAAAAA + YAkAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABra2sdAAAAAAAAAABjY2MJ + a2trEwAAAAAAAAAAa2trE2trawkAAAAAAAAAAGtrax0AAAAAAAAAAGxsbAoAAAAAAAAAAAAAAAAAAAAA + eHh4J3d3d054eHhOeHh4Tnd3d053d3efd3d3Tnd3d053d3dpd3d3hHd3d053d3dOd3d3hHd3d2l4eHhO + d3d3Tnd3d593d3dOeHh4Tnd3d4Z4eHhid3d3EAAAAAAAAAAAd3d3Tnd3d0R3d3cnd3d3J3d3dyd3d3cy + d3d3J3d3dyd3d3cqd3d3Lnd3dyd3d3cnd3d3Lnd3dyp3d3cnd3d3J3d3dzJ3d3cnd3d3J3d3d2l3d3c6 + c3NzAgAAAAAAAAAAeHh4Tnd3dycAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAd3d3Tnd3dycAAAAA + 72cJle5nCaHvaxBi6W0XIgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA + 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 + P/8AAP//AAA= + + + \ No newline at end of file diff --git a/AsPerfMon/AsPerfMon/App.config b/AsPerfMon/AsPerfMon/App.config new file mode 100644 index 0000000..7d6d35f --- /dev/null +++ b/AsPerfMon/AsPerfMon/App.config @@ -0,0 +1,27 @@ + + + + +
+ + + + + + + + + + + + + + + 2500 + + + False + + + + \ No newline at end of file diff --git a/AsPerfMon/AsPerfMon/Chart.ico b/AsPerfMon/AsPerfMon/Chart.ico new file mode 100644 index 0000000..d6e987d Binary files /dev/null and b/AsPerfMon/AsPerfMon/Chart.ico differ diff --git a/AsPerfMon/AsPerfMon/Connect.Designer.cs b/AsPerfMon/AsPerfMon/Connect.Designer.cs new file mode 100644 index 0000000..454c1e0 --- /dev/null +++ b/AsPerfMon/AsPerfMon/Connect.Designer.cs @@ -0,0 +1,210 @@ +namespace ASPerfMon +{ + partial class Connect + { + /// + /// Required designer variable. + /// + private System.ComponentModel.IContainer components = null; + + /// + /// Clean up any resources being used. + /// + /// true if managed resources should be disposed; otherwise, false. + protected override void Dispose(bool disposing) + { + if (disposing && (components != null)) + { + components.Dispose(); + } + base.Dispose(disposing); + } + + #region Windows Form Designer generated code + + /// + /// Required method for Designer support - do not modify + /// the contents of this method with the code editor. + /// + private void InitializeComponent() + { + this.btnOK = new System.Windows.Forms.Button(); + this.btnCancel = new System.Windows.Forms.Button(); + this.txtUserName = new System.Windows.Forms.TextBox(); + this.txtServer = new System.Windows.Forms.TextBox(); + this.label3 = new System.Windows.Forms.Label(); + this.label1 = new System.Windows.Forms.Label(); + this.chkIntegratedAuth = new System.Windows.Forms.CheckBox(); + this.txtPassword = new System.Windows.Forms.TextBox(); + this.label2 = new System.Windows.Forms.Label(); + this.groupBox1 = new System.Windows.Forms.GroupBox(); + this.txtSampleInterval = new System.Windows.Forms.TextBox(); + this.label4 = new System.Windows.Forms.Label(); + this.groupBox1.SuspendLayout(); + this.SuspendLayout(); + // + // btnOK + // + this.btnOK.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right))); + this.btnOK.Location = new System.Drawing.Point(264, 179); + this.btnOK.Name = "btnOK"; + this.btnOK.Size = new System.Drawing.Size(75, 23); + this.btnOK.TabIndex = 0; + this.btnOK.Text = "OK"; + this.btnOK.UseVisualStyleBackColor = true; + this.btnOK.Click += new System.EventHandler(this.btnOK_Click); + // + // btnCancel + // + this.btnCancel.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right))); + this.btnCancel.DialogResult = System.Windows.Forms.DialogResult.Cancel; + this.btnCancel.Location = new System.Drawing.Point(345, 179); + this.btnCancel.Name = "btnCancel"; + this.btnCancel.Size = new System.Drawing.Size(75, 23); + this.btnCancel.TabIndex = 1; + this.btnCancel.Text = "Cancel"; + this.btnCancel.UseVisualStyleBackColor = true; + // + // txtUserName + // + this.txtUserName.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.txtUserName.Location = new System.Drawing.Point(111, 62); + this.txtUserName.Name = "txtUserName"; + this.txtUserName.Size = new System.Drawing.Size(310, 20); + this.txtUserName.TabIndex = 10; + // + // txtServer + // + this.txtServer.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.txtServer.Location = new System.Drawing.Point(111, 13); + this.txtServer.Name = "txtServer"; + this.txtServer.Size = new System.Drawing.Size(310, 20); + this.txtServer.TabIndex = 1; + // + // label3 + // + this.label3.AutoSize = true; + this.label3.Location = new System.Drawing.Point(6, 65); + this.label3.Name = "label3"; + this.label3.Size = new System.Drawing.Size(63, 13); + this.label3.TabIndex = 8; + this.label3.Text = "User Name:"; + // + // label1 + // + this.label1.AutoSize = true; + this.label1.Location = new System.Drawing.Point(6, 16); + this.label1.Name = "label1"; + this.label1.Size = new System.Drawing.Size(41, 13); + this.label1.TabIndex = 6; + this.label1.Text = "Server:"; + // + // chkIntegratedAuth + // + this.chkIntegratedAuth.AutoSize = true; + this.chkIntegratedAuth.Location = new System.Drawing.Point(111, 39); + this.chkIntegratedAuth.Name = "chkIntegratedAuth"; + this.chkIntegratedAuth.Size = new System.Drawing.Size(145, 17); + this.chkIntegratedAuth.TabIndex = 2; + this.chkIntegratedAuth.Text = "Integrated Authentication"; + this.chkIntegratedAuth.UseVisualStyleBackColor = true; + this.chkIntegratedAuth.CheckedChanged += new System.EventHandler(this.chkIntegratedAuth_CheckedChanged); + // + // txtPassword + // + this.txtPassword.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.txtPassword.Location = new System.Drawing.Point(111, 88); + this.txtPassword.Name = "txtPassword"; + this.txtPassword.PasswordChar = '*'; + this.txtPassword.Size = new System.Drawing.Size(310, 20); + this.txtPassword.TabIndex = 13; + // + // label2 + // + this.label2.AutoSize = true; + this.label2.Location = new System.Drawing.Point(6, 91); + this.label2.Name = "label2"; + this.label2.Size = new System.Drawing.Size(56, 13); + this.label2.TabIndex = 12; + this.label2.Text = "Password:"; + // + // groupBox1 + // + this.groupBox1.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.groupBox1.Controls.Add(this.txtUserName); + this.groupBox1.Controls.Add(this.txtPassword); + this.groupBox1.Controls.Add(this.label1); + this.groupBox1.Controls.Add(this.label2); + this.groupBox1.Controls.Add(this.label3); + this.groupBox1.Controls.Add(this.chkIntegratedAuth); + this.groupBox1.Controls.Add(this.txtServer); + this.groupBox1.Location = new System.Drawing.Point(12, 12); + this.groupBox1.Name = "groupBox1"; + this.groupBox1.Size = new System.Drawing.Size(427, 123); + this.groupBox1.TabIndex = 14; + this.groupBox1.TabStop = false; + // + // txtSampleInterval + // + this.txtSampleInterval.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.txtSampleInterval.Location = new System.Drawing.Point(123, 141); + this.txtSampleInterval.Name = "txtSampleInterval"; + this.txtSampleInterval.Size = new System.Drawing.Size(310, 20); + this.txtSampleInterval.TabIndex = 15; + this.txtSampleInterval.Text = "1000"; + // + // label4 + // + this.label4.AutoSize = true; + this.label4.Location = new System.Drawing.Point(18, 144); + this.label4.Name = "label4"; + this.label4.Size = new System.Drawing.Size(105, 13); + this.label4.TabIndex = 14; + this.label4.Text = "Sample Interval (ms):"; + // + // Connect + // + this.AcceptButton = this.btnOK; + this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); + this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; + this.CancelButton = this.btnCancel; + this.ClientSize = new System.Drawing.Size(450, 219); + this.Controls.Add(this.txtSampleInterval); + this.Controls.Add(this.label4); + this.Controls.Add(this.groupBox1); + this.Controls.Add(this.btnCancel); + this.Controls.Add(this.btnOK); + this.MaximizeBox = false; + this.MinimizeBox = false; + this.Name = "Connect"; + this.ShowIcon = false; + this.Text = "Connect"; + this.Load += new System.EventHandler(this.Connect_Load); + this.groupBox1.ResumeLayout(false); + this.groupBox1.PerformLayout(); + this.ResumeLayout(false); + this.PerformLayout(); + + } + + #endregion + + private System.Windows.Forms.Button btnOK; + private System.Windows.Forms.Button btnCancel; + private System.Windows.Forms.TextBox txtUserName; + private System.Windows.Forms.TextBox txtServer; + private System.Windows.Forms.Label label3; + private System.Windows.Forms.Label label1; + private System.Windows.Forms.CheckBox chkIntegratedAuth; + private System.Windows.Forms.TextBox txtPassword; + private System.Windows.Forms.Label label2; + private System.Windows.Forms.GroupBox groupBox1; + private System.Windows.Forms.TextBox txtSampleInterval; + private System.Windows.Forms.Label label4; + } +} \ No newline at end of file diff --git a/AsPerfMon/AsPerfMon/Connect.cs b/AsPerfMon/AsPerfMon/Connect.cs new file mode 100644 index 0000000..bde3f21 --- /dev/null +++ b/AsPerfMon/AsPerfMon/Connect.cs @@ -0,0 +1,70 @@ +using System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Data; +using System.Drawing; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Windows.Forms; + +namespace ASPerfMon +{ + public partial class Connect : Form + { + public string ServerName { get; set; } + public bool IntegratedAuth { get; set; } + public string UserName { get; set; } + public string Passwrod { get; set; } + public int SampleInterval { get; set; } + + public Connect() + { + InitializeComponent(); + } + + private void Connect_Load(object sender, EventArgs e) + { + this.txtServer.Text = Settings.Default.ServerName; + this.chkIntegratedAuth.Checked = Settings.Default.IntegratedAuth; + this.txtUserName.Text = Settings.Default.UserName; + this.txtSampleInterval.Text = Settings.Default.SampleInterval.ToString(); + + this.txtServer.MouseDown += new System.Windows.Forms.MouseEventHandler(this.txt_MouseDown); + this.txtUserName.MouseDown += new System.Windows.Forms.MouseEventHandler(this.txt_MouseDown); + this.txtPassword.MouseDown += new System.Windows.Forms.MouseEventHandler(this.txt_MouseDown); + this.txtSampleInterval.MouseDown += new System.Windows.Forms.MouseEventHandler(this.txt_MouseDown); + + } + + private void chkIntegratedAuth_CheckedChanged(object sender, EventArgs e) + { + txtUserName.Enabled = !chkIntegratedAuth.Checked; + txtPassword.Enabled = !chkIntegratedAuth.Checked; + } + + private void btnOK_Click(object sender, EventArgs e) + { + int sampleInterval; + if (!int.TryParse(txtSampleInterval.Text, out sampleInterval)) + { + MessageBox.Show("Sample Interval must be a positive integer", "AS PerfMon", MessageBoxButtons.OK, MessageBoxIcon.Error); + return; + } + + this.ServerName = txtServer.Text; + this.IntegratedAuth = chkIntegratedAuth.Checked; + this.UserName = txtUserName.Text; + this.Passwrod = txtPassword.Text; + this.SampleInterval = sampleInterval; + + this.DialogResult = DialogResult.OK; + } + + private void txt_MouseDown(object sender, MouseEventArgs e) + { + TextBox textBox = (TextBox)sender; + textBox.SelectAll(); + } + } +} diff --git a/AsPerfMon/AsPerfMon/Connect.resx b/AsPerfMon/AsPerfMon/Connect.resx new file mode 100644 index 0000000..3bf930b --- /dev/null +++ b/AsPerfMon/AsPerfMon/Connect.resx @@ -0,0 +1,123 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + True + + \ No newline at end of file diff --git a/AsPerfMon/AsPerfMon/Program.cs b/AsPerfMon/AsPerfMon/Program.cs new file mode 100644 index 0000000..bffc787 --- /dev/null +++ b/AsPerfMon/AsPerfMon/Program.cs @@ -0,0 +1,23 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Threading.Tasks; +using System.Windows.Forms; + +namespace ASPerfMon +{ + static class Program + { + /// + /// The main entry point for the application. + /// + [STAThread] + static void Main() + { + Application.EnableVisualStyles(); + Application.SetCompatibleTextRenderingDefault(false); + + Application.Run(new ASPerfMon()); + } + } +} diff --git a/AsPerfMon/AsPerfMon/Properties/AssemblyInfo.cs b/AsPerfMon/AsPerfMon/Properties/AssemblyInfo.cs new file mode 100644 index 0000000..bac05e3 --- /dev/null +++ b/AsPerfMon/AsPerfMon/Properties/AssemblyInfo.cs @@ -0,0 +1,36 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// General Information about an assembly is controlled through the following +// set of attributes. Change these attribute values to modify the information +// associated with an assembly. +[assembly: AssemblyTitle("ASPerfMon")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("Microsoft Corporation")] +[assembly: AssemblyProduct("ASPerfMon")] +[assembly: AssemblyCopyright("Copyright © Microsoft Corporation 2016")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// Setting ComVisible to false makes the types in this assembly not visible +// to COM components. If you need to access a type in this assembly from +// COM, set the ComVisible attribute to true on that type. +[assembly: ComVisible(false)] + +// The following GUID is for the ID of the typelib if this project is exposed to COM +[assembly: Guid("b2442578-2c46-47d2-b5fb-57096c234552")] + +// Version information for an assembly consists of the following four values: +// +// Major Version +// Minor Version +// Build Number +// Revision +// +// You can specify all the values or you can default the Build and Revision Numbers +// by using the '*' as shown below: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/AsPerfMon/AsPerfMon/Properties/Resources.Designer.cs b/AsPerfMon/AsPerfMon/Properties/Resources.Designer.cs new file mode 100644 index 0000000..5787797 --- /dev/null +++ b/AsPerfMon/AsPerfMon/Properties/Resources.Designer.cs @@ -0,0 +1,63 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace ASPerfMon.Properties { + using System; + + + /// + /// A strongly-typed resource class, for looking up localized strings, etc. + /// + // This class was auto-generated by the StronglyTypedResourceBuilder + // class via a tool like ResGen or Visual Studio. + // To add or remove a member, edit your .ResX file then rerun ResGen + // with the /str option, or rebuild your VS project. + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "4.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + internal class Resources { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal Resources() { + } + + /// + /// Returns the cached ResourceManager instance used by this class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Resources.ResourceManager ResourceManager { + get { + if (object.ReferenceEquals(resourceMan, null)) { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("ASPerfMon.Properties.Resources", typeof(Resources).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// + /// Overrides the current thread's CurrentUICulture property for all + /// resource lookups using this strongly typed resource class. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Globalization.CultureInfo Culture { + get { + return resourceCulture; + } + set { + resourceCulture = value; + } + } + } +} diff --git a/AsPerfMon/AsPerfMon/Properties/Resources.resx b/AsPerfMon/AsPerfMon/Properties/Resources.resx new file mode 100644 index 0000000..ffecec8 --- /dev/null +++ b/AsPerfMon/AsPerfMon/Properties/Resources.resx @@ -0,0 +1,117 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/AsPerfMon/AsPerfMon/Properties/Settings.Designer.cs b/AsPerfMon/AsPerfMon/Properties/Settings.Designer.cs new file mode 100644 index 0000000..89f78a6 --- /dev/null +++ b/AsPerfMon/AsPerfMon/Properties/Settings.Designer.cs @@ -0,0 +1,26 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace ASPerfMon.Properties { + + + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "14.0.0.0")] + internal sealed partial class Settings : global::System.Configuration.ApplicationSettingsBase { + + private static Settings defaultInstance = ((Settings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new Settings()))); + + public static Settings Default { + get { + return defaultInstance; + } + } + } +} diff --git a/AsPerfMon/AsPerfMon/Properties/Settings.settings b/AsPerfMon/AsPerfMon/Properties/Settings.settings new file mode 100644 index 0000000..abf36c5 --- /dev/null +++ b/AsPerfMon/AsPerfMon/Properties/Settings.settings @@ -0,0 +1,7 @@ + + + + + + + diff --git a/AsPerfMon/AsPerfMon/Settings.Designer.cs b/AsPerfMon/AsPerfMon/Settings.Designer.cs new file mode 100644 index 0000000..c9e3087 --- /dev/null +++ b/AsPerfMon/AsPerfMon/Settings.Designer.cs @@ -0,0 +1,74 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace ASPerfMon { + + + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "14.0.0.0")] + internal sealed partial class Settings : global::System.Configuration.ApplicationSettingsBase { + + private static Settings defaultInstance = ((Settings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new Settings()))); + + public static Settings Default { + get { + return defaultInstance; + } + } + + [global::System.Configuration.UserScopedSettingAttribute()] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Configuration.DefaultSettingValueAttribute("")] + public string ServerName { + get { + return ((string)(this["ServerName"])); + } + set { + this["ServerName"] = value; + } + } + + [global::System.Configuration.UserScopedSettingAttribute()] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Configuration.DefaultSettingValueAttribute("")] + public string UserName { + get { + return ((string)(this["UserName"])); + } + set { + this["UserName"] = value; + } + } + + [global::System.Configuration.UserScopedSettingAttribute()] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Configuration.DefaultSettingValueAttribute("2500")] + public int SampleInterval { + get { + return ((int)(this["SampleInterval"])); + } + set { + this["SampleInterval"] = value; + } + } + + [global::System.Configuration.UserScopedSettingAttribute()] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Configuration.DefaultSettingValueAttribute("False")] + public bool IntegratedAuth { + get { + return ((bool)(this["IntegratedAuth"])); + } + set { + this["IntegratedAuth"] = value; + } + } + } +} diff --git a/AsPerfMon/AsPerfMon/Settings.settings b/AsPerfMon/AsPerfMon/Settings.settings new file mode 100644 index 0000000..0b4dcde --- /dev/null +++ b/AsPerfMon/AsPerfMon/Settings.settings @@ -0,0 +1,18 @@ + + + + + + + + + + + + 2500 + + + False + + + \ No newline at end of file diff --git a/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.exe.config b/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.exe.config new file mode 100644 index 0000000..7d6d35f --- /dev/null +++ b/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.exe.config @@ -0,0 +1,27 @@ + + + + +
+ + + + + + + + + + + + + + + 2500 + + + False + + + + \ No newline at end of file diff --git a/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.vshost.exe b/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.vshost.exe new file mode 100644 index 0000000..681ab77 Binary files /dev/null and b/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.vshost.exe differ diff --git a/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.vshost.exe.config b/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.vshost.exe.config new file mode 100644 index 0000000..7d6d35f --- /dev/null +++ b/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.vshost.exe.config @@ -0,0 +1,27 @@ + + + + +
+ + + + + + + + + + + + + + + 2500 + + + False + + + + \ No newline at end of file diff --git a/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.vshost.exe.manifest b/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.vshost.exe.manifest new file mode 100644 index 0000000..f96b1d6 --- /dev/null +++ b/AsPerfMon/AsPerfMon/bin/Debug/ASPerfMon.vshost.exe.manifest @@ -0,0 +1,11 @@ + + + + + + + + + + + diff --git a/AsPerfMon/AsPerfMon/obj/Debug/ASPerfMon.csproj.FileListAbsolute.txt b/AsPerfMon/AsPerfMon/obj/Debug/ASPerfMon.csproj.FileListAbsolute.txt new file mode 100644 index 0000000..6f44f20 --- /dev/null +++ b/AsPerfMon/AsPerfMon/obj/Debug/ASPerfMon.csproj.FileListAbsolute.txt @@ -0,0 +1 @@ +C:\Users\ChWade\Source\Repos\Analysis-Services\AsPerfMon\ASPerfMon\bin\Debug\ASPerfMon.exe.config diff --git a/AsPerfMon/AsPerfMon/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache b/AsPerfMon/AsPerfMon/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache new file mode 100644 index 0000000..48cc6c9 Binary files /dev/null and b/AsPerfMon/AsPerfMon/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache differ diff --git a/AsPerfMon/AsPerfMon/obj/Debug/TemporaryGeneratedFile_036C0B5B-1481-4323-8D20-8F5ADCB23D92.cs b/AsPerfMon/AsPerfMon/obj/Debug/TemporaryGeneratedFile_036C0B5B-1481-4323-8D20-8F5ADCB23D92.cs new file mode 100644 index 0000000..e69de29 diff --git a/AsPerfMon/AsPerfMon/obj/Debug/TemporaryGeneratedFile_5937a670-0e60-4077-877b-f7221da3dda1.cs b/AsPerfMon/AsPerfMon/obj/Debug/TemporaryGeneratedFile_5937a670-0e60-4077-877b-f7221da3dda1.cs new file mode 100644 index 0000000..e69de29 diff --git a/AsPerfMon/AsPerfMon/obj/Debug/TemporaryGeneratedFile_E7A71F73-0F8D-4B9B-B56E-8E70B10BC5D3.cs b/AsPerfMon/AsPerfMon/obj/Debug/TemporaryGeneratedFile_E7A71F73-0F8D-4B9B-B56E-8E70B10BC5D3.cs new file mode 100644 index 0000000..e69de29 diff --git a/AsPerfMon/AsPerfMon/packages.config b/AsPerfMon/AsPerfMon/packages.config new file mode 100644 index 0000000..007291b --- /dev/null +++ b/AsPerfMon/AsPerfMon/packages.config @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/AsPerfMon/README.md b/AsPerfMon/README.md new file mode 100644 index 0000000..f49fdc5 --- /dev/null +++ b/AsPerfMon/README.md @@ -0,0 +1,4 @@ +Monitor Analysis Services memory usage broken out by database and other high-level allocations in a stacked bar that increments at set interval. Useful during processing especially with multiple databases on same server. + +![alt text](AsPerfMon.png "Stacked bar by memory allocation") + diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..12eee49 --- /dev/null +++ b/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2016 Microsoft + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/README.md b/README.md new file mode 100644 index 0000000..3642063 --- /dev/null +++ b/README.md @@ -0,0 +1,16 @@ +# Analysis Services +Git repo for Analysis Services samples and community projects + +## [AsPartitionProcessing](https://github.com/Microsoft/Analysis-Services/tree/master/AsPartitionProcessing) +Automated partition management of Azure Analysis Services tabular models + +## [AsPerfMon](https://github.com/Microsoft/Analysis-Services/tree/master/AsPerfMon) +Real-time monitoring of Analysis Services memory usage broken out by database + +## Code of Conduct +This project has adopted the [Microsoft Open Source Code of +Conduct](https://opensource.microsoft.com/codeofconduct/). +For more information see the [Code of Conduct +FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or +contact [opencode@microsoft.com](mailto:opencode@microsoft.com) +with any additional questions or comments.