From 39fb07921fa1b2e9648cd101fc4d11fcd6a8d9ff Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Fri, 13 Dec 2024 11:59:13 +0200 Subject: [PATCH 01/12] update id version --- v4.0.1/admin-schema.json | 714 ++++++++++++++++++ v4.0.1/tasks-schema.json | 1540 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 2254 insertions(+) create mode 100644 v4.0.1/admin-schema.json create mode 100644 v4.0.1/tasks-schema.json diff --git a/v4.0.1/admin-schema.json b/v4.0.1/admin-schema.json new file mode 100644 index 0000000..7e9e57b --- /dev/null +++ b/v4.0.1/admin-schema.json @@ -0,0 +1,714 @@ +{ + "$schema": "https://json-schema.org/draft/2020-12/schema", + "$id": "https://raw.githubusercontent.com/hubverse-org/schemas/main/v4.0.1/admin-schema.json", + "title": "Schema for Modeling Hub administrative settings", + "description": "This JSON file provides a schema for modeling hub administrative information.", + "type": "object", + "properties": { + "schema_version": { + "description": "URL to a version of the Modeling Hub schema admin-schema.json file (see https://github.com/hubverse-org/schemas). Used to declare the schema version an 'admin.json' file is written for and for config file validation. The URL provided should be the URL to the raw content of the schema file on GitHub.", + "examples": [ + "https://raw.githubusercontent.com/hubverse-org/schemas/main/v3.0.0/admin-schema.json" + ], + "type": "string", + "format": "uri" + }, + "name": { + "description": "The name of the hub.", + "type": "string", + "examples": [ + "US COVID-19 Forecast Hub​" + ] + }, + "maintainer": { + "description": "The entity that maintains and runs the hub.", + "type": "string", + "examples": [ + "The Consortium of Infectious Disease Modeling Hubs" + ] + }, + "contact": { + "description": "The name and email of a human being who serves as a point of contact for the hub.", + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "email": { + "type": "string", + "format": "email" + } + } + }, + "repository": { + "description": "Object containing details of the hub repository.", + "examples": [ + { + "host": "github", + "owner": "hubverse-org", + "name": "example-simple-forecast-hub" + } + ], + "type": "object", + "properties": { + "host": { + "description": "The name of the web host for the hub repository", + "type": "string", + "enum": [ + "github" + ] + }, + "owner": { + "description": "The hub repository owner (user or organisation).", + "type": "string" + }, + "name": { + "description": "The name of the hub repository.", + "type": "string" + } + } + }, + "zoltar_project_id": { + "description": "The project id of the Hub in Zoltar", + "type": "integer", + "examples": [ + 44 + ] + }, + "citation": { + "description": "One or more citations for the hub.", + "type": "string", + "examples": [ + "Cramer, E.Y., Huang, Y., Wang, Y. et al. The United States COVID-19 Forecast Hub dataset. Sci Data 9, 462 (2022). https://doi.org/10.1038/s41597-022-01517-w" + ] + }, + "file_format": { + "description": "Accepted file formats of model output files.", + "examples": [ + [ + "arrow", + "parquet" + ], + [ + "csv" + ] + ], + "type": "array", + "items": { + "type": "string", + "enum": [ + "csv", + "parquet", + "arrow" + ] + } + }, + "timezone": { + "description": "Hub timezone in TZ database name format. Used primarily for determining exact time of submission deadlines.", + "examples": [ + "Africa/Cairo", + "America/Sao_Paulo", + "Asia/Bangkok", + "US/Eastern", + "Europe/Berlin" + ], + "type": "string", + "enum": [ + "Africa/Abidjan", + "Africa/Accra", + "Africa/Addis_Ababa", + "Africa/Algiers", + "Africa/Asmara", + "Africa/Asmera", + "Africa/Bamako", + "Africa/Bangui", + "Africa/Banjul", + "Africa/Bissau", + "Africa/Blantyre", + "Africa/Brazzaville", + "Africa/Bujumbura", + "Africa/Cairo", + "Africa/Casablanca", + "Africa/Ceuta", + "Africa/Conakry", + "Africa/Dakar", + "Africa/Dar_es_Salaam", + "Africa/Djibouti", + "Africa/Douala", + "Africa/El_Aaiun", + "Africa/Freetown", + "Africa/Gaborone", + "Africa/Harare", + "Africa/Johannesburg", + "Africa/Juba", + "Africa/Kampala", + "Africa/Khartoum", + "Africa/Kigali", + "Africa/Kinshasa", + "Africa/Lagos", + "Africa/Libreville", + "Africa/Lome", + "Africa/Luanda", + "Africa/Lubumbashi", + "Africa/Lusaka", + "Africa/Malabo", + "Africa/Maputo", + "Africa/Maseru", + "Africa/Mbabane", + "Africa/Mogadishu", + "Africa/Monrovia", + "Africa/Nairobi", + "Africa/Ndjamena", + "Africa/Niamey", + "Africa/Nouakchott", + "Africa/Ouagadougou", + "Africa/Porto-Novo", + "Africa/Sao_Tome", + "Africa/Timbuktu", + "Africa/Tripoli", + "Africa/Tunis", + "Africa/Windhoek", + "America/Adak", + "America/Anchorage", + "America/Anguilla", + "America/Antigua", + "America/Araguaina", + "America/Argentina/Buenos_Aires", + "America/Argentina/Catamarca", + "America/Argentina/ComodRivadavia", + "America/Argentina/Cordoba", + "America/Argentina/Jujuy", + "America/Argentina/La_Rioja", + "America/Argentina/Mendoza", + "America/Argentina/Rio_Gallegos", + "America/Argentina/Salta", + "America/Argentina/San_Juan", + "America/Argentina/San_Luis", + "America/Argentina/Tucuman", + "America/Argentina/Ushuaia", + "America/Aruba", + "America/Asuncion", + "America/Atikokan", + "America/Atka", + "America/Bahia", + "America/Bahia_Banderas", + "America/Barbados", + "America/Belem", + "America/Belize", + "America/Blanc-Sablon", + "America/Boa_Vista", + "America/Bogota", + "America/Boise", + "America/Buenos_Aires", + "America/Cambridge_Bay", + "America/Campo_Grande", + "America/Cancun", + "America/Caracas", + "America/Catamarca", + "America/Cayenne", + "America/Cayman", + "America/Chicago", + "America/Chihuahua", + "America/Coral_Harbour", + "America/Cordoba", + "America/Costa_Rica", + "America/Creston", + "America/Cuiaba", + "America/Curacao", + "America/Danmarkshavn", + "America/Dawson", + "America/Dawson_Creek", + "America/Denver", + "America/Detroit", + "America/Dominica", + "America/Edmonton", + "America/Eirunepe", + "America/El_Salvador", + "America/Ensenada", + "America/Fort_Nelson", + "America/Fort_Wayne", + "America/Fortaleza", + "America/Glace_Bay", + "America/Godthab", + "America/Goose_Bay", + "America/Grand_Turk", + "America/Grenada", + "America/Guadeloupe", + "America/Guatemala", + "America/Guayaquil", + "America/Guyana", + "America/Halifax", + "America/Havana", + "America/Hermosillo", + "America/Indiana/Indianapolis", + "America/Indiana/Knox", + "America/Indiana/Marengo", + "America/Indiana/Petersburg", + "America/Indiana/Tell_City", + "America/Indiana/Vevay", + "America/Indiana/Vincennes", + "America/Indiana/Winamac", + "America/Indianapolis", + "America/Inuvik", + "America/Iqaluit", + "America/Jamaica", + "America/Jujuy", + "America/Juneau", + "America/Kentucky/Louisville", + "America/Kentucky/Monticello", + "America/Knox_IN", + "America/Kralendijk", + "America/La_Paz", + "America/Lima", + "America/Los_Angeles", + "America/Louisville", + "America/Lower_Princes", + "America/Maceio", + "America/Managua", + "America/Manaus", + "America/Marigot", + "America/Martinique", + "America/Matamoros", + "America/Mazatlan", + "America/Mendoza", + "America/Menominee", + "America/Merida", + "America/Metlakatla", + "America/Mexico_City", + "America/Miquelon", + "America/Moncton", + "America/Monterrey", + "America/Montevideo", + "America/Montreal", + "America/Montserrat", + "America/Nassau", + "America/New_York", + "America/Nipigon", + "America/Nome", + "America/Noronha", + "America/North_Dakota/Beulah", + "America/North_Dakota/Center", + "America/North_Dakota/New_Salem", + "America/Nuuk", + "America/Ojinaga", + "America/Panama", + "America/Pangnirtung", + "America/Paramaribo", + "America/Phoenix", + "America/Port_of_Spain", + "America/Port-au-Prince", + "America/Porto_Acre", + "America/Porto_Velho", + "America/Puerto_Rico", + "America/Punta_Arenas", + "America/Rainy_River", + "America/Rankin_Inlet", + "America/Recife", + "America/Regina", + "America/Resolute", + "America/Rio_Branco", + "America/Rosario", + "America/Santa_Isabel", + "America/Santarem", + "America/Santiago", + "America/Santo_Domingo", + "America/Sao_Paulo", + "America/Scoresbysund", + "America/Shiprock", + "America/Sitka", + "America/St_Barthelemy", + "America/St_Johns", + "America/St_Kitts", + "America/St_Lucia", + "America/St_Thomas", + "America/St_Vincent", + "America/Swift_Current", + "America/Tegucigalpa", + "America/Thule", + "America/Thunder_Bay", + "America/Tijuana", + "America/Toronto", + "America/Tortola", + "America/Vancouver", + "America/Virgin", + "America/Whitehorse", + "America/Winnipeg", + "America/Yakutat", + "America/Yellowknife", + "Antarctica/Casey", + "Antarctica/Davis", + "Antarctica/DumontDUrville", + "Antarctica/Macquarie", + "Antarctica/Mawson", + "Antarctica/McMurdo", + "Antarctica/Palmer", + "Antarctica/Rothera", + "Antarctica/South_Pole", + "Antarctica/Syowa", + "Antarctica/Troll", + "Antarctica/Vostok", + "Arctic/Longyearbyen", + "Asia/Aden", + "Asia/Almaty", + "Asia/Amman", + "Asia/Anadyr", + "Asia/Aqtau", + "Asia/Aqtobe", + "Asia/Ashgabat", + "Asia/Ashkhabad", + "Asia/Atyrau", + "Asia/Baghdad", + "Asia/Bahrain", + "Asia/Baku", + "Asia/Bangkok", + "Asia/Barnaul", + "Asia/Beirut", + "Asia/Bishkek", + "Asia/Brunei", + "Asia/Calcutta", + "Asia/Chita", + "Asia/Choibalsan", + "Asia/Chongqing", + "Asia/Chungking", + "Asia/Colombo", + "Asia/Dacca", + "Asia/Damascus", + "Asia/Dhaka", + "Asia/Dili", + "Asia/Dubai", + "Asia/Dushanbe", + "Asia/Famagusta", + "Asia/Gaza", + "Asia/Harbin", + "Asia/Hebron", + "Asia/Ho_Chi_Minh", + "Asia/Hong_Kong", + "Asia/Hovd", + "Asia/Irkutsk", + "Asia/Istanbul", + "Asia/Jakarta", + "Asia/Jayapura", + "Asia/Jerusalem", + "Asia/Kabul", + "Asia/Kamchatka", + "Asia/Karachi", + "Asia/Kashgar", + "Asia/Kathmandu", + "Asia/Katmandu", + "Asia/Khandyga", + "Asia/Kolkata", + "Asia/Krasnoyarsk", + "Asia/Kuala_Lumpur", + "Asia/Kuching", + "Asia/Kuwait", + "Asia/Macao", + "Asia/Macau", + "Asia/Magadan", + "Asia/Makassar", + "Asia/Manila", + "Asia/Muscat", + "Asia/Nicosia", + "Asia/Novokuznetsk", + "Asia/Novosibirsk", + "Asia/Omsk", + "Asia/Oral", + "Asia/Phnom_Penh", + "Asia/Pontianak", + "Asia/Pyongyang", + "Asia/Qatar", + "Asia/Qostanay", + "Asia/Qyzylorda", + "Asia/Rangoon", + "Asia/Riyadh", + "Asia/Saigon", + "Asia/Sakhalin", + "Asia/Samarkand", + "Asia/Seoul", + "Asia/Shanghai", + "Asia/Singapore", + "Asia/Srednekolymsk", + "Asia/Taipei", + "Asia/Tashkent", + "Asia/Tbilisi", + "Asia/Tehran", + "Asia/Tel_Aviv", + "Asia/Thimbu", + "Asia/Thimphu", + "Asia/Tokyo", + "Asia/Tomsk", + "Asia/Ujung_Pandang", + "Asia/Ulaanbaatar", + "Asia/Ulan_Bator", + "Asia/Urumqi", + "Asia/Ust-Nera", + "Asia/Vientiane", + "Asia/Vladivostok", + "Asia/Yakutsk", + "Asia/Yangon", + "Asia/Yekaterinburg", + "Asia/Yerevan", + "Atlantic/Azores", + "Atlantic/Bermuda", + "Atlantic/Canary", + "Atlantic/Cape_Verde", + "Atlantic/Faeroe", + "Atlantic/Faroe", + "Atlantic/Jan_Mayen", + "Atlantic/Madeira", + "Atlantic/Reykjavik", + "Atlantic/South_Georgia", + "Atlantic/St_Helena", + "Atlantic/Stanley", + "Australia/ACT", + "Australia/Adelaide", + "Australia/Brisbane", + "Australia/Broken_Hill", + "Australia/Canberra", + "Australia/Currie", + "Australia/Darwin", + "Australia/Eucla", + "Australia/Hobart", + "Australia/LHI", + "Australia/Lindeman", + "Australia/Lord_Howe", + "Australia/Melbourne", + "Australia/North", + "Australia/NSW", + "Australia/Perth", + "Australia/Queensland", + "Australia/South", + "Australia/Sydney", + "Australia/Tasmania", + "Australia/Victoria", + "Australia/West", + "Australia/Yancowinna", + "Brazil/Acre", + "Brazil/DeNoronha", + "Brazil/East", + "Brazil/West", + "Canada/Atlantic", + "Canada/Central", + "Canada/Eastern", + "Canada/Mountain", + "Canada/Newfoundland", + "Canada/Pacific", + "Canada/Saskatchewan", + "Canada/Yukon", + "Chile/Continental", + "Chile/EasterIsland", + "Europe/Amsterdam", + "Europe/Andorra", + "Europe/Astrakhan", + "Europe/Athens", + "Europe/Belfast", + "Europe/Belgrade", + "Europe/Berlin", + "Europe/Bratislava", + "Europe/Brussels", + "Europe/Bucharest", + "Europe/Budapest", + "Europe/Busingen", + "Europe/Chisinau", + "Europe/Copenhagen", + "Europe/Dublin", + "Europe/Gibraltar", + "Europe/Guernsey", + "Europe/Helsinki", + "Europe/Isle_of_Man", + "Europe/Istanbul", + "Europe/Jersey", + "Europe/Kaliningrad", + "Europe/Kiev", + "Europe/Kirov", + "Europe/Kyiv", + "Europe/Lisbon", + "Europe/Ljubljana", + "Europe/London", + "Europe/Luxembourg", + "Europe/Madrid", + "Europe/Malta", + "Europe/Mariehamn", + "Europe/Minsk", + "Europe/Monaco", + "Europe/Moscow", + "Europe/Nicosia", + "Europe/Oslo", + "Europe/Paris", + "Europe/Podgorica", + "Europe/Prague", + "Europe/Riga", + "Europe/Rome", + "Europe/Samara", + "Europe/San_Marino", + "Europe/Sarajevo", + "Europe/Saratov", + "Europe/Simferopol", + "Europe/Skopje", + "Europe/Sofia", + "Europe/Stockholm", + "Europe/Tallinn", + "Europe/Tirane", + "Europe/Tiraspol", + "Europe/Ulyanovsk", + "Europe/Uzhgorod", + "Europe/Vaduz", + "Europe/Vatican", + "Europe/Vienna", + "Europe/Vilnius", + "Europe/Volgograd", + "Europe/Warsaw", + "Europe/Zagreb", + "Europe/Zaporozhye", + "Europe/Zurich", + "Indian/Antananarivo", + "Indian/Chagos", + "Indian/Christmas", + "Indian/Cocos", + "Indian/Comoro", + "Indian/Kerguelen", + "Indian/Mahe", + "Indian/Maldives", + "Indian/Mauritius", + "Indian/Mayotte", + "Indian/Reunion", + "Mexico/BajaNorte", + "Mexico/BajaSur", + "Mexico/General", + "Pacific/Apia", + "Pacific/Auckland", + "Pacific/Bougainville", + "Pacific/Chatham", + "Pacific/Chuuk", + "Pacific/Easter", + "Pacific/Efate", + "Pacific/Enderbury", + "Pacific/Fakaofo", + "Pacific/Fiji", + "Pacific/Funafuti", + "Pacific/Galapagos", + "Pacific/Gambier", + "Pacific/Guadalcanal", + "Pacific/Guam", + "Pacific/Honolulu", + "Pacific/Johnston", + "Pacific/Kanton", + "Pacific/Kiritimati", + "Pacific/Kosrae", + "Pacific/Kwajalein", + "Pacific/Majuro", + "Pacific/Marquesas", + "Pacific/Midway", + "Pacific/Nauru", + "Pacific/Niue", + "Pacific/Norfolk", + "Pacific/Noumea", + "Pacific/Pago_Pago", + "Pacific/Palau", + "Pacific/Pitcairn", + "Pacific/Pohnpei", + "Pacific/Ponape", + "Pacific/Port_Moresby", + "Pacific/Rarotonga", + "Pacific/Saipan", + "Pacific/Samoa", + "Pacific/Tahiti", + "Pacific/Tarawa", + "Pacific/Tongatapu", + "Pacific/Truk", + "Pacific/Wake", + "Pacific/Wallis", + "Pacific/Yap", + "US/Alaska", + "US/Aleutian", + "US/Arizona", + "US/Central", + "US/East-Indiana", + "US/Eastern", + "US/Hawaii", + "US/Indiana-Starke", + "US/Michigan", + "US/Mountain", + "US/Pacific", + "US/Samoa" + ] + }, + "model_output_dir": { + "description": "Relative path, with respect to the root of hub, to directory containing model output data. If property not supplied, the default path `model-output` assumed", + "default": "model-output", + "examples": [ + "forecasts", + "data/model_output" + ], + "type": "string" + }, + "cloud": { + "description": "Optional settings for cloud-enabled hubs", + "type": "object", + "properties": { + "enabled": { + "type": "boolean" + }, + "host": { + "type": "object", + "required": [ + "name", + "storage_service", + "storage_location" + ], + "properties": { + "name": { + "description": "Name of the cloud storage provider.", + "type": "string", + "enum": [ + "aws" + ] + }, + "storage_service": { + "description": "Name of the cloud service used as backend storage", + "type": "string", + "enum": [ + "s3" + ] + }, + "storage_location": { + "description": "Cloud storage location, excluding prefix (for example, AWS S3 bucket name).", + "type": "string" + } + } + } + }, + "if": { + "properties": { + "enabled": { + "const": true + } + } + }, + "then": { + "required": [ + "host" + ] + }, + "examples": [ + { + "enabled": true, + "host": { + "name": "aws", + "storage_service": "s3", + "storage_location": "hub-s3-bucket-name" + } + } + ] + } + }, + "required": [ + "schema_version", + "name", + "maintainer", + "contact", + "repository", + "file_format", + "timezone" + ], + "additionalProperties": false +} diff --git a/v4.0.1/tasks-schema.json b/v4.0.1/tasks-schema.json new file mode 100644 index 0000000..cdb7246 --- /dev/null +++ b/v4.0.1/tasks-schema.json @@ -0,0 +1,1540 @@ +{ + "$schema": "https://json-schema.org/draft/2020-12/schema", + "$id": "https://raw.githubusercontent.com/hubverse-org/schemas/main/v4.0.1/tasks-schema.json", + "title": "Schema for Modeling Hub model task definitions", + "description": "This is the schema of the tasks.json configuration file that defines the tasks within a modeling hub.", + "type": "object", + "properties": { + "schema_version": { + "description": "URL to a version of the Modeling Hub schema tasks-schema.json file (see https://github.com/hubverse-org/schemas). Used to declare the schema version a 'tasks.json' file is written for and for config file validation. The URL provided should be the URL to the raw content of the schema file on GitHub.", + "examples": [ + "https://raw.githubusercontent.com/hubverse-org/schemas/main/v3.0.0/tasks-schema.json" + ], + "type": "string", + "format": "uri" + }, + "rounds": { + "description": "Array of modeling round properties", + "type": "array", + "items": { + "type": "object", + "description": "Individual modeling round properties", + "properties": { + "round_id_from_variable": { + "description": "Whether the round identifier is encoded by a task id variable in the data.", + "type": "boolean" + }, + "round_id": { + "description": "Round identifier. If round_id_from_variable = true, round_id should be the name of a task id variable present in all sets of modeling task specifications", + "examples": [ + "round-1", + "2022-11-05", + "origin_date" + ], + "type": "string" + }, + "round_name": { + "description": "An optional round name. This can be useful for internal referencing of rounds, for examples, when a date is used as round_id but hub maintainers and teams also refer to rounds as round-1, round-2 etc.", + "examples": [ + "round-1" + ], + "type": "string" + }, + "model_tasks": { + "type": "array", + "description": "Array defining round-specific modeling tasks. Can contain one or more groups of modeling tasks per round where each group is defined by a distinct combination of values of task id variables.", + "items": { + "type": "object", + "properties": { + "task_ids": { + "description": "Group of valid values of task id variables. A set of valid tasks corresponding to this group is formed by taking all combinations of these values.", + "type": "object", + "properties": { + "origin_date": { + "description": "An object containing arrays of required and optional unique origin dates. Origin date defines the starting point that can be used for calculating a target_date via the formula target_date = origin_date + horizon x time_units_per_horizon (e.g., with weekly data, target_date is calculated as origin_date + horizon x 7 days)", + "examples": [ + { + "required": null, + "optional": [ + "2022-11-05", + "2022-11-12", + "2022-11-19" + ] + } + ], + "type": "object", + "properties": { + "required": { + "description": "Array of origin date unique identifiers that must be present for submission to be valid. Can be null if no origin dates are required and all valid origin dates are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string", + "format": "date" + } + }, + "optional": { + "description": "Array of valid but not required unique origin date identifiers. Can be null if all origin dates are required and are specified in the required property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string", + "format": "date" + } + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + }, + "forecast_date": { + "description": "An object containing arrays of required and optional unique forecast dates. Forecast date usually defines the date that a model is run to produce a forecast.", + "examples": [ + { + "required": null, + "optional": [ + "2022-11-05", + "2022-11-12", + "2022-11-19" + ] + } + ], + "type": "object", + "properties": { + "required": { + "description": "Array of forecast date unique identifiers that must be present for submission to be valid. Can be null if no forecast dates are required and all valid forecast dates are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string", + "format": "date" + } + }, + "optional": { + "description": "Array of valid but not required unique forecast date identifiers. Can be null if all forecast dates are required and are specified in the required property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string", + "format": "date" + } + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + }, + "scenario_id": { + "description": "An object containing arrays of required and optional unique identifiers of each valid scenario.", + "examples": [ + { + "required": null, + "optional": [ + 1, + 2, + 3, + 4 + ] + }, + { + "required": null, + "optional": [ + "A-2021-03-28", + "B-2021-03-28", + "A-2021-04-05", + "B-2021-04-05" + ] + } + ], + "type": "object", + "properties": { + "required": { + "description": "Array of identifiers of scenarios that must be present in a valid submission. Can be null if no scenario ids are required and all valid ids are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": [ + "integer", + "string" + ] + } + }, + "optional": { + "description": "Array of identifiers of valid but not required scenarios. Can be null if all scenarios are required and are specified in the required property.", + "type": [ + "null", + "array" + ], + "uniqueItems": true, + "items": { + "type": [ + "integer", + "string" + ] + } + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + }, + "location": { + "description": "An object containing arrays of required and optional unique identifiers for each valid location, e.g. country codes, FIPS state or county level code etc.", + "examples": [ + { + "required": [ + "US" + ], + "optional": [ + "01", + "02", + "04", + "05", + "06", + "08", + "09", + "10", + "11", + "12", + "13", + "15", + "16", + "17", + "18", + "19", + "20", + "21", + "22", + "23", + "24", + "25", + "26", + "27", + "28", + "29", + "30", + "31", + "32", + "33", + "34", + "35", + "36", + "37", + "38", + "39", + "40", + "41", + "42", + "44", + "45", + "46", + "47", + "48", + "49", + "50", + "51", + "53", + "54", + "55", + "56" + ] + } + ], + "type": "object", + "properties": { + "required": { + "description": "Array of location unique identifiers that must be present for submission to be valid. Can be null if no locations are required and all valid locations are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + }, + "optional": { + "description": "Array of valid but not required unique location identifiers. Can be null if all locations are required and are specified in the required property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + }, + "target": { + "description": "An object containing arrays of required and optional unique identifiers for each valid target. Usually represents a single task ID target key variable.", + "type": "object", + "examples": [ + { + "required": null, + "optional": [ + "inc hosp", + "inc case", + "inc death" + ] + }, + { + "required": [ + "peak week inc hosp" + ], + "optional": null + } + ], + "properties": { + "required": { + "description": "Array of target unique identifiers that must be present for submission to be valid. Can be null if no targets are required and all valid targets are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + }, + "optional": { + "description": "Array of valid but not required unique target identifiers. Can be null if all targets are required and are specified in the required property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + }, + "target_variable": { + "description": "An object containing arrays of required and optional unique identifiers for each valid target variable. Usually forms part of a pair of task ID target key variables (along with target_outcome) which combine to define individual targets.", + "type": "object", + "examples": [ + { + "required": null, + "optional": [ + "hosp", + "death", + "case" + ] + }, + { + "required": [ + "hosp" + ], + "optional": [ + "case" + ] + } + ], + "properties": { + "required": { + "description": "Array of target variable unique identifiers that must be present for submission to be valid. Can be null if no target variables are required and all valid target variables are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + }, + "optional": { + "description": "Array of valid but not required unique target variable identifiers. Can be null if all target variables are required and are specified in the required property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + }, + "target_outcome": { + "description": "An object containing arrays of required and optional unique identifiers for each valid target outcome. Usually forms part of a pair of task ID target key variables (along with target_variable) which combine to define individual targets.", + "type": "object", + "examples": [ + { + "required": [ + "inc" + ], + "optional": null + }, + { + "required": [ + "inc" + ], + "optional": [ + "cum" + ] + } + ], + "properties": { + "required": { + "description": "Array of target outcome unique identifiers that must be present for submission to be valid. Can be null if no target outcomes are required and all valid target outcomes are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + }, + "optional": { + "description": "Array of valid but not required unique target outcome identifiers. Can be null if all target outcomes are required and are specified in the required property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + }, + "target_date": { + "description": "An object containing arrays of required and optional unique target dates. For short-term forecasts, the target_date specifies the date of occurrence of the outcome of interest. For instance, if models are requested to forecast the number of hospitalizations that will occur on 2022-07-15, the target_date is 2022-07-15", + "examples": [ + { + "required": null, + "optional": [ + "2022-11-12", + "2022-11-19", + "2022-11-26" + ] + } + ], + "type": "object", + "properties": { + "required": { + "description": "Array of target date unique identifiers that must be present for submission to be valid. Can be null if no target dates are required and all valid target dates are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string", + "format": "date" + } + }, + "optional": { + "description": "Array of valid but not required unique target date identifiers. Can be null if all target dates are required and are specified in the required property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string", + "format": "date" + } + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + }, + "target_end_date": { + "description": "An object containing arrays of required and optional unique target end dates. For short-term forecasts, the target_end_date specifies the date of occurrence of the outcome of interest. For instance, if models are requested to forecast the number of hospitalizations that will occur on 2022-07-15, the target_end_date is 2022-07-15", + "examples": [ + { + "required": null, + "optional": [ + "2022-11-12", + "2022-11-19", + "2022-11-26" + ] + } + ], + "type": "object", + "properties": { + "required": { + "description": "Array of target end date unique identifiers that must be present for submission to be valid. Can be null if no target end dates are required and all valid target end dates are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string", + "format": "date" + } + }, + "optional": { + "description": "Array of valid but not required unique target end date identifiers. Can be null if all target end dates are required and are specified in the required property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string", + "format": "date" + } + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + }, + "horizon": { + "description": "An object containing arrays of required and optional unique horizons. Horizons define the difference between the target_date and the origin_date in time units specified by the hub (e.g., may be days, weeks, or months)", + "examples": [ + { + "required": null, + "optional": [ + 1, + 2, + 3, + 4 + ] + } + ], + "type": "object", + "properties": { + "required": { + "description": "Array of horizon unique identifiers that must be present for submission to be valid. Can be null if no horizons are required and all valid horizons are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": [ + "integer", + "string" + ] + } + }, + "optional": { + "description": "Array of valid but not required unique horizon identifiers. Can be null if all horizons are required and are specified in the required property.", + "type": [ + "null", + "array" + ], + "uniqueItems": true, + "items": { + "type": [ + "integer", + "string" + ] + } + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + }, + "age_group": { + "type": "object", + "description": "An object containing arrays of required and optional unique identifiers for age groups", + "examples": [ + { + "required": [ + "0-5", + "6-18", + "19-24", + "25-64", + "65+" + ], + "optional": null + } + ], + "properties": { + "required": { + "description": "Array of age group unique identifiers that must be present for submission to be valid. Can be null if no age groups are required and all valid age groups are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + }, + "optional": { + "description": "Array of valid but not required unique age group identifiers. Can be null if all age group are required and are specified in the required property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + } + }, + "additionalProperties": { + "type": "object", + "description": "An object containing arrays of required and optional unique values for a custom Task ID", + "properties": { + "required": { + "description": "Array of custom Task ID unique values that must be present for submission to be valid. Can be null if no values are required and all valid values are specified in the optional property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true + }, + "optional": { + "description": "Array of valid but not required unique custom Task ID values. Can be null if all values are required and are specified in the required property.", + "type": [ + "array", + "null" + ], + "uniqueItems": true + } + }, + "required": [ + "required", + "optional" + ], + "additionalProperties": false + } + }, + "output_type": { + "type": "object", + "description": "Object defining valid model output types for a given modeling task. The name of each property corresponds to valid values in column 'output_type' while the 'output_type_id' property of each output type defines the valid values of the 'output_type_id' column and the 'value' property defines the valid values of the 'value' column for a given output type.", + "properties": { + "mean": { + "type": "object", + "description": "Object defining the mean of the predictive distribution output type.", + "properties": { + "output_type_id": { + "description": "output_type_id is not meaningful for a point estimate output_type. Must have a single property named 'required' with the value null.", + "examples": [ + { + "required": null + } + ], + "type": "object", + "properties": { + "required": { + "description": "Not relevant for point estimate output types. Must be null.", + "type": "null" + } + }, + "required": [ + "required" + ], + "additionalProperties": false + }, + "value": { + "type": "object", + "description": "Object defining the characteristics of valid mean values.", + "examples": [ + { + "type": "double", + "minimum": 0 + } + ], + "properties": { + "type": { + "description": "Data type of mean values.", + "type": "string", + "enum": [ + "double", + "integer" + ] + }, + "minimum": { + "description": "The minimum inclusive valid mean value", + "type": [ + "number", + "integer" + ] + }, + "maximum": { + "description": "the maximum inclusive valid mean value", + "type": [ + "number", + "integer" + ] + } + }, + "required": [ + "type" + ], + "additionalProperties": false + }, + "is_required": { + "description": "Is output type required? When required, property should be set to 'true'. If output type is optional, set to 'false'.", + "examples": [ + { + "is_required": true + }, + { + "is_required": false + } + ], + "type": "boolean" + } + }, + "required": [ + "output_type_id", + "value", + "is_required" + ], + "additionalProperties": false + }, + "median": { + "type": "object", + "description": "Object defining the median of the predictive distribution output type", + "properties": { + "output_type_id": { + "description": "output_type_id is not meaningful for a point estimate output_type. Must have a single property named 'required' with the value null.", + "examples": [ + { + "required": null + } + ], + "type": "object", + "properties": { + "required": { + "description": "Not relevant for point estimate output types. Must be null.", + "type": "null" + } + }, + "required": [ + "required" + ], + "additionalProperties": false + }, + "value": { + "type": "object", + "description": "Object defining the characteristics of valid median values.", + "examples": [ + { + "type": "double", + "minimum": 0 + } + ], + "properties": { + "type": { + "description": "Data type of median values.", + "type": "string", + "enum": [ + "double", + "integer" + ] + }, + "minimum": { + "description": "The minimum inclusive valid median value", + "type": [ + "number", + "integer" + ] + }, + "maximum": { + "description": "the maximum inclusive valid median value", + "type": [ + "number", + "integer" + ] + } + }, + "required": [ + "type" + ], + "additionalProperties": false + }, + "is_required": { + "description": "Is output type required? When required, property should be set to 'true'. If output type is optional, set to 'false'.", + "examples": [ + { + "is_required": true + }, + { + "is_required": false + } + ], + "type": "boolean" + } + }, + "required": [ + "output_type_id", + "value", + "is_required" + ], + "additionalProperties": false + }, + "quantile": { + "description": "Object defining the quantiles of the predictive distribution output type.", + "type": "object", + "properties": { + "output_type_id": { + "description": "Object containing arrays of required probability levels at which quantiles of the predictive distribution will be recorded.", + "examples": [ + { + "required": [ + 0.1, + 0.2, + 0.25, + 0.3, + 0.4, + 0.5, + 0.6, + 0.7, + 0.75, + 0.8, + 0.9 + ] + } + ], + "type": "object", + "properties": { + "required": { + "description": "Array of unique probability levels between 0 and 1 inclusive that must be present for submission to be valid.", + "type": "array", + "uniqueItems": true, + "items": { + "type": "number", + "minimum": 0, + "maximum": 1 + } + } + }, + "required": [ + "required" + ], + "additionalProperties": false + }, + "value": { + "type": "object", + "description": "Object defining the characteristics of valid quantiles of the predictive distribution at a given probability level.", + "properties": { + "type": { + "description": "Data type of quantile values.", + "examples": [ + "double" + ], + "type": "string", + "enum": [ + "double", + "integer" + ] + }, + "minimum": { + "description": "The minimum inclusive valid quantile value (optional).", + "examples": [ + 0 + ], + "type": [ + "number", + "integer" + ] + }, + "maximum": { + "description": "The maximum inclusive valid quantile value (optional).", + "type": [ + "number", + "integer" + ] + } + }, + "required": [ + "type" + ], + "additionalProperties": false + }, + "is_required": { + "description": "Is output type required? When required, property should be set to 'true'. If output type is optional, set to 'false'.", + "examples": [ + { + "is_required": true + }, + { + "is_required": false + } + ], + "type": "boolean" + } + }, + "required": [ + "output_type_id", + "value", + "is_required" + ], + "additionalProperties": false + }, + "cdf": { + "description": "Object defining the cumulative distribution function of the predictive distribution output type.", + "type": "object", + "properties": { + "output_type_id": { + "description": "Object containing required arrays defining possible values of the target variable at which values of the cumulative distribution function of the predictive distribution will be recorded. These should be listed in order from low to high.", + "examples": [ + { + "required": [ + 10, + 20 + ] + }, + { + "required": [ + "EW202240", + "EW202241", + "EW202242", + "EW202243", + "EW202244", + "EW202245", + "EW202246", + "EW202247" + ] + } + ], + "type": "object", + "properties": { + "required": { + "description": "Array of unique target values that must be present for submission to be valid.", + "type": "array", + "uniqueItems": true, + "items": { + "oneOf": [ + { + "type": [ + "number", + "integer" + ] + }, + { + "type": "string" + } + ] + } + } + }, + "required": [ + "required" + ], + "additionalProperties": false + }, + "value": { + "type": "object", + "description": "Object defining the characteristics of valid values of the cumulative distribution function at a given target value.", + "properties": { + "type": { + "description": "Data type of cumulative distribution function values.", + "examples": [ + "double" + ], + "const": "double" + }, + "minimum": { + "description": "The minimum inclusive valid cumulative distribution function value. Must be 0.", + "const": 0 + }, + "maximum": { + "description": "The maximum inclusive valid cumulative distribution function value. Must be 1.", + "const": 1 + } + }, + "required": [ + "type", + "minimum", + "maximum" + ], + "additionalProperties": false + }, + "is_required": { + "description": "Is output type required? When required, property should be set to 'true'. If output type is optional, set to 'false'.", + "examples": [ + { + "is_required": true + }, + { + "is_required": false + } + ], + "type": "boolean" + } + }, + "required": [ + "output_type_id", + "value", + "is_required" + ], + "additionalProperties": false + }, + "pmf": { + "description": "Object defining a probability mass function for a discrete variable output type. Includes nominal, binary and ordinal variable types.", + "type": "object", + "properties": { + "output_type_id": { + "description": "Object containing arrays of required values specifying valid categories of a discrete variable. Note that for ordinal variables, the category levels should be listed in order from low to high.", + "examples": [ + { + "required": [ + "low", + "moderate", + "high", + "extreme" + ] + } + ], + "type": "object", + "properties": { + "required": { + "description": "Array of unique categories of a discrete variable that must be present for submission to be valid.", + "type": "array", + "uniqueItems": true, + "items": { + "type": "string" + } + } + }, + "required": [ + "required" + ], + "additionalProperties": false + }, + "value": { + "type": "object", + "description": "Object defining valid values of the probability mass function of the predictive distribution for a given category of a discrete outcome variable.", + "examples": [ + { + "type": "double", + "minimum": 0, + "maximum": 1 + } + ], + "properties": { + "type": { + "description": "Data type of the probability mass function values.", + "const": "double" + }, + "minimum": { + "description": "The minimum inclusive valid probability mass function value. Must be 0.", + "const": 0 + }, + "maximum": { + "description": "The maximum inclusive valid probability mass function value. Must be 1.", + "const": 1 + } + }, + "required": [ + "type", + "minimum", + "maximum" + ], + "additionalProperties": false + }, + "is_required": { + "description": "Is output type required? When required, property should be set to 'true'. If output type is optional, set to 'false'.", + "examples": [ + { + "is_required": true + }, + { + "is_required": false + } + ], + "type": "boolean" + } + }, + "required": [ + "output_type_id", + "value", + "is_required" + ], + "additionalProperties": false + }, + "sample": { + "description": "Object defining a sample output type.", + "type": "object", + "properties": { + "output_type_id_params": { + "description": "Object containing parameters specifying how samples were drawn.", + "examples": [ + { + "output_type_id_params": { + "type": "integer", + "min_samples_per_task": 100, + "max_samples_per_task": 100 + } + }, + { + "output_type_id_params": { + "type": "character", + "max_length": 6, + "min_samples_per_task": 100, + "max_samples_per_task": 500, + "compound_taskid_set": [ + "origin_date", + "horizon", + "location", + "variant" + ] + } + } + ], + "type": "object", + "properties": { + "type": { + "description": "Data type of sample indices.", + "type": "string", + "enum": [ + "character", + "integer" + ] + }, + "max_length": { + "description": "Required only if 'type' is 'character'. Positive integer representing the maximum number of characters in a sample index. Ignored if 'type' is 'integer'.", + "type": "integer", + "minimum": 1 + }, + "min_samples_per_task": { + "description": "The minimum number of samples per individual task.", + "type": "integer", + "minimum": 1 + }, + "max_samples_per_task": { + "description": "The maximum number of samples per individual task.", + "type": "integer", + "minimum": 1 + }, + "compound_taskid_set": { + "description": "Optional. Specifies whether validation should factor in the presence of a compound modeling task. Each item of the array must be a task id variable name. If unspecified, defaults to all task ID variables.", + "type": [ + "array" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + } + }, + "required": [ + "type", + "min_samples_per_task", + "max_samples_per_task" + ], + "if": { + "properties": { + "type": { + "const": "character" + } + } + }, + "then": { + "required": [ + "max_length" + ] + }, + "additionalProperties": false + }, + "value": { + "type": "object", + "description": "Object defining valid values of samples from the predictive distribution for a given sample index. Depending on the Hub specification, samples with the same sample index (specified by the output_type_id) may be assumed to correspond to a joint distribution across multiple levels of the task id variables. See Hub documentation for details.", + "properties": { + "type": { + "description": "Data type of sample value from the predictive distribution.", + "examples": [ + { + "type": "double" + } + ], + "type": "string", + "enum": [ + "double", + "integer" + ] + }, + "minimum": { + "description": "The minimum inclusive valid sample value from the predictive distribution.", + "type": [ + "number", + "integer" + ] + }, + "maximum": { + "description": "The maximum inclusive valid sample value from the predictive distribution.", + "type": [ + "number", + "integer" + ] + } + }, + "required": [ + "type" + ], + "additionalProperties": false + }, + "is_required": { + "description": "Is output type required? When required, property should be set to 'true'. If output type is optional, set to 'false'.", + "examples": [ + { + "is_required": true + }, + { + "is_required": false + } + ], + "type": "boolean" + } + }, + "required": [ + "output_type_id_params", + "value", + "is_required" + ], + "additionalProperties": false + } + }, + "additionalProperties": false + }, + "target_metadata": { + "description": "Array of objects containing metadata about each unique target, one object for each unique target value.", + "type": "array", + "items": { + "type": "object", + "description": "Object containg metadata about a single unique target.", + "properties": { + "target_id": { + "description": "Short description that uniquely identifies the target.", + "examples": [ + "inc hosp", + "peak week hosp" + ], + "type": "string", + "maxLength": 30 + }, + "target_name": { + "description": "A longer human readable target description that could be used, for example, as a visualisation axis label.", + "examples": [ + "Weekly incident influenza hospitalizations", + "Peak week for incident influenza hospitalizations" + ], + "type": "string", + "maxLength": 100 + }, + "target_units": { + "description": "Unit of observation of the target.", + "examples": [ + "rate per 100,000 population", + "count", + "date" + ], + "type": "string", + "maxLength": 100 + }, + "target_keys": { + "description": "Should be either null, in the case where the target is not specified as a task_id and is specified solely through the target_id target_metadata property or an object with one or more properties, the names of which match task_id variable(s) named within the same model_tasks object. Each property should have one specified value. Each value, or the combination of values if multiple keys are specified, define a single target value.", + "examples": [ + { + "target": "inc hosp" + }, + { + "target": "peak week hosp" + }, + { + "target_variable": "hosp", + "target_outcome": "inc" + }, + { + "target_variable": "case", + "target_outcome": "peak week" + }, + null + ], + "type": [ + "object", + "null" + ], + "additionalProperties": { + "type": "string" + } + }, + "description": { + "description": "a verbose description of the target that might include information such as the target_measure above, or definitions of a 'rate' or similar.", + "type": "string" + }, + "target_type": { + "description": "Target statistical data type", + "examples": [ + "discrete", + "ordinal" + ], + "type": "string", + "enum": [ + "continuous", + "discrete", + "date", + "binary", + "nominal", + "ordinal", + "compositional" + ] + }, + "is_step_ahead": { + "description": "Whether the target is part of a sequence of values", + "examples": [ + true, + false + ], + "type": "boolean" + }, + "time_unit": { + "description": " if is_step_ahead is true, then this is required and defines the unit of time steps. if is_step_ahead is false, then this should be left out and/or will be ignored if present.", + "examples": [ + "week" + ], + "type": "string", + "enum": [ + "day", + "week", + "month" + ] + } + }, + "required": [ + "target_id", + "target_name", + "target_units", + "target_type", + "target_keys", + "is_step_ahead" + ], + "additionalProperties": false, + "if": { + "properties": { + "is_step_ahead": { + "const": true + } + } + }, + "then": { + "required": [ + "time_unit" + ] + } + } + } + }, + "required": [ + "task_ids", + "output_type", + "target_metadata" + ], + "additionalProperties": false + } + }, + "submissions_due": { + "description": "Object defining the dates by which model forecasts must be submitted to the hub.", + "examples": [ + { + "start": "2022-06-07", + "end": "2022-07-20" + }, + { + "relative_to": "origin_date", + "start": -4, + "end": 2 + } + ], + "type": "object", + "oneOf": [ + { + "properties": { + "relative_to": { + "description": "Name of task id variable in relation to which submission start and end dates are calculated.", + "type": "string" + }, + "start": { + "description": "Difference in days between start and origin date.", + "type": "integer" + }, + "end": { + "description": "Difference in days between end and origin date.", + "type": "integer" + } + }, + "required": [ + "relative_to", + "start", + "end" + ], + "additionalProperties": false + }, + { + "properties": { + "start": { + "description": "Submission start date.", + "type": "string", + "format": "date" + }, + "end": { + "description": "Submission end date.", + "type": "string", + "format": "date" + } + }, + "required": [ + "start", + "end" + ], + "additionalProperties": false + } + ], + "required": [ + "start", + "end" + ] + }, + "last_data_date": { + "description": "The last date with recorded data in the data set used as input to a model.", + "examples": [ + "2022-07-18" + ], + "type": "string", + "format": "date" + }, + "file_format": { + "description": "Accepted file formats of model output files for the round. Overrides the file formats provided in admin.json.", + "examples": [ + [ + "arrow", + "parquet" + ], + [ + "csv" + ] + ], + "type": "array", + "items": { + "type": "string", + "enum": [ + "csv", + "parquet", + "arrow" + ] + } + }, + "derived_task_ids": { + "description": "Names of derived task IDs, i.e. task IDs whose values are derived from (and therefore dependent on) the values of other variables. Use this property to override the global setting for a specific round.", + "examples": [ + [ + "target_end_date" + ] + ], + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + } + }, + "required": [ + "round_id_from_variable", + "round_id", + "model_tasks", + "submissions_due" + ], + "additionalProperties": true + } + }, + "output_type_id_datatype": { + "description": "The hub level data type of the output_type_id column. This data type must be shared across all files in the hub and be able to represent all output type ID values across all hub output types and rounds. If not provided or set to 'auto', hub defaults to autodetecting the simplest hub level data type.", + "default": "auto", + "examples": [ + "character" + ], + "type": "string", + "enum": [ + "auto", + "character", + "double", + "integer", + "logical", + "Date" + ] + }, + "derived_task_ids": { + "description": "Names of derived task IDs, i.e. task IDs whose values are derived from (and therefore dependent on) the values of other variables.", + "examples": [ + [ + "target_end_date" + ] + ], + "type": [ + "array", + "null" + ], + "uniqueItems": true, + "items": { + "type": "string" + } + } + }, + "required": [ + "rounds", + "schema_version" + ], + "additionalProperties": false +} From 24ea8425f2197ba751c593d0952a8fdc6f0a8fa8 Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Fri, 13 Dec 2024 12:15:51 +0200 Subject: [PATCH 02/12] Add conditional round_id regex pattern. Resolves #112 --- v4.0.1/tasks-schema.json | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/v4.0.1/tasks-schema.json b/v4.0.1/tasks-schema.json index cdb7246..0554df0 100644 --- a/v4.0.1/tasks-schema.json +++ b/v4.0.1/tasks-schema.json @@ -27,7 +27,7 @@ "round_id": { "description": "Round identifier. If round_id_from_variable = true, round_id should be the name of a task id variable present in all sets of modeling task specifications", "examples": [ - "round-1", + "round_1", "2022-11-05", "origin_date" ], @@ -36,7 +36,7 @@ "round_name": { "description": "An optional round name. This can be useful for internal referencing of rounds, for examples, when a date is used as round_id but hub maintainers and teams also refer to rounds as round-1, round-2 etc.", "examples": [ - "round-1" + "round 1" ], "type": "string" }, @@ -1490,6 +1490,20 @@ } } }, + "if": { + "properties": { + "round_id_from_variable": { + "const": "false" + } + } + }, + "then": { + "properties": { + "round_id": { + "pattern": "^([0-9]{4}-[0-9]{2}-[0-9]{2})|[A-Za-z0-9_]+$" + } + } + }, "required": [ "round_id_from_variable", "round_id", From 97642f02e0c10d602e3499282a19200b976fb6e1 Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Fri, 13 Dec 2024 14:00:43 +0200 Subject: [PATCH 03/12] correct pattern --- v4.0.1/tasks-schema.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/v4.0.1/tasks-schema.json b/v4.0.1/tasks-schema.json index 0554df0..81368e4 100644 --- a/v4.0.1/tasks-schema.json +++ b/v4.0.1/tasks-schema.json @@ -1500,7 +1500,7 @@ "then": { "properties": { "round_id": { - "pattern": "^([0-9]{4}-[0-9]{2}-[0-9]{2})|[A-Za-z0-9_]+$" + "pattern": "^([0-9]{4}-[0-9]{2}-[0-9]{2})$|^[A-Za-z0-9_]+$" } } }, From 205ed385eaf10cabd337fc6402565da5231cf0c0 Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Fri, 13 Dec 2024 14:38:20 +0200 Subject: [PATCH 04/12] fix condition --- v4.0.1/tasks-schema.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/v4.0.1/tasks-schema.json b/v4.0.1/tasks-schema.json index 81368e4..f0dd500 100644 --- a/v4.0.1/tasks-schema.json +++ b/v4.0.1/tasks-schema.json @@ -1493,7 +1493,7 @@ "if": { "properties": { "round_id_from_variable": { - "const": "false" + "const": false } } }, From 0bd2967240206fc362438ecc1346fcb608922558 Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Fri, 13 Dec 2024 15:46:26 +0200 Subject: [PATCH 05/12] add if statement custom error message --- v4.0.1/tasks-schema.json | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/v4.0.1/tasks-schema.json b/v4.0.1/tasks-schema.json index f0dd500..7a46aab 100644 --- a/v4.0.1/tasks-schema.json +++ b/v4.0.1/tasks-schema.json @@ -1502,6 +1502,10 @@ "round_id": { "pattern": "^([0-9]{4}-[0-9]{2}-[0-9]{2})$|^[A-Za-z0-9_]+$" } + }, + "errorMessage": { + "properties": { + "round_id": "must match either an ISO date format (YYYY-MM-DD) or alphanumeric characters separated by underscores."} } }, "required": [ From ea42005f0cbccc7367375a2a1debc2ef5996f0ad Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Fri, 13 Dec 2024 15:53:08 +0200 Subject: [PATCH 06/12] move error message --- v4.0.1/tasks-schema.json | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/v4.0.1/tasks-schema.json b/v4.0.1/tasks-schema.json index 7a46aab..5feb84a 100644 --- a/v4.0.1/tasks-schema.json +++ b/v4.0.1/tasks-schema.json @@ -1500,12 +1500,9 @@ "then": { "properties": { "round_id": { - "pattern": "^([0-9]{4}-[0-9]{2}-[0-9]{2})$|^[A-Za-z0-9_]+$" + "pattern": "^([0-9]{4}-[0-9]{2}-[0-9]{2})$|^[A-Za-z0-9_]+$", + "errorMessage": "The 'round_id' must match either an ISO date format (YYYY-MM-DD) or alphanumeric characters with underscores." } - }, - "errorMessage": { - "properties": { - "round_id": "must match either an ISO date format (YYYY-MM-DD) or alphanumeric characters separated by underscores."} } }, "required": [ From c608a8b4a7c487368bb03e7dd221b98aafb2e906 Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Fri, 13 Dec 2024 15:53:40 +0200 Subject: [PATCH 07/12] error msg edit --- v4.0.1/tasks-schema.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/v4.0.1/tasks-schema.json b/v4.0.1/tasks-schema.json index 5feb84a..feab874 100644 --- a/v4.0.1/tasks-schema.json +++ b/v4.0.1/tasks-schema.json @@ -1501,7 +1501,7 @@ "properties": { "round_id": { "pattern": "^([0-9]{4}-[0-9]{2}-[0-9]{2})$|^[A-Za-z0-9_]+$", - "errorMessage": "The 'round_id' must match either an ISO date format (YYYY-MM-DD) or alphanumeric characters with underscores." + "errorMessage": "The 'round_id' must match either an ISO date format (YYYY-MM-DD) or alphanumeric characters separated by underscores." } } }, From 1720bb763adbe3be1b6d75e91cc6856e16659901 Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Tue, 17 Dec 2024 15:14:04 +0200 Subject: [PATCH 08/12] Update NEWS.md --- NEWS.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/NEWS.md b/NEWS.md index 843bf81..4d58a94 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,3 +1,9 @@ +# v4.0.1 + +This release contains the following non-breaking changes: + +* Added explicit checks of `round_id` format through a regex `pattern` check to the `round.round_id` property when `round.round_id_from_variable` is `false`. This provides upfront validation of the expected format of manual round IDs (i.e. those not source from a task ID). + # v4.0.0 * BREAKING CHANGE: Introduction of `is_required` boolean property at the `output_type` level to configure whether the output type is required for submissions to be considered valid (#99). From 43b2c8aceb3a316b7a1929dbe8d8ead2711d4e84 Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Tue, 17 Dec 2024 15:14:53 +0200 Subject: [PATCH 09/12] Add issue number to NEWS item --- NEWS.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/NEWS.md b/NEWS.md index 4d58a94..a6e88c9 100644 --- a/NEWS.md +++ b/NEWS.md @@ -2,7 +2,7 @@ This release contains the following non-breaking changes: -* Added explicit checks of `round_id` format through a regex `pattern` check to the `round.round_id` property when `round.round_id_from_variable` is `false`. This provides upfront validation of the expected format of manual round IDs (i.e. those not source from a task ID). +* Added explicit checks of `round_id` format through a regex `pattern` check to the `round.round_id` property when `round.round_id_from_variable` is `false`. This provides upfront validation of the expected format of manual round IDs (i.e. those not source from a task ID) (#112). # v4.0.0 From 0afa40e5ba3c628182638d1f76ed28008c7a6b7a Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Tue, 17 Dec 2024 15:27:57 +0200 Subject: [PATCH 10/12] Restricted the `target_keys` object to contain only a single key value pair. Resolves #117 --- NEWS.md | 1 + v4.0.1/tasks-schema.json | 10 ++-------- 2 files changed, 3 insertions(+), 8 deletions(-) diff --git a/NEWS.md b/NEWS.md index a6e88c9..e43dc2e 100644 --- a/NEWS.md +++ b/NEWS.md @@ -3,6 +3,7 @@ This release contains the following non-breaking changes: * Added explicit checks of `round_id` format through a regex `pattern` check to the `round.round_id` property when `round.round_id_from_variable` is `false`. This provides upfront validation of the expected format of manual round IDs (i.e. those not source from a task ID) (#112). +* Restricted the `target_keys` object to contain only a single key value pair (if not `null`). This means that target keys can now only consist of a single value from a single task ID (#117). # v4.0.0 diff --git a/v4.0.1/tasks-schema.json b/v4.0.1/tasks-schema.json index feab874..0ecd9f3 100644 --- a/v4.0.1/tasks-schema.json +++ b/v4.0.1/tasks-schema.json @@ -1290,20 +1290,14 @@ { "target": "peak week hosp" }, - { - "target_variable": "hosp", - "target_outcome": "inc" - }, - { - "target_variable": "case", - "target_outcome": "peak week" - }, null ], "type": [ "object", "null" ], + "minProperties": 1, + "maxProperties": 1, "additionalProperties": { "type": "string" } From 29e85983a0be6ca4730a7e5fe938b3e10c496c12 Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Fri, 17 Jan 2025 10:38:34 +0200 Subject: [PATCH 11/12] Change version to v5.0.0 to signify breaking target_keys change --- NEWS.md | 4 ++-- {v4.0.1 => v5.0.0}/admin-schema.json | 2 +- {v4.0.1 => v5.0.0}/tasks-schema.json | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) rename {v4.0.1 => v5.0.0}/admin-schema.json (99%) rename {v4.0.1 => v5.0.0}/tasks-schema.json (99%) diff --git a/NEWS.md b/NEWS.md index e43dc2e..829e0e7 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,9 +1,9 @@ -# v4.0.1 +# v5.0.0 This release contains the following non-breaking changes: * Added explicit checks of `round_id` format through a regex `pattern` check to the `round.round_id` property when `round.round_id_from_variable` is `false`. This provides upfront validation of the expected format of manual round IDs (i.e. those not source from a task ID) (#112). -* Restricted the `target_keys` object to contain only a single key value pair (if not `null`). This means that target keys can now only consist of a single value from a single task ID (#117). +* BREAKING CHANGE: Restricted the `target_keys` object to contain only a single key value pair (if not `null`). This means that target keys can now only consist of a single value from a single task ID (#117). # v4.0.0 diff --git a/v4.0.1/admin-schema.json b/v5.0.0/admin-schema.json similarity index 99% rename from v4.0.1/admin-schema.json rename to v5.0.0/admin-schema.json index 7e9e57b..4c92e77 100644 --- a/v4.0.1/admin-schema.json +++ b/v5.0.0/admin-schema.json @@ -1,6 +1,6 @@ { "$schema": "https://json-schema.org/draft/2020-12/schema", - "$id": "https://raw.githubusercontent.com/hubverse-org/schemas/main/v4.0.1/admin-schema.json", + "$id": "https://raw.githubusercontent.com/hubverse-org/schemas/main/v5.0.0/admin-schema.json", "title": "Schema for Modeling Hub administrative settings", "description": "This JSON file provides a schema for modeling hub administrative information.", "type": "object", diff --git a/v4.0.1/tasks-schema.json b/v5.0.0/tasks-schema.json similarity index 99% rename from v4.0.1/tasks-schema.json rename to v5.0.0/tasks-schema.json index 0ecd9f3..26a57f2 100644 --- a/v4.0.1/tasks-schema.json +++ b/v5.0.0/tasks-schema.json @@ -1,6 +1,6 @@ { "$schema": "https://json-schema.org/draft/2020-12/schema", - "$id": "https://raw.githubusercontent.com/hubverse-org/schemas/main/v4.0.1/tasks-schema.json", + "$id": "https://raw.githubusercontent.com/hubverse-org/schemas/main/v5.0.0/tasks-schema.json", "title": "Schema for Modeling Hub model task definitions", "description": "This is the schema of the tasks.json configuration file that defines the tasks within a modeling hub.", "type": "object", From 54c8c3e525b4b4bc36b0fc2af5cd32dbc98c3f05 Mon Sep 17 00:00:00 2001 From: Anna Krystalli Date: Fri, 17 Jan 2025 10:39:21 +0200 Subject: [PATCH 12/12] Remove target_variable and target_outcome from std task ids --- v5.0.0/tasks-schema.json | 100 --------------------------------------- 1 file changed, 100 deletions(-) diff --git a/v5.0.0/tasks-schema.json b/v5.0.0/tasks-schema.json index 26a57f2..5f1cf3f 100644 --- a/v5.0.0/tasks-schema.json +++ b/v5.0.0/tasks-schema.json @@ -341,106 +341,6 @@ ], "additionalProperties": false }, - "target_variable": { - "description": "An object containing arrays of required and optional unique identifiers for each valid target variable. Usually forms part of a pair of task ID target key variables (along with target_outcome) which combine to define individual targets.", - "type": "object", - "examples": [ - { - "required": null, - "optional": [ - "hosp", - "death", - "case" - ] - }, - { - "required": [ - "hosp" - ], - "optional": [ - "case" - ] - } - ], - "properties": { - "required": { - "description": "Array of target variable unique identifiers that must be present for submission to be valid. Can be null if no target variables are required and all valid target variables are specified in the optional property.", - "type": [ - "array", - "null" - ], - "uniqueItems": true, - "items": { - "type": "string" - } - }, - "optional": { - "description": "Array of valid but not required unique target variable identifiers. Can be null if all target variables are required and are specified in the required property.", - "type": [ - "array", - "null" - ], - "uniqueItems": true, - "items": { - "type": "string" - } - } - }, - "required": [ - "required", - "optional" - ], - "additionalProperties": false - }, - "target_outcome": { - "description": "An object containing arrays of required and optional unique identifiers for each valid target outcome. Usually forms part of a pair of task ID target key variables (along with target_variable) which combine to define individual targets.", - "type": "object", - "examples": [ - { - "required": [ - "inc" - ], - "optional": null - }, - { - "required": [ - "inc" - ], - "optional": [ - "cum" - ] - } - ], - "properties": { - "required": { - "description": "Array of target outcome unique identifiers that must be present for submission to be valid. Can be null if no target outcomes are required and all valid target outcomes are specified in the optional property.", - "type": [ - "array", - "null" - ], - "uniqueItems": true, - "items": { - "type": "string" - } - }, - "optional": { - "description": "Array of valid but not required unique target outcome identifiers. Can be null if all target outcomes are required and are specified in the required property.", - "type": [ - "array", - "null" - ], - "uniqueItems": true, - "items": { - "type": "string" - } - } - }, - "required": [ - "required", - "optional" - ], - "additionalProperties": false - }, "target_date": { "description": "An object containing arrays of required and optional unique target dates. For short-term forecasts, the target_date specifies the date of occurrence of the outcome of interest. For instance, if models are requested to forecast the number of hospitalizations that will occur on 2022-07-15, the target_date is 2022-07-15", "examples": [