Introduction

This is the Somalia April Sorghum forecast report from the GB model. The goal is to assist users in evaluating current forecasts in the context of past forecasts and to translate the forecast component into key assumptions about food security.

The report includes the following key components:

  1. A verbal summary of assumptions based on the statistics in this forecast

  2. Mean Area, Production, and Yield over the years 2010-2020:This provides context for interpreting the grain data

  3. Historical Out of Sample Forecast Error Averaged Over a 10 Year+ Period. We show the Mean Absolute Percent Error (MAPE).

  4. Yield Forecast, (based on April 2023 Precip, NDVI, Et0 ) expressed as percent of mean yield over the period 2012 - 2022.

Assumption Statements

Average Forecast Error For This Point in the Season

At this point in the season historical forecast error, is on average, below 40% for the admin units used in the forecast.


Admin Units Forecast to have Above or Below Average Yields

Of the admin units used in the forecast:

Averages are based on the most recent 10 year period of observed yields: (2010-2020)


The forecast identifies severe yield issues (lowest on record) in the following Admin Unit 2-zones:

The forecast identifies substantially below-average yields (among the lowest 3 on record) in the following Admin Unit 2-zones:


Summary Figures

Mean area, production, and yields for the years 2010-2020 .



Out of Sample Forecast Error (MAPE)

Mean Absolute Percent Error (MAPE) calculated based on historical out of sample seasonal forecasts. Lower scores indicate greater accuracy. Forecasts are based on model type MODEL1



Yield Forecast for April 2023

Forecast values expressed as percent of Mean Yields over the Years 2010-2020 .

The figure shows predicted percent of mean (center) as well as lower (left) and higher (right) predicted percent of mean intervals.



Static and Dynamic Version of Main Forecast

Roll over the polygon borders to get the district name and % of mean forecast value.

Static Version

This map shows the main % of mean forecast value along with district labels for reference.

Discrete Map

This map shows the main % of mean forecast binned into discrete values. Averages are based on the most recent 10 year period of observed yields: 2012 - 2022

This table shows the forecast percentage of mean values in the above table along with the mean yield values from the first figure.


Table of Mean Yields and Predicted Percent of Mean Values
District % of mean
Hargeysa 82
Gabiley 88
Balcad 103
Afgooye 126
Qoryooley 106
Wanla Weyn 131
Baydhabo 112
Buur Hakaba 115
Diinsoor 97
Qansax Dheere 98
Xudur 119
Tiyeglow 126
Garbahaarey 131
Baardheere 85
Luuq 77
Bu'aale 72
Afmadow 124

# Analog Year Forecasts Yield forecasts in analog years. <–DESCRIPTION OF ANALOG YEAR PROCESS–>.
*** –>


# Analog Year Forecasts Errors Forecast errors in analog years. If observed data is not available in a given year we cannot calculate forecast errors. Values are expressed a percentage of observed yields in a given year (t):


\[\frac{(observed_{(t)}-forecast_{(t)})}{observed_{(t)}}\] ***

Positive (+) values indicate an under prediction. Negative (-) values indicate an over prediction.

*** –>


  1. ET=Extra/Extended Trees. GB=Xtreme Gradient Boosting. Both are a type of Random Forest Model↩︎

LS0tCnRpdGxlOiAiRm9yZWNhc3QgUmVwb3J0IHdpdGggQW5hbG9nIFllYXJzLVNvbWFsaWEgTUFNIChFVCkiCm91dHB1dDoKICBodG1sX25vdGVib29rOgogICAgdG9jOiB5ZXMKZmlnX3dpZHRoOiA3CmZpZ19oZWlnaHQ6IDYKZmlnX2NhcHRpb246IHRydWUKLS0tCgpgYGB7cixldmFsPVRSVUUsZWNobz1GQUxTRSx3YXJuaW5nPUZBTFNFLG1lc3NhZ2U9RkFMU0UscmVzdWx0cz0naGlkZSd9CiMtLS0tLS0tLS0tLS0tLS0tLS0tQmFzZSBTZXR1cC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCnJtKGxpc3Q9bHMoKSkKCiMtLS1TZXQgYmFzZSBkaXJlY3RvcnkKZGlyRzwtJ34vTGlicmFyeS9DbG91ZFN0b3JhZ2UvR29vZ2xlRHJpdmUtZnJhbmtfZGF2ZW5wb3J0QHVjc2IuZWR1LycKCiMtLS1TZXQgUHJvamVjdCBEaXJlY3RvcmllcwpkaXJCYXNlPC1wYXN0ZTAoZGlyRywnTXkgRHJpdmUvJykKZGlyQmFzZTI8LXBhc3RlMChkaXJHLCdTaGFyZWQgZHJpdmVzL0NIQyBUZWFtIERyaXZlIC8nKQoKIy1Qcm9qZWN0IERpcmVjdG9yaWVzCmRpclByb2o8LXBhc3RlMChkaXJCYXNlMiwncHJvamVjdF9tYWNoaW5lX2xlYXJuaW5nX2ZvcmVjYXN0aW5nLycpICNwcm9qZWN0IGRpcmVjdG9yeQoKZGlyVmlld2VyPC1wYXN0ZTAoZGlyUHJvaiwndmlld2VyLycpCmRpclZpZXdlck91dFN0YXRpYzwtcGFzdGUwKGRpclZpZXdlciwndmlld2VyX3N0YXRpY19zaGFwZXMvJykKZGlyVmlld2VyRHluYW1pYzwtcGFzdGUwKGRpclZpZXdlciwndmlld2VyX2R5bmFtaWNfc2hhcGVzLycpCgpkaXJSZXBvcnQ8LXBhc3RlMChkaXJQcm9qLCdmb3JlY2FzdF9yZXBvcnRpbmcvJykKZGlyUmVwb3J0UmRhdGE8LXBhc3RlMChkaXJSZXBvcnQsJ2ZvcmVjYXN0X3JlcG9ydGluZ19SZGF0YS8nKQpkaXJSZXBvcnRPdXQ8LXBhc3RlMChkaXJSZXBvcnQsJ2ZvcmVjYXN0X3JlcG9ydGluZ19vdXRwdXRzLycpCgoKbGlicmFyeShzdHJpbmdyKQpsaWJyYXJ5KGdncGxvdDIpCmxpYnJhcnkoZHBseXIpCmxpYnJhcnkocmFzdGVyKQojbGlicmFyeShyZ2RhbCkKbGlicmFyeShtZ2N2KQpsaWJyYXJ5KHRpZHlyKQpsaWJyYXJ5KGx1YnJpZGF0ZSkKbGlicmFyeShzZikKbGlicmFyeShybWFwc2hhcGVyKQpsaWJyYXJ5KHZpcmlkaXMpCmxpYnJhcnkoc2NhbGVzKQpsaWJyYXJ5KHBsb3RseSkKbGlicmFyeShmb3JjYXRzKQpsaWJyYXJ5KFJDb2xvckJyZXdlcikKCgpsaWJyYXJ5KGtuaXRyKQpsaWJyYXJ5KGthYmxlRXh0cmEpCmxpYnJhcnkoc2hpbnkpCgojPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQoKI1BhcmFtZXRlcnMKQ1VSUkVOVF9ZRUFSPC0yMDIzCk1PTlRIPC00CkRFS0FEPC0zCk1PREVMPC0nR0InCkNPVU5UUlk8LSdTb21hbGlhJwpQUk9EVUNUPC0nU29yZ2h1bScKI0NST1BfQVJFQTwtMiAgI1BlcmNlbnQKQU5BTE9HX1lFQVJTPC1jKDE5OTYsIDE5OTgsIDIwMDUsIDIwMTAsIDIwMTYsIDIwMjAsIDIwMjEpCgptb250aF9uYW1lPC1tb250aC5uYW1lW01PTlRIXSAjbW9udGggdGhlIHByb2R1Y3QgaXMgYmFzZWQgb24KCiMtLUxvYWQgRXhpc3RpbmcgUGxvdHMKc2V0d2QoZGlyUmVwb3J0UmRhdGEpCmxvYWQoZmlsZT1wYXN0ZTAoJzIwX2ZvcmVjYXN0X3JlcG9ydGluZ19tYWluX3Bsb3RzJyxtb250aF9uYW1lLENPVU5UUlksJ18nLE1PREVMLCdfJyxQUk9EVUNULCcuUmRhdGEnKSkKbG9hZChmaWxlPXBhc3RlMCgnMDFfZm9yZWNhc3RfcmVwb3J0X2Fnc3RhdG1hcHNfJyxDT1VOVFJZLCdfJyxQUk9EVUNULCcuUmRhdGEnKSkKYGBgCiMgSW50cm9kdWN0aW9uClRoaXMgaXMgdGhlIGByIENPVU5UUllgIGByIG1vbnRoX25hbWVgIGByIFBST0RVQ1RgIGZvcmVjYXN0IHJlcG9ydCBmcm9tIHRoZSBgciBNT0RFTGAgbW9kZWwuICoqVGhlIGdvYWwgaXMgdG8gYXNzaXN0IHVzZXJzIGluIGV2YWx1YXRpbmcgY3VycmVudCBmb3JlY2FzdHMgaW4gdGhlIGNvbnRleHQgb2YgcGFzdCBmb3JlY2FzdHMqKiBhbmQgKip0byB0cmFuc2xhdGUgdGhlIGZvcmVjYXN0IGNvbXBvbmVudCBpbnRvIGtleSBhc3N1bXB0aW9ucyBhYm91dCBmb29kIHNlY3VyaXR5LioqCgpUaGUgcmVwb3J0IGluY2x1ZGVzIHRoZSBmb2xsb3dpbmcga2V5IGNvbXBvbmVudHM6CgoxLiAqKipBIHZlcmJhbCBzdW1tYXJ5IG9mIGFzc3VtcHRpb25zIGJhc2VkIG9uIHRoZSBzdGF0aXN0aWNzIGluIHRoaXMgZm9yZWNhc3QqKiogCgoyLiAqKipNZWFuIEFyZWEsIFByb2R1Y3Rpb24sIGFuZCBZaWVsZCBvdmVyIHRoZSB5ZWFycyAyMDEwLTIwMjA6KioqVGhpcyBwcm92aWRlcyBjb250ZXh0IGZvciBpbnRlcnByZXRpbmcgdGhlIGdyYWluIGRhdGEKCjMuICoqKkhpc3RvcmljYWwgT3V0IG9mIFNhbXBsZSBGb3JlY2FzdCBFcnJvciBBdmVyYWdlZCBPdmVyIGEgMTAgWWVhcisgUGVyaW9kKioqLiBXZSBzaG93IHRoZSAqKipNKioqZWFuICoqKkEqKipic29sdXRlICoqKlAqKiplcmNlbnQgKioqRSoqKnJyb3IgKCoqKk1BUEUqKiopLgoKNC4gKioqWWllbGQgRm9yZWNhc3QqKiosIChiYXNlZCBvbiBgciBsaXNfdmFyc19yZXBvcnQkbW9udGhfbmFtZWAgYHIgbGlzX3ZhcnNfcmVwb3J0JG1heF9ldmFyX3llYXJgIGByIGxpc192YXJzX3JlcG9ydCR2YXJfbmFtZWAgKSBleHByZXNzZWQgYXMgKipwZXJjZW50IG9mIG1lYW4geWllbGQqKiBvdmVyIHRoZSBwZXJpb2QgYHIgbGlzX3ZhcnNfcmVwb3J0JG1pbl9hZ2AgLSBgciBsaXNfdmFyc19yZXBvcnQkbWF4X2FnYC4KCjwhLS0gNS4gKioqRm9yZWNhc3RzIGFuZCBGb3JlY2FzdCBFcnJvciBpbiBBbmFsb2cgWWVhcnMqKiogV2Ugc2hvdyBzcGVjaWZpYyBmb3JlY2FzdHMgYW5kIGZvcmVjYXN0IGVycm9yIGZvciB5ZWFycyB3ZXJlIGNsaW1hdG9sb2dpY2FsbHkgc2ltaWxhciB0byB0aG9zZSBpbiB0aGlzIHJlcG9ydC4gLS0+CgojIEFzc3VtcHRpb24gU3RhdGVtZW50cyAKIyMjIyBBdmVyYWdlIEZvcmVjYXN0IEVycm9yIEZvciBUaGlzIFBvaW50IGluIHRoZSBTZWFzb24KQXQgdGhpcyBwb2ludCBpbiB0aGUgc2Vhc29uICoqKmhpc3RvcmljYWwgZm9yZWNhc3QgZXJyb3IsIGlzIG9uIGF2ZXJhZ2UsIGJlbG93IDQwJSBmb3IgdGhlIGFkbWluIHVuaXRzKioqIHVzZWQgaW4gdGhlIGZvcmVjYXN0LgoKCioqKgoKIyMjIyBBZG1pbiBVbml0cyBGb3JlY2FzdCB0byBoYXZlIEFib3ZlIG9yIEJlbG93IEF2ZXJhZ2UgWWllbGRzCk9mIHRoZSAqKiphZG1pbiB1bml0cyB1c2VkIGluIHRoZSBmb3JlY2FzdDoqKioKCjwhLS0gKiAxIGFyZSBmb3JlY2FzdCB0byBiZSBzZXZlcmVseSBiZWxvdyBhdmVyYWdlICg8NTAlIG9mIGF2ZXJhZ2UpICAgLS0+CjwhLS0gKiAxMiBhcmUgZm9yZWNhc3QgdG8gYmUgYmVsb3cgYXZlcmFnZSAoPCA5MCUgb2YgYXZlcmFnZSkgICAtLT4KPCEtLSAqIDMgYXJlIGZvcmVjYXN0IHRvIGJlIGF2ZXJhZ2UgKGJldHdlZW4gOTAgdG8gMTEwJSBvZiBhdmVyYWdlKSAgIC0tPgo8IS0tICogMiBhcmUgZm9yZWNhc3QgdG8gYmUgYWJvdmUgYXZlcmFnZSAoPiAxMTAlIG9mIGF2ZXJhZ2UpICAgLS0+CgoqKkF2ZXJhZ2VzKiogYXJlIGJhc2VkIG9uIHRoZSBtb3N0IHJlY2VudCAxMCB5ZWFyIHBlcmlvZCBvZiBvYnNlcnZlZCB5aWVsZHM6ICgyMDEwLTIwMjApIDwhLS1gciBsaXNfdmFyc19yZXBvcnQkbWluX2FnYCAtIGByIGxpc192YXJzX3JlcG9ydCRtYXhfYWdgIC0tPgoKKioqIAoKKioqVGhlIGZvcmVjYXN0IGlkZW50aWZpZXMgc2V2ZXJlIHlpZWxkIGlzc3VlcyAobG93ZXN0IG9uIHJlY29yZCkgaW4gdGhlIGZvbGxvd2luZyBBZG1pbiBVbml0IDItem9uZXM6KioqCjwhLS0gTWlkZGxlIEp1YmEtQnUnYWFsZSAtLT4KCioqKlRoZSBmb3JlY2FzdCBpZGVudGlmaWVzIHN1YnN0YW50aWFsbHkgYmVsb3ctYXZlcmFnZSB5aWVsZHMgKGFtb25nIHRoZSBsb3dlc3QgMyBvbiByZWNvcmQpIGluIHRoZSBmb2xsb3dpbmcgQWRtaW4gVW5pdCAyLXpvbmVzOioqKgo8IS0tIEJheS1EaWluc29vciwgQmF5LVFhbnNheCBEaGVlcmUsIE1pZGRsZSBKdWJhLUJ1J2FhbGUgLS0+CgoKCioqKgoKIyBTdW1tYXJ5IEZpZ3VyZXMKCiMjIyMgTWVhbiBhcmVhLCBwcm9kdWN0aW9uLCBhbmQgeWllbGRzIGZvciB0aGUgeWVhcnMgMjAxMC0yMDIwIDwhLS1gciBsaXNfdmFyc19yZXBvcnQkbWluX2FnYCB0byBgciBsaXNfdmFyc19yZXBvcnQkbWF4X2FnYC0tPi4KCioqKgpgYGB7cixlY2hvPUZBTFNFLHdhcm5pbmc9RkFMU0UsbWVzc2FnZT1GQUxTRX0KcDFhbGwKYGBgCioqKgoKCgoKCiMjIyMgT3V0IG9mIFNhbXBsZSBGb3JlY2FzdCBFcnJvciAoTUFQRSkKTWVhbiBBYnNvbHV0ZSBQZXJjZW50IEVycm9yIChNQVBFKSBjYWxjdWxhdGVkIGJhc2VkIG9uIGhpc3RvcmljYWwgb3V0IG9mIHNhbXBsZSBzZWFzb25hbCBmb3JlY2FzdHMuICoqTG93ZXIgc2NvcmVzIGluZGljYXRlIGdyZWF0ZXIgYWNjdXJhY3kqKi4gRm9yZWNhc3RzIGFyZSBiYXNlZCBvbiBtb2RlbCB0eXBlIGBNT0RFTGBeW0VUPUV4dHJhL0V4dGVuZGVkIFRyZWVzLiBHQj1YdHJlbWUgR3JhZGllbnQgQm9vc3RpbmcuIEJvdGggYXJlIGEgdHlwZSBvZiBSYW5kb20gRm9yZXN0IE1vZGVsXQoKKioqCmBgYHtyLGVjaG89RkFMU0Usd2FybmluZz1GQUxTRSxtZXNzYWdlPUZBTFNFfQpwMgpgYGAKKioqCgoKIyBZaWVsZCBGb3JlY2FzdCBmb3IgYHIgbGlzX3ZhcnNfcmVwb3J0JG1vbnRoX25hbWVgIGByIGxpc192YXJzX3JlcG9ydCRtYXhfZXZhcl95ZWFyYCAKRm9yZWNhc3QgdmFsdWVzIGV4cHJlc3NlZCBhcyBwZXJjZW50IG9mIE1lYW4gWWllbGRzIG92ZXIgdGhlIFllYXJzICAyMDEwLTIwMjAgPCEtLWByIGxpc192YXJzX3JlcG9ydCRtaW5fYWdgIC0gYHIgbGlzX3ZhcnNfcmVwb3J0JG1heF9hZ2AgLS0+LiAKClRoZSBmaWd1cmUgc2hvd3MgKioqcHJlZGljdGVkIHBlcmNlbnQgb2YgbWVhbioqKiAoY2VudGVyKSBhcyB3ZWxsIGFzIGxvd2VyIChsZWZ0KSBhbmQgaGlnaGVyIChyaWdodCkgKioqcHJlZGljdGVkIHBlcmNlbnQgb2YgbWVhbioqKiBpbnRlcnZhbHMuCgoqKioKYGBge3IsZWNobz1GQUxTRSx3YXJuaW5nPUZBTFNFLG1lc3NhZ2U9RkFMU0UsZmlnLndpZHRoPTgsZmlnLmhlaWdodD04fQojcDM8LWdncGxvdGx5KHA9cDMsdG9vbHRpcD1jKCdkaXN0cmljdCcsJ3Blcl9vZl9tZWFuJykpCnAxCmBgYAoqKioKCiMjIyMgU3RhdGljIGFuZCBEeW5hbWljIFZlcnNpb24gb2YgTWFpbiBGb3JlY2FzdApSb2xsIG92ZXIgdGhlIHBvbHlnb24gYm9yZGVycyB0byBnZXQgdGhlIGRpc3RyaWN0IG5hbWUgYW5kICUgb2YgbWVhbiBmb3JlY2FzdCB2YWx1ZS4KCmBgYHtyLGVjaG89RkFMU0Usd2FybmluZz1GQUxTRSxtZXNzYWdlPUZBTFNFLGZpZy5hbGlnbj0nY2VudGVyJyxmaWcud2lkdGg9OCxmaWcuaGVpZ2h0PTh9CiNwMUxzCnAxTDwtZ2dwbG90bHkocDFMLHRvb2x0aXA9YygnYWRtaW4yJywndmFsdWUnKSkgJT4lIGxheW91dChsZWdlbmQgPSBsaXN0KG9yaWVudGF0aW9uID0gImgiLCB4ID0gMC40LCB5ID0gLTAuMikpCnAxTApgYGAKIyMjIyBTdGF0aWMgVmVyc2lvbgpUaGlzIG1hcCBzaG93cyB0aGUgbWFpbiAlIG9mIG1lYW4gZm9yZWNhc3QgdmFsdWUgYWxvbmcgd2l0aCBkaXN0cmljdCBsYWJlbHMgZm9yIHJlZmVyZW5jZS4KYGBge3IsZWNobz1GQUxTRSx3YXJuaW5nPUZBTFNFLG1lc3NhZ2U9RkFMU0UsZmlnLmFsaWduPSdjZW50ZXInLGZpZy53aWR0aD04LGZpZy5oZWlnaHQ9OH0KcDFMcwoKYGBgCiMjIyMgRGlzY3JldGUgTWFwClRoaXMgbWFwIHNob3dzIHRoZSBtYWluICUgb2YgbWVhbiBmb3JlY2FzdCBiaW5uZWQgaW50byBkaXNjcmV0ZSB2YWx1ZXMuICoqQXZlcmFnZXMqKiBhcmUgYmFzZWQgb24gdGhlIG1vc3QgcmVjZW50IDEwIHllYXIgcGVyaW9kIG9mIG9ic2VydmVkIHlpZWxkczogYHIgbGlzX3ZhcnNfcmVwb3J0JG1pbl9hZ2AgLSBgciBsaXNfdmFyc19yZXBvcnQkbWF4X2FnYApgYGB7cixlY2hvPUZBTFNFLHdhcm5pbmc9RkFMU0UsbWVzc2FnZT1GQUxTRSxmaWcuYWxpZ249J2NlbnRlcicsZmlnLndpZHRoPTgsZmlnLmhlaWdodD04fQpwMUxjCgpgYGAKCiMjIyMgVGhpcyB0YWJsZSBzaG93cyB0aGUgZm9yZWNhc3QgcGVyY2VudGFnZSBvZiBtZWFuIHZhbHVlcyBpbiB0aGUgYWJvdmUgdGFibGUgYWxvbmcgd2l0aCB0aGUgbWVhbiB5aWVsZCB2YWx1ZXMgZnJvbSB0aGUgZmlyc3QgZmlndXJlLiAKKioqCmBgYHtyLGVjaG89RkFMU0Usd2FybmluZz1GQUxTRSxtZXNzYWdlPUZBTFNFfQp0MTwta25pdHI6OmthYmxlKGR0YWIsIGNhcHRpb24gPSAnVGFibGUgb2YgTWVhbiBZaWVsZHMgYW5kIFByZWRpY3RlZCBQZXJjZW50IG9mIE1lYW4gVmFsdWVzJykKdDE8LWthYmxlX3N0eWxpbmcodDEsYm9vdHN0cmFwX29wdGlvbnMgPSBjKCJzdHJpcGVkIiwgImhvdmVyIiwiY29uZGVuc2VkIikpCnNjcm9sbF9ib3godDEsIGhlaWdodCA9ICczMDBweCcsIHdpZHRoID0gJzEwMCUnLAogIGJveF9jc3MgPSAiYm9yZGVyOiAxcHggc29saWQgI2RkZDsgcGFkZGluZzogMXB4OyAiLCBleHRyYV9jc3MgPSBOVUxMLAogIGZpeGVkX3RoZWFkID0gVFJVRSkKCgpgYGAKKioqCgogIyBBbmFsb2cgWWVhciBGb3JlY2FzdHMKWWllbGQgZm9yZWNhc3RzIGluIGFuYWxvZyB5ZWFycy4gPC0tREVTQ1JJUFRJT04gT0YgQU5BTE9HIFlFQVIgUFJPQ0VTUy0tPi4gIAoqKiogLS0+CmBgYHtyLGVjaG89RkFMU0Usd2FybmluZz1GQUxTRSxtZXNzYWdlPUZBTFNFLGZpZy53aWR0aD03LjUsZmlnLmhlaWdodD03LjV9CnAzCmBgYAoqKioKCiAjIEFuYWxvZyBZZWFyIEZvcmVjYXN0cyBFcnJvcnMKRm9yZWNhc3QgZXJyb3JzIGluIGFuYWxvZyB5ZWFycy4gSWYgb2JzZXJ2ZWQgZGF0YSBpcyBub3QgYXZhaWxhYmxlIGluIGEgZ2l2ZW4geWVhciB3ZSBjYW5ub3QgY2FsY3VsYXRlIGZvcmVjYXN0IGVycm9ycy4gVmFsdWVzIGFyZSBleHByZXNzZWQgYSBwZXJjZW50YWdlICBvZiBvYnNlcnZlZCB5aWVsZHMgaW4gYSBnaXZlbiB5ZWFyIF8odClfOgoKKioqCiQkXGZyYWN7KG9ic2VydmVkX3sodCl9LWZvcmVjYXN0X3sodCl9KX17b2JzZXJ2ZWRfeyh0KX19JCQKKioqIAoKKioqUG9zaXRpdmUgKCspKioqIHZhbHVlcyBpbmRpY2F0ZSBhbiBfdW5kZXIgcHJlZGljdGlvbl8uICoqKk5lZ2F0aXZlICgtKSoqKiB2YWx1ZXMgaW5kaWNhdGUgYW4gX292ZXIgcHJlZGljdGlvbl8uCgoqKiogLS0+CmBgYHtyLGVjaG89RkFMU0Usd2FybmluZz1GQUxTRSxtZXNzYWdlPUZBTFNFLGZpZy53aWR0aD03LjUsZmlnLmhlaWdodD03LjV9CnA0CmBgYA==