@idm-plugin/meteo2 0.9.3 → 0.9.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  var V0 = Object.defineProperty;
2
- var l0 = (M, z, p) => z in M ? V0(M, z, { enumerable: !0, configurable: !0, writable: !0, value: p }) : M[z] = p;
3
- var Q = (M, z, p) => (l0(M, typeof z != "symbol" ? z + "" : z, p), p);
2
+ var l0 = (z, M, p) => M in z ? V0(z, M, { enumerable: !0, configurable: !0, writable: !0, value: p }) : z[M] = p;
3
+ var Q = (z, M, p) => (l0(z, typeof M != "symbol" ? M + "" : M, p), p);
4
4
  import Y0 from "@log4js-node/log4js-api";
5
5
  import L from "moment";
6
6
  import $ from "got";
@@ -14,7 +14,7 @@ try {
14
14
  } catch {
15
15
  } finally {
16
16
  }
17
- var m0 = /* @__PURE__ */ ((M) => (M.Arome = "arome", M.IconEU = "iconEu", M.GFS = "gfs", M.GFSWave = "gfsWave", M.NamConus = "namConus", M.NamHawaii = "namHawaii", M.NamAlaska = "namAlaska", M.Geos5 = "geos5", M))(m0 || {});
17
+ var m0 = /* @__PURE__ */ ((z) => (z.Arome = "arome", z.IconEU = "iconEu", z.GFS = "gfs", z.GFSWave = "gfsWave", z.NamConus = "namConus", z.NamHawaii = "namHawaii", z.NamAlaska = "namAlaska", z.Geos5 = "geos5", z))(m0 || {});
18
18
  class j0 {
19
19
  /**
20
20
  * 点查海洋气象要素(全量)
@@ -25,26 +25,26 @@ class j0 {
25
25
  * @param source
26
26
  * @param options
27
27
  */
28
- static async queryPointMeteo(z, p, b, O = !1, W = "", o = {}) {
28
+ static async queryPointMeteo(M, p, b, O = !1, W = "", o = {}) {
29
29
  typeof b == "number" && (b = b < 1e12 ? b * 1e3 : b);
30
30
  const A = L(b), q = {
31
31
  searchParams: {
32
- lng: z,
32
+ lng: M,
33
33
  lat: p,
34
34
  ts: A.valueOf(),
35
35
  params: O ? "watertemp" : void 0,
36
36
  source: W == null ? void 0 : W.toLowerCase()
37
37
  },
38
38
  timeout: 3e4
39
- }, a = L(), Y = a.valueOf();
40
- A.isBefore(a.subtract(1, "month")) && (Z == null || Z.warn("[%s] get history meteo on %s: %j", o.requestId, A.format(), q));
41
- const e = "https://aod4idm.idmwx.com/api/ocean/point", d = await $.get(e, q).json(), t = L().valueOf();
42
- if (Z == null || Z.info("[%s] get meteo(cost: %d ms) from %s with options: %j", o.requestId, t - Y, e, q), (d == null ? void 0 : d.code) === 0)
39
+ }, d = L(), n = d.valueOf();
40
+ A.isBefore(d.subtract(1, "month")) && (Z == null || Z.warn("[%s] get history meteo on %s: %j", o.requestId, A.format(), q));
41
+ const a = "https://aod4idm.idmwx.com/api/ocean/point", Y = await $.get(a, q).json(), t = L().valueOf();
42
+ if (Z == null || Z.info("[%s] get meteo(cost: %d ms) from %s with options: %j", o.requestId, t - n, a, q), (Y == null ? void 0 : Y.code) === 0)
43
43
  return {
44
- ...d.data,
44
+ ...Y.data,
45
45
  source: W
46
46
  };
47
- Z == null || Z.warn("[%s] get meteo failed: %j", o.requestId, d);
47
+ Z == null || Z.warn("[%s] get meteo failed: %j", o.requestId, Y);
48
48
  }
49
49
  /**
50
50
  * 点查海洋气象要素(指定要素组合)
@@ -60,32 +60,32 @@ class j0 {
60
60
  * @param source
61
61
  * @param options
62
62
  */
63
- static async queryPointFactor(z, p, b, O = "wind,wave,current,watertemp,visibility", W = "", o = {}) {
63
+ static async queryPointFactor(M, p, b, O = "wind,wave,current,watertemp,visibility", W = "", o = {}) {
64
64
  typeof b == "number" && (b = b < 1e12 ? b * 1e3 : b);
65
65
  const A = L(b), q = {
66
66
  searchParams: {
67
- lng: z,
67
+ lng: M,
68
68
  lat: p,
69
69
  ts: A.valueOf(),
70
70
  params: O,
71
71
  source: W == null ? void 0 : W.toLowerCase()
72
72
  },
73
73
  timeout: 3e4
74
- }, a = L(), Y = a.valueOf();
75
- A.isBefore(a.subtract(1, "month")) && (Z == null || Z.warn("[%s] get history factors on %s: %j", o.requestId, A.format(), q));
76
- const e = "https://aod4idm.idmwx.com/api/ocean/factor", d = await $.get(e, q).json(), t = L().valueOf();
77
- if (Z == null || Z.info("[%s] get factors(cost: %d ms) from %s with options: %j", o.requestId, t - Y, e, q), (d == null ? void 0 : d.code) === 0)
74
+ }, d = L(), n = d.valueOf();
75
+ A.isBefore(d.subtract(1, "month")) && (Z == null || Z.warn("[%s] get history factors on %s: %j", o.requestId, A.format(), q));
76
+ const a = "https://aod4idm.idmwx.com/api/ocean/factor", Y = await $.get(a, q).json(), t = L().valueOf();
77
+ if (Z == null || Z.info("[%s] get factors(cost: %d ms) from %s with options: %j", o.requestId, t - n, a, q), (Y == null ? void 0 : Y.code) === 0)
78
78
  return {
79
- ...d.data,
79
+ ...Y.data,
80
80
  source: W
81
81
  };
82
- Z == null || Z.warn("[%s] get factors failed: %j", o.requestId, d);
82
+ Z == null || Z.warn("[%s] get factors failed: %j", o.requestId, Y);
83
83
  }
84
84
  /**
85
85
  * @see https://api.windy.com/point-forecast/docs
86
86
  * @param key
87
87
  */
88
- static async queryWindyPointForecast(z, p, b, O = {}) {
88
+ static async queryWindyPointForecast(M, p, b, O = {}) {
89
89
  const W = "https://api.windy.com/api/point-forecast/v2", o = [];
90
90
  try {
91
91
  let A = L().valueOf();
@@ -94,7 +94,7 @@ class j0 {
94
94
  "Content-Type": "application/json"
95
95
  },
96
96
  json: {
97
- lat: z,
97
+ lat: M,
98
98
  lon: p,
99
99
  key: b,
100
100
  model: "gfs",
@@ -118,14 +118,14 @@ class j0 {
118
118
  levels: ["surface"]
119
119
  }
120
120
  }).json();
121
- let a = L().valueOf();
122
- Z == null || Z.info("[%s] get gfs-factors(cost: %d ms) from %s", O.requestId, a - A, W), A = a;
123
- const Y = await $.post(W, {
121
+ let d = L().valueOf();
122
+ Z == null || Z.info("[%s] get gfs-factors(cost: %d ms) from %s", O.requestId, d - A, W), A = d;
123
+ const n = await $.post(W, {
124
124
  headers: {
125
125
  "Content-Type": "application/json"
126
126
  },
127
127
  json: {
128
- lat: z,
128
+ lat: M,
129
129
  lon: p,
130
130
  key: b,
131
131
  model: "gfsWave",
@@ -133,36 +133,36 @@ class j0 {
133
133
  levels: ["surface"]
134
134
  }
135
135
  }).json();
136
- a = L().valueOf(), Z == null || Z.info("[%s] get gfs-wave-factors(cost: %d ms) from %s", O.requestId, a - A, W);
137
- for (let d = 0; d < q.ts.length; d++) {
138
- const t = this.populateUVFactor(q["wind_u-surface"][d], q["wind_v-surface"][d], !1, O);
136
+ d = L().valueOf(), Z == null || Z.info("[%s] get gfs-wave-factors(cost: %d ms) from %s", O.requestId, d - A, W);
137
+ for (let Y = 0; Y < q.ts.length; Y++) {
138
+ const t = this.populateUVFactor(q["wind_u-surface"][Y], q["wind_v-surface"][Y], !1, O);
139
139
  t.scale = this.calculateBeaufortWindForceScale(t.speed), o.push({
140
- utc: L(q.ts[d]).utc().format(),
141
- temp: q["temp-surface"][d] ? Math.round((q["temp-surface"][d] - 273.15) * 100) / 100 : void 0,
142
- dp_temp: q["dewpoint-surface"][d] ? Math.round((q["dewpoint-surface"][d] - 273.15) * 100) / 100 : void 0,
140
+ utc: L(q.ts[Y]).utc().format(),
141
+ temp: q["temp-surface"][Y] ? Math.round((q["temp-surface"][Y] - 273.15) * 100) / 100 : void 0,
142
+ dp_temp: q["dewpoint-surface"][Y] ? Math.round((q["dewpoint-surface"][Y] - 273.15) * 100) / 100 : void 0,
143
143
  precip: {
144
- inter3h: q["past3hprecip-surface"][d] ? Math.round(q["past3hprecip-surface"][d] * 1e3 * 1e3) / 1e3 : 0,
145
- inter3hSnow: q["past3hsnowprecip-surface"][d] ? Math.round(q["past3hsnowprecip-surface"][d] * 1e3 * 1e3) / 1e3 : 0,
146
- inter3hConv: q["past3hconvprecip-surface"][d] ? Math.round(q["past3hconvprecip-surface"][d] * 1e3 * 1e3) / 1e3 : 0
144
+ inter3h: q["past3hprecip-surface"][Y] ? Math.round(q["past3hprecip-surface"][Y] * 1e3 * 1e3) / 1e3 : 0,
145
+ inter3hSnow: q["past3hsnowprecip-surface"][Y] ? Math.round(q["past3hsnowprecip-surface"][Y] * 1e3 * 1e3) / 1e3 : 0,
146
+ inter3hConv: q["past3hconvprecip-surface"][Y] ? Math.round(q["past3hconvprecip-surface"][Y] * 1e3 * 1e3) / 1e3 : 0
147
147
  },
148
148
  wind: t,
149
149
  gusts: {
150
- speed: Math.round((q["gust-surface"][d] || 0) * 100) / 100,
151
- kts: this.convertMs2Kts(q["gust-surface"][d])
150
+ speed: Math.round((q["gust-surface"][Y] || 0) * 100) / 100,
151
+ kts: this.convertMs2Kts(q["gust-surface"][Y])
152
152
  },
153
- lclouds: q["lclouds-surface"][d] ? Math.round(q["lclouds-surface"][d] * 100) / 100 : 0,
154
- mclouds: q["mclouds-surface"][d] ? Math.round(q["mclouds-surface"][d] * 100) / 100 : 0,
155
- hclouds: q["hclouds-surface"][d] ? Math.round(q["hclouds-surface"][d] * 100) / 100 : 0,
156
- rh: q["rh-surface"][d] ? Math.round(q["rh-surface"][d] * 100) / 100 : 0,
157
- gh: q["gh-surface"][d] ? Math.round(q["gh-surface"][d] * 100) / 100 : 0,
158
- pressure: Math.round(q["pressure-surface"][d] / 100 * 100) / 100
153
+ lclouds: q["lclouds-surface"][Y] ? Math.round(q["lclouds-surface"][Y] * 100) / 100 : 0,
154
+ mclouds: q["mclouds-surface"][Y] ? Math.round(q["mclouds-surface"][Y] * 100) / 100 : 0,
155
+ hclouds: q["hclouds-surface"][Y] ? Math.round(q["hclouds-surface"][Y] * 100) / 100 : 0,
156
+ rh: q["rh-surface"][Y] ? Math.round(q["rh-surface"][Y] * 100) / 100 : 0,
157
+ gh: q["gh-surface"][Y] ? Math.round(q["gh-surface"][Y] * 100) / 100 : 0,
158
+ pressure: Math.round(q["pressure-surface"][Y] / 100 * 100) / 100
159
159
  });
160
160
  }
161
- const e = [];
162
- for (let d = 0; d < Y.ts.length; d++) {
163
- const t = this.calculateDouglasScale(Y["waves_height-surface"][d], Y["waves_direction-surface"][d], Y["waves_period-surface"][d]), i = this.calculateDouglasScale(Y["wwaves_height-surface"][d], Y["wwaves_direction-surface"][d], Y["wwaves_period-surface"][d]), U = this.calculateDouglasScale(Y["swell1_height-surface"][d], Y["swell1_direction-surface"][d], Y["swell1_period-surface"][d]), s = this.calculateDouglasScale(Y["swell2_height-surface"][d], Y["swell2_direction-surface"][d], Y["swell2_period-surface"][d]);
164
- e.push({
165
- utc: L(Y.ts[d]).utc().format(),
161
+ const a = [];
162
+ for (let Y = 0; Y < n.ts.length; Y++) {
163
+ const t = this.calculateDouglasScale(n["waves_height-surface"][Y], n["waves_direction-surface"][Y], n["waves_period-surface"][Y]), i = this.calculateDouglasScale(n["wwaves_height-surface"][Y], n["wwaves_direction-surface"][Y], n["wwaves_period-surface"][Y]), U = this.calculateDouglasScale(n["swell1_height-surface"][Y], n["swell1_direction-surface"][Y], n["swell1_period-surface"][Y]), s = this.calculateDouglasScale(n["swell2_height-surface"][Y], n["swell2_direction-surface"][Y], n["swell2_period-surface"][Y]);
164
+ a.push({
165
+ utc: L(n.ts[Y]).utc().format(),
166
166
  wave: {
167
167
  sig: t,
168
168
  wd: i,
@@ -171,9 +171,9 @@ class j0 {
171
171
  }
172
172
  });
173
173
  }
174
- for (const d of o) {
175
- const t = e.find((i) => i.utc === d.utc);
176
- d.wave = t == null ? void 0 : t.wave;
174
+ for (const Y of o) {
175
+ const t = a.find((i) => i.utc === Y.utc);
176
+ Y.wave = t == null ? void 0 : t.wave;
177
177
  }
178
178
  } catch (A) {
179
179
  Z.warn("[%s] get-gfs-factor failed: %s", O.requestId, A);
@@ -187,19 +187,19 @@ class j0 {
187
187
  * @param reverse 反转, 如计算洋流方向时,风来流去
188
188
  * @param options
189
189
  */
190
- static populateUVFactor(z, p, b = !1, O = {}) {
191
- const W = Math.round(Math.sqrt(Math.pow(z, 2) + Math.pow(p, 2)) * 1e4) / 1e4, { degree: o, direction: A } = this.calculateUVDirection(z, p, b, O), q = this.convertMs2Kts(W);
190
+ static populateUVFactor(M, p, b = !1, O = {}) {
191
+ const W = Math.round(Math.sqrt(Math.pow(M, 2) + Math.pow(p, 2)) * 1e4) / 1e4, { degree: o, direction: A } = this.calculateUVDirection(M, p, b, O), q = this.convertMs2Kts(W);
192
192
  return {
193
193
  speed: W,
194
194
  kts: q,
195
195
  degree: o,
196
196
  direction: A,
197
- eastward: Math.round(z * 1e4) / 1e4,
197
+ eastward: Math.round(M * 1e4) / 1e4,
198
198
  northward: Math.round(p * 1e4) / 1e4
199
199
  };
200
200
  }
201
- static convertMs2Kts(z) {
202
- return isNaN(z) ? 0 : Math.round(z * 3600 / 1852 * 1e3) / 1e3;
201
+ static convertMs2Kts(M) {
202
+ return isNaN(M) ? 0 : Math.round(M * 3600 / 1852 * 1e3) / 1e3;
203
203
  }
204
204
  /**
205
205
  * 计算UV向量方向
@@ -208,9 +208,9 @@ class j0 {
208
208
  * @param reverse 反转, 如计算洋流方向时,风来流去
209
209
  * @param options
210
210
  */
211
- static calculateUVDirection(z, p, b = !1, O = {}) {
212
- let W = Math.atan2(z, p) + Math.PI;
213
- b && (W = Math.atan2(z, p));
211
+ static calculateUVDirection(M, p, b = !1, O = {}) {
212
+ let W = Math.atan2(M, p) + Math.PI;
213
+ b && (W = Math.atan2(M, p));
214
214
  const o = this.convert2Direction(W);
215
215
  return W = Math.round(W / (2 * Math.PI) * 360 * 1e4) / 1e4, {
216
216
  angle: W,
@@ -223,12 +223,12 @@ class j0 {
223
223
  * @param delta 弧度
224
224
  * @return {string}
225
225
  */
226
- static convert2Direction(z) {
226
+ static convert2Direction(M) {
227
227
  let p = "N/A";
228
- if (!isNaN(z)) {
229
- z < 0 && (z += 2 * Math.PI);
228
+ if (!isNaN(M)) {
229
+ M < 0 && (M += 2 * Math.PI);
230
230
  const b = Math.PI / 16;
231
- z < b ? p = "N" : z >= b && z < 3 * b ? p = "NNE" : z >= 3 * b && z < 5 * b ? p = "NE" : z >= 5 * b && z < 7 * b ? p = "ENE" : z >= 7 * b && z < 9 * b ? p = "E" : z >= 9 * b && z < 11 * b ? p = "ESE" : z >= 11 * b && z < 13 * b ? p = "SE" : z >= 13 * b && z < 15 * b ? p = "SSE" : z >= 15 * b && z < 17 * b ? p = "S" : z >= 17 * b && z < 19 * b ? p = "SSW" : z >= 19 * b && z < 21 * b ? p = "SW" : z >= 21 * b && z < 23 * b ? p = "WSW" : z >= 23 * b && z < 25 * b ? p = "W" : z >= 25 * b && z < 27 * b ? p = "WNW" : z >= 27 * b && z < 29 * b ? p = "NW" : z >= 29 * b && z < 31 * b ? p = "NNW" : z >= 31 * b && z < 32 * b && (p = "N");
231
+ M < b ? p = "N" : M >= b && M < 3 * b ? p = "NNE" : M >= 3 * b && M < 5 * b ? p = "NE" : M >= 5 * b && M < 7 * b ? p = "ENE" : M >= 7 * b && M < 9 * b ? p = "E" : M >= 9 * b && M < 11 * b ? p = "ESE" : M >= 11 * b && M < 13 * b ? p = "SE" : M >= 13 * b && M < 15 * b ? p = "SSE" : M >= 15 * b && M < 17 * b ? p = "S" : M >= 17 * b && M < 19 * b ? p = "SSW" : M >= 19 * b && M < 21 * b ? p = "SW" : M >= 21 * b && M < 23 * b ? p = "WSW" : M >= 23 * b && M < 25 * b ? p = "W" : M >= 25 * b && M < 27 * b ? p = "WNW" : M >= 27 * b && M < 29 * b ? p = "NW" : M >= 29 * b && M < 31 * b ? p = "NNW" : M >= 31 * b && M < 32 * b && (p = "N");
232
232
  }
233
233
  return p;
234
234
  }
@@ -237,9 +237,9 @@ class j0 {
237
237
  * @param speed m/s
238
238
  * @returns {number}
239
239
  */
240
- static calculateBeaufortWindForceScale(z) {
240
+ static calculateBeaufortWindForceScale(M) {
241
241
  let p = 0;
242
- return isNaN(z) || (z = Math.round(z * 10) / 10, z <= 0.2 ? p = 0 : z <= 1.5 ? p = 1 : z <= 3.3 ? p = 2 : z <= 5.4 ? p = 3 : z <= 7.9 ? p = 4 : z <= 10.7 ? p = 5 : z <= 13.8 ? p = 6 : z <= 17.1 ? p = 7 : z <= 20.7 ? p = 8 : z <= 22.4 ? p = 9 : z <= 28.4 ? p = 10 : z <= 32.6 ? p = 11 : z > 32.6 && (p = 12)), p;
242
+ return isNaN(M) || (M = Math.round(M * 10) / 10, M <= 0.2 ? p = 0 : M <= 1.5 ? p = 1 : M <= 3.3 ? p = 2 : M <= 5.4 ? p = 3 : M <= 7.9 ? p = 4 : M <= 10.7 ? p = 5 : M <= 13.8 ? p = 6 : M <= 17.1 ? p = 7 : M <= 20.7 ? p = 8 : M <= 22.4 ? p = 9 : M <= 28.4 ? p = 10 : M <= 32.6 ? p = 11 : M > 32.6 && (p = 12)), p;
243
243
  }
244
244
  /**
245
245
  * 计算海浪等级
@@ -247,103 +247,103 @@ class j0 {
247
247
  * @param degree 度
248
248
  * @param period 周期 s
249
249
  */
250
- static calculateDouglasScale(z, p, b) {
250
+ static calculateDouglasScale(M, p, b) {
251
251
  let O = "Calm";
252
252
  const W = this.convert2Direction(p / 360 * 2 * Math.PI);
253
- return isNaN(z) || z <= 0.1 ? O = "Calm" : z <= 0.5 ? O = "Smooth" : z <= 1.25 ? O = "Slight" : z <= 2.5 ? O = "Moderate" : z <= 4 ? O = "Rough" : z <= 6 ? O = "VeryRough" : z <= 9 ? O = "High" : z <= 14 ? O = "VeryHigh" : O = "Precipitous", {
253
+ return isNaN(M) || M <= 0.1 ? O = "Calm" : M <= 0.5 ? O = "Smooth" : M <= 1.25 ? O = "Slight" : M <= 2.5 ? O = "Moderate" : M <= 4 ? O = "Rough" : M <= 6 ? O = "VeryRough" : M <= 9 ? O = "High" : M <= 14 ? O = "VeryHigh" : O = "Precipitous", {
254
254
  degree: Math.round(p * 100) / 100,
255
255
  scale: O,
256
256
  direction: W,
257
- height: Math.round(z * 1e3) / 1e3,
257
+ height: Math.round(M * 1e3) / 1e3,
258
258
  period: Math.round(b * 100) / 100
259
259
  };
260
260
  }
261
261
  }
262
262
  var E0 = typeof globalThis < "u" ? globalThis : typeof window < "u" ? window : typeof global < "u" ? global : typeof self < "u" ? self : {};
263
- function I0(M) {
264
- return M && M.__esModule && Object.prototype.hasOwnProperty.call(M, "default") ? M.default : M;
263
+ function I0(z) {
264
+ return z && z.__esModule && Object.prototype.hasOwnProperty.call(z, "default") ? z.default : z;
265
265
  }
266
266
  var t0 = { exports: {} };
267
- (function(M) {
268
- function z(p, b) {
267
+ (function(z) {
268
+ function M(p, b) {
269
269
  var O = "XIXHXHXGXGXQXQXPXPXOXOXN##U6U6UW#$U%U%U%U%U%XFXEXEXRXRXVXVXWXWXXXXXYXYXZXZY#Y#Y$Y$Y%Y%XSXSXTXTXUXIXHXHXGXGXQXQVAVA#%#&V'#'U6#(#)U%U%U%U%U%#*U%XEXEVLVLVLVLYGYGYGYG#+W=W=W=W=W=W=Y$X+X+X+X+X+XTXUVPUQ#,T*T*#-VAVA#.#/#0#1#2U6U6UWU%U%U%U%U%#3VLVLXEYH#4#5#6YGYGYG#7X.#8W=W=W=#9X,X,#:#;#<#=#>VPVP#?#@#AT*T*#B#C#D#E#F#GV'#H#I#JUWU%U%U%U%X6X6#K#LYH#M#N#O#PYG#Q#R#SX.#T#UW=W=#V#WX,#X#Y#Z$#$$$%$&T)$'$(T*T*$)$*$+TW$,$-$.$/$0$1$2$3U%U%XJXJXF$4$5$6$7$8$9$:YG$;$<$=$>$?$@$A$BW3$C$D$E$F$G$HW8$IT)T)T)XHXGXGXQV=$J$K$L$M$N$O$P$Q$R$SV2XKXJXJXFY4$T$U$V$W$X$Y$Z%#%$%%VN%&%'%(%)%*%+%,%-%.%/%0W8XTT)XIXHXHXGXGXQXQU>%1%2%3TL%4%5%6%7U-XKXKX0X0XF%8%9%:%;%<%=%>%?%@%A%B%C%DX(%E%F%GWU%H%I%J%KXSXTXTXUXIXHXHXGXGXQXQU>%L%M%NTL%OUPXMX1XLXKXKXJX0X5%P%QS0%R%S%T%U%V%W%X%Y%Z&#WUWUWUWUWU&$&%X%XSXSXTXTXU&&ZDZDXGXGXQXQXP&'&(&)&*&+&,UOXLXLXKXKXJXJ&-&.&/S0&0T&&1&2WQ&3&4&5&6&7&8&9&:&;&<&=X%X%XSX%XTXTXUXIZDZDZDXGXQXQXPUI&>&?&@&A&B&C&DXLXKXKXJX3&E&F&G&H&I&J&K&L&M&N&OWEW<W<&P&Q&R&S&T&UY%X%ZUXSXTZYXUXIXHXHXGXGXQXQXPXPXOXO&V&W&X&Y&Z'#XKXKXJX3'$'%'&'''(')'*'+','-VMXXW<'.XZ'/'0'1'2WDZPZ9'3'4ZH'5XUXIXHZEZEXGXQXQXPXPXOXOZ@'6'7'8'9':';XKXJXJXF'<'='>'?'@'A'B'C'DXXXXZ1W'XZ'E'F'G'H'I'JW5Z9'K'L'MZWZ<Z<XHZEXGXQXQXPXPXOXOZ@'N'O'PUB'Q'R'S'TXJXFXFXESQ'U'V'W'X'YXWZ0XX'ZXYXZXZW4(#($(%W5(&ZS('ZB((()(*(+ZTZE(,(-XQXPXPXOXOXNU=U=(.(/(0(1(2(3XJXFX8XEXESN(4(5(6(7(8Z2XXZ+XYXZZ-Y#(9(:(;(<(=(>(?ZB(@(A(BZLZT(CZV(DXQXPXPXOXOXNXNU=(E(F(G(H(IXJXJXFXFX8XE(J(K(L(M(NZ*(OZ2XYXYXZXZY#Y#XCXC(P(QX;X;ZN(RZ>(SXHXHZVZVZA(TZQXPZ:XOXNXNV,(U(V(WV.V.XJXJXFXFXEXET((X(Y(ZZ*Z*XXXXXYXYXZXZY#Y#XCXC)#)$)%)&XT)'XUZ6XHXHXGXGXQXQXPXPXOXOXNXNV,)()))*V.XKXJXJXFX8XEXEXRSE)+SEXWXWXXXXXYXYXZXZY#Y#XC),)-).)/XDXAZ6Z6Z8XHXHXGXGXQXQXPXPXOXOXNXNV,)0)1T.XKXKXJXJXFX8XEXEXRXRXVXVXWXWXXXXXYZ/XZXZY#Y#Y$Y$Y%)2)3XDXTZ6Z6XIXHXHXGXGXQXQXPXPXOXOXNXN)4)5)6X9XKXKXJXJXFXFXEXEXRXRXVSESEZ/Z/XXZ/XYXZXZY#Y#Y$Y$Y%Y%XSXSXTZ6Z6XIXHXHXGXGXQXQXPXPXOXOXNXNV&)7)8X9XKX7X7X7XFXFXEXEXRXRXVXVXWXWXXXXXYXYXZXZY#Y#Y$Y$Y%Y%XSXSVEZ6XUXIXHXHXGXGXQXQXPXPXOXOXNXNVHVH)9):T9T9XJXJXFXFXEXEXRXRVIVIVIVI);VFVFVC)<VKVBVBVBVDVDVDVDVD)=VGXUXIXHXHXGXGXQXQXPXPXOXOXNXNVHVHT9T9T9T9)>VH)?Y&)@VJVJVJ)AVIVIVI)BVFVF)C)DVK)E)F)G)H)I)J)K)L)MVGVGVGVGVGVGXGXQXQXPXPXOXOXNXNVHVHT9T9T9T9)NVH)OY&)PVJVJVJ)QVIVIVI)RVFVF)S)TVKVKVK)UXCXCXCXCXC)VVGVGVGVGVGVGVGVGVGVGVGVGVGVGVG)W)X)Y)Z*#*$*%*&*'*(*)***+*,*-*.*/*0*1*2*3*4*5*6*7*8*9*:*;*<*=*>*?VGVGXNXNV'*?XLXLUWU%*>TF*?TFTFV'TFV'V'*>V'*?U6*?V8V8*?U%V8*@U%U%U%*@XYW=YGXYXHT*UQT*XQXQ*>*?VAVA*?*@*@TF*ATFTF*ATFTF*AV'TFTFV'*A*B*C*CTRV/XFVLVLYH*CYHYH*C*DXVXV*DYGYGX.YG*D*DW=X.*EW=*E*F*GX,X+X,*GX+X+X+*G*G*HWWWW*HWWWWWWXTXTWW*HVPVPVPUQ*GUQUQUQUQT*UQT**FV>*GV>*GVAV>*HVAVA*HVAVA*HVAVA*H*IVAVATFV'VAV'V'*HV'*IU6U6U6*IU6U6*IU6X6XFXFX4XEXEX4Y@YH*GYH*HYUYUYU*H*HY7Y7*I*IYGYGYGYGYG*IYGYGYG*I*J*J*KX.X.X.X.*K*L*LW=*MW=*MX,*N*OX,X,*OX,X,*OX,*P*P*QW;*R*RWW*SWB*S*TWBWB*T*UWB*VVPVPW8*VVPVP*VVPUQUQT)UQ*UT*UQT**U*VXQV0*VV=*WV=*W*XV=*Y*YV)*ZV)V)V?*ZV?V?*ZV?V?V'*ZV;+#U6+#U6V;V;+#V;V;+#U&+$U&XLXLU&V2Y@Y@XF+#Y@Y@+#Y@XEYHY@+#+#+$+%+&YU+&+'+(+(+)+*++YGYG++YG+++,+-+.+.X.+/X.X.X.+/+0X.+0+1+2+2+3+4+5+5+6+7+8W=W=W=+8+8+9W3W3W3+9+:W%X,X,+:+;X,+;X,X+X+X+X++;X+WBWRXSWB+:XSW8W8W8W8T)V=+9+:+;+;+<+=+>+>V)TTTTV)V?+>+?V?V?TL+?V;V;+?+@+@V;V;V;V;V;V;+@V;+@+A+B+BV2+CV2+C+DYIYI+D+EYI+F+F+G+H+I+I+J+K+L+L+M+N+O+O+P+Q+R+R+S+T+U+U+V+W+X+X+Y+ZVR+Z,#,$,%VN,%VNVN,%,&,'X(,',(,)W2X',),*X',*,+X'X',+,,W&,-,-,.WUWU,.,/,0,1X+,1X+,2WRXSWRX)WW,1,2WW,2,3U>,4,4TTTTTTTT,4TTTL,4,5,6,7,7,8UPUP,8UPUPUP,8U-XLXLXF,8XFY>,8,9,:YB,:,;YBYB,;,<YMYM,<,=YM,>,>,?,@,A,A,BY9Y9,B,CY9,D,D,E,F,G,G,HVS,I,I,J,K,L,L,M,N,O,O,P,QX(X(,QWUWU,Q,RWUWU,R,SWUWUWU,SWU,T,TX+,UY%X+X%X%X%,TX)XSXSU>,T,U,V,VTT,W,X,XTL,YTLTL,YTL,ZXF,ZXFS:,Z-#S:-$-$-%-&-'YMY*T&T&Y*-&-'S9-'-(S9-)-)-*-+-,-,X#--X#---.X#X#-.-/-0-1-1-2-3-4-4-5-6-7WUWTWUWT-6X%X%X%ZJZDXIZDV:-5XPUF-5-6UF-7-7-8-9-:TLTL-:UHTL-:UH-;-;UO-<UOXFX2XFSA-;-<-=SZS0S0-=->->T&-?-@-@S9-AS9S9-AS9-B-B-CWQ-DX#-D-E-F-FW9-GW9-G-H-IW<W<-IW<W<-I-JW<-K-K-L-M-N-NWU-O-PWUWU-PWUWUWU-P-QWUX%-QX%UI-QUIXO-Q-RUIUIUIUHUI-R-RU.-SV7-S-T-U-V-VV--W-XV<T+-X-YXF-YX3-Z-ZSZ.#SZ.#S2.$S2.$.%S2SY.%SYSYSYSX.%SXSX.%SH.&SH.&SHSH.'.'WQ.(.)WQWQ.)VM.)WE.*WEW<.*W<XZ.*X-X-X-.*.+.,.-.-WU..././WXWU.0.0Y$WDY$XN.0XNXN.0UAXNTNTDTDUV.0TD.0.1TITI.1TI.2T?XLU,XLXF.1XFS5.1.2.3.4.4.5.6.7.7.8.9SK.9.:SK.;.;SX.<.=SHSH.=.>SH.>.?S/.?.@S/.A.A.BSUSUW<W<W<.BW<.BW<.C.C.D.E.F.FW0W0W0W0WD.FWDZCXSZ9Z9XSXSZ9ZRZHZH.DZHTNXNZ@XN.CTD.DTDTD.DTD.ETI.E.F.G.G.H.I.J.JXKT@T@SB.JXFXFS-.JXEXE.JSKXET%.JS@.K.L.L.M.NSJ.N.O.P.QSF.Q.R.SS/.SSWSU.SSUSUXWW<.SXZW4.S.TW4.UW4W4W4.U.U.V.WWCWD.WWC.XY%ZP.X.YZ9ZRXSZRZRZFXTXTZHZHXTZWZ@U=XNU=.U.V.WU=.W.X.Y.Z.ZV+/#V+T@/#T@/$U#U#U#/$XJURU#URSL/#SL/$/$/%/&/'/'/(SO/)/)/*S>S>/*/+/,XWXYZ1Z+Z+W4/+W4/,/,WC/-WCWCW5WC/-W5/-W5/.ZSZ7ZS/.ZKZWXTXTZWZWZ?Z?Z?Z=ZZ/,/,ZT/-ZTZEXGZVZVZIZIZVZV/+/,U=/-/-/.U</////0TPTP/0/1/2/3/3/4T=/5/5XJT=XJSN/5SNSNSO/5/6/7/7S>/8/9S>Z.SR/9Z0Z0/9Z*/9W4Y#Y#/9WCY$Y$WC/9XCXC/9/:/;X>/;/<X>X;/<ZSX;XSZS/<ZSZSZBXT/<ZBXUZ?XUZ>Z>ZX/;ZXZVZV/;ZVZVZVZV/;U=/;U=/<U<U</</=/=/>/?/@/@V./AV.V./AV.V.XR/AXRT(/ASNT(/B/B/CSC/D/D/E/FSRSRZ*XWZ*XXZ2Z4Z2/DX>/EX>X>X;/EX;Z;Z;ZN/EZXZXZ6XIZAZQXQXQXMV,V,/C/C/D/ET0/E/F/G/HT(/H/I/J/J/KSE/L/LSR/MXV/MX>/NX:X>X;X:/NX;X;/N/OX;XS/OXSZNZNZMXTV,/NV,/O/O/P/Q/R/R/S/T/USE/USESEXC/UXCXC/UX:Y%X:X:/UX:/VXDXD/V/W/W/X/YT/T5/Y/ZT5Y%/ZY%Y%/Z0#X@X@XMV,XMV&/Z0#0$0%0%XLT4X9V&0%XMV&T90%XLXLV&V&T9T90$T9T9T9XXXX0$VFXZXZVCVKXTXT0#VGXJXJ0#VHXF0#VH0$0$SE0%SE0%VI0&VI0&VF0'VF0'VC0(VCVCVKVCVK0'0(VKVK0(0)VKVK0)0*0+XC0+0,XCXC0,0-XCXC0-0.XCXC0.0/XCXC0/00XCXC00VG01VG01VH02VHVH02VH0303SE04SE04VI05VI05VF06VF06VC07VCVCVKVCVK06XC07XC07VG08VG08VHVGVGVHVHVGVGT9T9VGVGT9T9VGVGT9T9VGVGT9T9VGVG03VHVGVGVHVHVGVGVH02VGVGY&Y&VGVG01SEVGVGVJVJVGVGVJVJVGVGVJVJVGVG0.VIVGVGVIVIVGVGVIVIVGVGVIVIVGVG0+VFVGVGVFVFVGVGVFVFVGVG0)VCVGVGVCVKVGVGVKVKVGVGVKVKVGVGVKVKVGVG0%XCVGVGXCXCVGVGXCXCVGVGXCXCVGVGXCXCVGVGXCXCVGVG/XVGVGVGXNXNV'U6XOXOVATFVATFVATFV'U6V'U6V'U6V'U6U6U6U6V8UWUWU%U%V8U%V8U%U%U%U%TRT*V>T*V>V>VAV>VAVAVATFTFVAVATFTFVATFVATFVATFTFTFV'V'TFTFV'V'TFTFV'U6V'U6V'V'TFV'V'U6V'U6TRTRU%TRYHYHYUYUYHYH/BY7YHYHY7YG/AYGYGYGYGX./AX.X.W=X.X.X.W=X.X.W=X,W=X,W=W=W=X,W=X,X,X,X,X+X,X+X+X+X+WWX+X+X+WWX+X+WWWWX+XSWWWWWWVPVPVPVPVPVPUQT*V>T*V>T*V>T*V>V>VAV>V>V>VAV>V>VAVAV>VATFTFVAVATFTFVAVATFTFVATFV'U6T<T<V'U6V'U6U6U6U6V;U6U6V;V;YHYH/)YUYUYU/)YUYU/)/*/+YUY7/+Y7Y7Y7/+/,YGYG/,YGYGYGYG/,YGYGYGX.YGYGX.X.YGYGX.X./)X.X.X.X.X.X./)X.X./)X.W=W=X.W=X.W=X.W=W=X,W=X,W=W3W3W3X,X,W3X,X,X,X,/$X+X+X,W;X,/#X,W;X+X+W;W;WWWWW;X)W;X)X+X+WWWWX)WWX)WBX+X+WWWWWWWBWWWWWBWBWWVPWBWBVPVPWBW8WBW8W8W8W8VPW8W8VPVPW8VPUQT*XHXHT*V@XQXQV=U8U8V0.LV=V0V=V0V0V=V=TZTZV=V=TZTZTSTSV=TSV=V=TWV)TWV)TWV)TW.GV).GV).HV'V'V?V'V'U6V'U6V;U6V;V;V;V;U6V;V;U6V;V;UWV;V;V;V;V;U&U&Y4.AY4Y4.AY@.B.CXEXEY'.CYH.C.D.E.EYU.FYU.F.GY,Y,.G.HY,.I.I.JYU.K.K.LZ&Z&.L.MZ&Z&.MYV.N.O.O.P.QYG.Q.R.S.T.T.UYEYE.UYG.V.WYGY=YG.W.W.X.Y.Z.Z/#/$/%YG/%/&/'/'X./(/)/)X./*X.X.X./*WOX.X.WOVNX.X.WIWI/(/)VNVNWIWIVNVN/(X&/)/*X&X&/*X&/*WHVN/+WHWHVY/+X&X&X&/+X&W=X&W=/*/+/,/-WG/-/.//W=//W=W=W=W=//W3W=W=W3W3W3X,W%W%W3W3W3W%W%X,W%/,X,X,/,X,X,X+X+X+X+WRX+WRWBWBW8W8V=V=/)V=V=U>XPU>/(U>U>U>V=/(/)/*TWTW/*/+U>U>U>/+TTTTU>TTTWV)TWV)TT/)TTTTTLTL/)TL/)TLTL/*/*TU/+/,V;V;/,/-V;U6V;V;V;/,/-/.V;TBV;TB/-UKUK/.U-U-U-/.TB/.V2V2V2V2U$UJ/-Y@Y@/.Y@Y@/./////0YI/1/1/2/3/4YI/4YI/5Y,Y,/5Y,Y,/5/6/7/7/8/9/:/:/;/</=/=Z&/>/?Z&Z&/?/@/@/A/B/C/C/D/E/F/F/G/HY</H/IY<Y</I/JY/Y//J/KY//L/L/MY<Y</MYG/N/OY<Y<Y</O/O/P/Q/RYGYG/R/S/S/T/UZ%/U/VYGYG/V/WYGYG/WYQZ%/X/X/YWJWJ/Y/ZYG0#VTVTVT0#0#X.WJVR0#0$VRVRVTVR0$0%X.WOVRWOWOVNWOWOVRVRWPWPVNVNWPWPVY/YVNVNVYVYVNVNVYW=VYVYVNVN/WX(W=W=W2W2W=W=W2W2W2W2X(W2W3W3X'X'W2X'X'X'W3W3/RX'/RW%W%W%W%W%W&W&W%W%/Q/RW&WUWUWU/QWUWUWUWUWUWU/QX,X,/QX,/QX+X+X+WU/QWUWU/QWU/R/SX+WRX+WRX+WRX+/RWWW8WWWWX)WWX)X)U>/PU>U>TETE/P/QU>/QU>TT/QTT/RTT/RTLTLTLTL/RTL/STUTU/S/TTL/TTL/U/UUP/VUPV;/V/W/X/X/YUPUP/YUPUPUP/YU-XLXLYBYBYB/YYBYB/YYBYB/YYB/Z/ZYB0#YBYIYI0#0$YI0$YIYI0$YM0%0&0&0'YMYM0'0(0)0*0*0+0,0-0-0.Y*Y*0.0/000101020304Y*04Y*05Y9Y905Y9XVYRY9Y9YR04Y9Y9YG04Y905YGYG0506Y906Y907YGYG0708VQVQVWVQ0708090:VWVW0:XWVQVQVSVQWSWSWS09VSVS090:WSWP0:WSWPWPWSVNVS09VS0:WS0:0;0<0<VN0=0>VNVN0>0?0?0@0A0B0B0CW,W,VNVN0C0DVNX(X(X(0CX(X(X(X(W2WUWUX'X'WUWUX'X'WUX'X'X'X'0@X'WU0@WUWUWUWU0@0@0AWM0BWU0B0C0DWMWM0DWTX%0DX%X%0D0E0F0GU>0GXPV:0GUYV:U/0GTT0H0IUY0I0J0KTTTTUU0KTT0KTTTLTT0KTLTL0KUP0LUP0LUP0MUPXFY>XFS:0L0MS:S:YB0M0N0OS:0OS0S00OT'0PT'YM0PT'YC0PT'S0T&0PT&T&T&0P0QY*XVT&T&T&S9Y9Y9XV0P0P0Q0R0S0S0T0UVO0U0VW(0W0W0XVUVUVOVUWQ0XVUVUWQVU0WX#0XX#0X0YVU0Z0ZX#X#X#X#0ZX#X#0ZVS1#1$1$1%W7W7W7W71%W7W7W7W71%1%1&W71'1'1(1)1*1*1+W9W9W91+W91,X(X(W9W<X(WUWUWU1*W<W<W<WUWUW<WUWTWT1)1*V:1*UFUFU/U/1*U/TM1*TM1+UFULUF1+1+UE1,1-1-TL1.1/ULUL1/UI1/1011UL11XNULXN11UPXNUPXNUPU.U.UPUPUP10UP1011UOX2S:1112S:S:SA12SASASASZSZS0SZS2S0S0S2S0S0T&S0T&S0T&S0S0T&T&SYT&T&1,T&S9T&S9T&S91+1,1-WQS91-S9S91-1.WQWQ1.X#1/X#1/10WQWQX#X#10X#1011W+1212X#WEWE12W9X#13X#W9WEXXW9W9W9121213W<W<W913W<W<13W:W<1414WU1516WUWU16171718W<19WUWU19W<W<WU19X-191:1;W<1;X-X-X-WUWUX-WU1:WU1;WUWUWUWU1;WUWU1;WUWUWU1;1<WU1<WU1=1=1>WXX%UF1>XOUI1>UIUIUIUI1>UIUIUI1>UIU*UH1>1?TH1?TAU*V7U.U.TKTKU.UOU.U.XMXMV7TDU71<U7XMUOU'U.UZUZ1;XMXMV-1;XMXMV%1;XLTI1;T,UN1<1<SASASZXFSZS=1<SASZSZSZSZSZS=SZSZS2SZS2SZS2SZS2S0S0S2S2S0S0S017S0SYSYSYSXT&SXSXT&SHSXSHSXSHSXSH13SHSHSHSHSHSH1313WQSHWQ13WQS1S1WQ1314VMWQWQVMVMWQWQWQWEWEWEVMWEW<11W<XZW)11XZX-X-111213X*VXX*X*12VX13VX1314VX15VX15VX1616W0X*17WUWUW0WU16WUY$Y$Y$WDWUWD15WDWDWD15U*XNXN1516TYUAUVTDUVTDXMXM1516TD16TD17XL17TIU(TI17TITIS=17S=18S=18S5S<S2S2S218S<S<18SBS<1819S<S2S2S21919T#T#T#191:S-S-T#1:1;S.1;SYT#SY1;SY1<SK1<T$1=1>SYSYSK1>SYSXSK1>SK1>1?S@SXSX1?SX1?SXSX1@SXSXS3S3SHSHS3SFSH1>SFSFSH1>SHS/SHSFSFSF1=1>S/S/1>VM1?1@S/SUS/S/VMVMVMSUVMVMSUSU1=W'1>W'W<XZW<X-XZX-W<VXX-VXX-1<1<1=1>WK1>VXVXVXWKWKVXW0WK1=WK1>WDWDW0Y$ZHZGZHZGUVUVTDXMXMTDU+U+TD1:TDTDTDTDTDUBTIU,TITCTITIUBUBTCTCUBTCU,16U,UXUXUXUXTJU,U,TCV+UXTJV+T@XKXK13XKSV13SVSV13S.14S.1415S.XESK1516S@SQS@SL16S@S@SLS7S3S3S315S3S3SJS3S@S7S714S3S314SOSFSFSO1414SOSOSOSOSOSO14S/S/SFS/13SG14SGSGSW14SWS/S/S/SUS/SUSUSUW<W4W4W4VX11W4W>11W>W>W>11W>1213W4W?13WLY$W?1314W?WD14W?W?WCWLWCWD13WCWCWCWCWCW5W5ZPW5W5ZPY%W5W5U+U+1011U+U+11U=U=11U=U=TDTDU=U=TDUBTDUBU=U=U=TXTXUBTXUBUBV+UBUBUBV+UBV+T@U#T@U#1*U#1+U#U#U#1+U#SL1+S7S71+1,1-1.S71.S7SJSJSJSJSO1-SJSNSJ1-SOSJSOSJSOSOSOSO1,SO1-SO1-SOSO1-SG1.S>1.SWS>1/SWSW1/SWSUSUSWXW1.1/S>S>1/WLWLWLW4WLW4W4WLWLWL1.WLWCW4W4WCW5WCW5W5Y%W5ZSW5ZSW5ZSZ7Z7Z7ZBZZXIZZZ5Z=XHZOXHZOXHZ5ZO1&V*U=U=V*TXV*1&U=U<U=U<UB1%U<V$V$UBV$TPV$1$U<U<UBV+TPTPV+V+TPTPT@T@TPT-T-U#T-U#TPT-TPV.T-0W0XT=U#U#T=T=0W0X0Y0ZT=0ZT=T=0Z1#U@U@SNSNSN1#SOSOSOSPSNSPSPSP0Y0ZSPSP0Z1#SPSPSP1#SP1$1$SR1%SRZ.Z.XWZ3Z3Z*Z3Z*W4W4Z,Y#W40ZY$Y$WCW*WCW*W5W5Y%X>W5Y%X>Y%Y%X>XCX>Y%W5X>Y%W5ZSY%X;ZSZSX;XSZBZBZSXSZBZBZ;Z;Z>Z>Z>ZXZTXGXGZVZVZVZVZAU=U<0NU<V,0NV,0OU<U<U<0OU<T;0OT;TPTPU<TGTPTPTGTGT;0MT;TGTGTG0MTG0MV.V.V.0MV.0NV.0NT=0OT=SNSNT(T(SNSN0NT(T(SCT(SCSPSPSC0MSP0M0NSDSDSD0N0OSDSRSDSD0NSRSRSRSD0N0OSRXCX>XCX>XCX>XCX>X>0MX>X>Z;XTZNZNV,T/0L0MT10MT50N0NT;T0T00N0O0P0QT;T;0Q0R0R0S0TV.T0T;T00T0T0U0VV.T(SCT(SCT(T(T(SET(SESESESCSCSC0S0SSESESESESE0S0TSESR0TSR0TSESESEXCX>XCX>XCX:XCX:X:X;X:XDX;X;XDXDX;X;XD0PX;X;0P0Q0QT60R0S0ST30T0UT2T0T70UT0T0T00UT70UT5T50U0V0WT.T00W0X0Y0YV.UM0Z0Z1#T.T.UMUMT.XL0ZSESESEXCXCXCX?0YX:X?Y%X:XDX:0YX:0YX:0ZXDXDXB0ZXDXD0ZXDV,V,V,0Z0ZT5T5T5V,0ZV,V,T.T.0ZT.T/0ZT/T/X:0ZY%Y%XBXBX=0ZXBXBX@X@V,0YV,T40Y0ZT4T4V&T4V&V&T4T40YT40YT/T4T4V&T9V&V&XLX9T9XLT9T9V&T9VIVFVIVFVDVGVDVGXJXJT9VHXFXFVHY&VHY&VHY&Y&SEY&SEY&SEY&SEVJVIVJVIVJVIVJVIVIVFVIVFVIVFVIVFVFVCVFVCVFVCVFVCVBVBVKVKVBVBVKVKVBVBVKVKVBVBVKVKVBVBVKXCVBVBXCXCVKXCVKXCVDVDXCXCVDVDXCXCVDVDXCXCVDVDXCXCVDVDXCXCVDVDXCXCVDVDXCXCVDVDXCXCVDVDXCXCVDVDXCXCVDVGXCVGXCVGXCVGT9VHT9VHT9VHT9VHVHY&VHY&VHY&VHY&Y&SEY&SEY&SEY&SEVJVIVJVIVJVIVJVIVIVFVIVFVIVFVIVFVFVCVFVCVFVCVFVCVKXCVKXCVKXCVKXCXCVGXCVGXCVGXCVGXMVHVGVHT9VHT9VHVHY&VHY&Y&SEY&SEVJVIVJVIVIVFVIVFVFVCVFVCVKXCVKXCXCVGXCVGYHYH/U/VYHYH/VYGYGX.YGYGYHYHYH/UYH/UYHYU/UY7Y7Y7XRY7/UYDY7Y7/UY7YU/UY7Y7Y7Y7/U/VY7/VYGYGYGYG/VYGYGYG/VY=YGX.X.X.X.X./U/VX.X.X&X&X,X,/UW3X,W;X,X,V=V=U8V=TWV)TWV)V)V?V)V?V)/QV)V)Y4Y4Y4/QY@Y@/QY@/Q/RY4Y4Y8/RY@Y@Y'Y,Y'/RYHYHYH/RYHY3Y3Y3Y3/QY3Y3/QYUYUYUYUYUY3YUY3Y3/P/QY3Y3/Q/RY3/RY3Y3YUYU/R/SY,/SY,/TYUYDYUYUYDY7YVYV/R/SYL/T/TYUY3Z&YUXRZ&Z&XRY;/SY;/SZ$Y;/TY7/TYVYVYLYLYL/TYL/TYLYL/T/UYVYG/UYGYGYG/UYGYL/VZ$Z$/VZ$Z$Z$Z$/V/V/WZ&/X/X/YYEYE/YYEYEYE/YYEYEYEYGYGYEYGYE/XYEYEYGYG/XYG/XY=/YYG/YY=Y=Y=Y=Y=Y=/YY=Y=YGY=Y=YN/XYNYGYGYG/XYGYGYG/XYG/XYGYGYXYXYX/X/X/Y/Z0#0#0$YNYNYN0$YN0%Y=X.0%X.YN0%0&0'X.X.0'X.0'0(0)0*0*X.X.X.X.0*X.WOX.X.VNVNX.WIVN0)0)0*0+X&WIX&WIWHX&X&WHWHX&X&WHX&WHWHWIWHWH0'VN0(0(WHVYVYX&X&X&0(WH0(WHWH0(WG0)WGWH0)VYVYVY0)VYVY0)0*W=W=0*WGVYWGWGW=WGW=W=0)W=W30)W3W3W3X,X,WUWUX,X,WUWUV=V=0'0(0(U>U>U>TWTWV=TWV=V=0'0(V=V=0(TOTWTW0(TWTWTWTW0(U>U>U>0(TLTL0(US0(TLTTTL0(TLTLTLTL0(TLTL0(V;TUTU0(TUTLTL0(TU0)0*TU0*TUTU0*V;TU0+V;V;UP0+V;UPV;UPUP0*UP0+V;V;UKUKUKU-UKU-U-0)U-U-U&V20)V2Y4Y4XEY@Y@Y@YIYIY@0'YI0(Y@Y@YIYIY@Y@Y@0'Y@Y'0'0(YI0(YIYIY'Y'0(0)0)0*0+Y,0+0,YIYI0,Y,0-0.YIYIYI0.0.0/YI00Y,Y,00Y,Y,000102Y,02Y,0303YK04YK04Y,0506Y,Y,06070708YM09090:YMYMY,0:0;0<0<0=Z#Z#YM0=YMYM0=0>0?0@Z&Z&0@Z&YK0@0A0B0B0C0D0EZ&Z&0E0FZ&Z&0F0GZ#0GZ#0H0HY-0I0J0J0K0L0M0MY00N0O0O0PY0Y00P0QY00R0R0S0TY+0TY/0UY/0U0VZ&0W0W0XY<Y<0X0YY<Y<0YYEY<Y<YEYEY<Y<0X0YY/Y/Y<0YY/Y/0Y0ZY/1#1#Y<Y21$1$1%1&1'1'1(1)Y<1)Y<Y<Y<YGYGY<1)Y<1)Y<Y<1)1*Y<Y<Y<1*YRYRY<1*1+1,1,Y<Z(1-1-1.YRYRZ(1.YRYG1.1/Y<Y<YGYG1/YGYG1/101111121314Z%Z%YGZ%Y<Y<131414YGYGYGYG14YG15Z%1516YG16YQ171818YQWJWJYQ18YQWJ18X.WJWJ1819YGYGWJWJY)19Y)Y)YGY)VTVTVQVQX.X.17WJX.X.X.17X.X.17X.1718VQVQ18VQVQVQVYVY18VYX(X(18X(X'18X'X'W3W318W%18W%WU1919WUWUWUW%WUWUWUWU18WUWU18X,WUWUX,X+X+X+WUX+WUWUX+X+WUWUWUWU15WU15X+16X+WRWRX%16U>TETETETETEU>U>TETETTTT13TTTTTTTETTTETETETE12TT12TLTLTLTL12TLTUTLTUTL12TUTU12TUTU121314141516U016171819U019U01:U01:1;UPV;V;V;1;1;V;1<UP1<1=UPUPV;V;1=1>V;1>UPUP1>UPUPUP1>U-XLU-YBYB1>1?YBYB1?1@YIYI1@YI1@1AYBYB1AYB1BYB1BYBYBYB1B1CYBYB1C1DYBYBYI1DYI1E1EYM1FYMYIYIYI1F1FYM1GYMYMYMYM1GZ'Z'YMZ'1F1GZ'Z'YPYP1GYPZ'Z'YMYM1F1GYMYJ1GY+YPY+Y+1GY+1H1H1I1J1KY+1K1LYSYWYWY*Y*1K1LY*Y*1LY/1M1NY/Y/1N1OYTYT1O1PYTYT1PYT1P1Q1R1SY/Y/1SXVYTYT1SY9YTXVY9Y9Y*1RY*Y*Y*Y*Y*1R1RY91SY9YRYGXVXVYGYG1RYGWZWZY9Y9WZWZWZ1QWZ1QWZWZ1QX/1R1SY91SY91T1TYG1UWZYGYG1U1V1VVW1W1XVWVWVW1X1X1YX#X#1Y1ZX#X#1ZXW2#X#2#2$VSVSVSVSX#2$VSVS2$2%WSWS2%WSWSWS2%2&VS2&VSVSWSWYWS2&2&2'VSVSWSWSVSWS2&VN2'VNVNVNVN2'VNVN2'2(2(2)2*W#2*2+W#W#WY2+2,2-2-2.2/2020W,21W,W,W,21W7212223W#W#W#W#X(22W#W#W#W#22W#W#W#W#X(X(X'X'WUWUX'WUWUWUWUWUWU2/WU2/20WM20WMWMWMWMWM2021WU21WUWUWUWU21WM2122WMWM22WT23WTX%X)X%X)U>U>U>2222TTUYUYU>22U>U>UYUY22UYU>U>2223U>U>2324TT24UYTTUY24UYUYUY24UY25UY25UYUYU/25U/U/2526U/U/26TTTMUUTTTLTLTLTLTL25TL2526TL272728TLUPTL28TL29TL29TL2:2:YBYB2;YBYB2;YBYBYBS0S02:2;S:S:2;S02<S0S0S0S:S0S0T'2;T'2;T'2<T'YMYMYCYCT'T'S0T'2:T&T&T&Y*2:Y*2;Y9Y92;2<2<2=WFWFY9Y92=Y9Y92=2>2?2?W(WFVZW(W(2?W(XV2?W62@2@W(2A2B2B2CS9W62CY9W(W(2C2DW(W(W(2DW(2E2E2F2GVU2GVUVUVUWQ2GWQWQ2GX#2H2IVU2I2JX#VU2JVUVUX#X#2JX#2JX#VU2KX#2KX#X#X#2KX#X#2K2LX#2MX#W72MW72MW7W7W7VS2MW7W7W72MW7W7X#2MX#X#W7W7W7W9W72LW7W72LW7W7W7W7W72L2MW,W,2MW9W7W9W9W92LW9W9W9W9W9W9W<W7W7W72K2KW92LW92L2MW92NW92N2O2PW<W<2PW<WT2PWTX%2PX%X%X%V:U/V:V:UFU/UFUFTMUUTMTMTMTMTM2MUFULUFUF2LTLTMUETM2L2M2NUEULULULTLTL2MTLUL2MULULTLTL2MTLULUIULUIULUL2LULUL2LULUL2LULUIUL2LXNUEXN2LUPXNXNUPUOUPUOUPUOUPUOUPU.U.U.X2SASASAS:S:SASASAS0SASZ2FS9T&S9S9VO2F2GVOWQWQWQS9WQS9S9WQWQS9WQVUVUWQWQW@2CWQ2DX#X#WQX#WQWQWQ2CWQ2CWQWQ2CWN2D2EX#X#2EX#WNX#W+W+X#2DW+2EW+2EW+WE2EX#2FXXX#2FX#2GX#W9X#W92FW<W<W<W92FW92G2GW<W<W<W9W<W9W9W<2FW<2GW<2GW<W<W:WUW:W:W:W:W<W<W:W:2EW:2EW:W:2FW<X$2F2GW<W<W<2G2G2H2IW)2IW)W<W)X$X$2IW<W<W<W<2IW<W<W)2IW<W<2IW<W)2IW)2JW<X-W<X-X-WU2IWU2IWUX-X-WUWUWU2IWUWUVXWUWUWUWU2HWUWU2HWUWUWU2HWUWUWXY$WXWUWX2GWXWXY$2GX%UFUFUF2GUFUI2GUIUI2GUIUIUHUHUIU*UHTH2FTHUH2FUHTHUH2FU*TAU7UZU7U7UZV-XMV-V-V%XMXM2CV<V5V52CV1U;2DU)U)TVUDXFSAXF2C2CS=S=S=S0SYSYSYS92BSHSHSHS1SHS1XWWQSHWQSHSHS1S1WQWQVM2?WQ2?VMVMW<W)W<W)W)X-2>X-WUWUX-X*X-X-VXVX2<X*VXVXVXVXX-VXX-2;X-VXX*2;VXVXVXX*VX2;VX2;VXVXWUWUVXVXVXVXY#WU29VXX*VX29W0X*W0WU29WUWUWXWXWXWDUI28XNXNU*V7TYTYV7V72728TI28TITITQU;28TITDTITITITITI27TIUDUDV6V4V#V#26TIS=S=262727S=S5S5S=S2S=S2S2S2S<S2XF25XFSBS<S2S<S-SBS<24SVS2T#S2T#S2S2S2T#S2S2S-S-T#T#21T#S.21S.S.S-S.S-21SYSY21SYSYSYSY2121SKSKSK21T$SMT$S.21S.SMT$SKT$SK20SKSKSKSKS@SK2020S@21SXSK21SKS@SXSX21SX21SX22SXSXSXSXS3SHSHSHSFSHS1SHS/S/2/S/S/2/S1S/S/S1VMS1S1S/2.S/S?VMVM2.XWW<W<2.W'W<W'W'W'VXVX2-Y#VXVXVXWK2,VXWKWKVX2,VXVXX-2,X-VXX*W0WKW0WKW0W0W0TITITD2*U,XLU,UXTJXKTJT@SV2(SVSV2(S.S-S.2(S.XES.2(2)2*2+2+SK2,SKSKSKS@S@SKS@2+2,SQSQSLSLS3S3S32+S7SJS7SJ2*S3SOSOSFSF2*SOSOSOSJSOSOSOSO2)SOSGSO2)2)SGSGSGSG2)2*SWVXVXW>2*VXVXVXW>W>W>2)W>W42)W4W42)W4W4W4WL2)WLWLY$W$W?2)2)W?W?W?W?W?WC2)WDWDWDWCXMU+U=U+U+U+2'U+U+U+2'U=U=U+U=U=T@U#T@2&T-U#T-U#U#U#U#2%SLS7SLS7S72$2%2&S7S7SJ2&SN2&XRSN2&SNSNSNS7SJSJSJ2%SJSJSJSJSJSJSOSO2$SO2%2%2&SO2'SOS8SO2'SGSG2'S>2'S>S8S>2'SW2(2)S>SWS>S>SWSW2(SWS>SWS>S>SWXW2'XWWLWLW4WLWLWC2&WCU=V*U=U=V*V*V*U<UBUBUB2$V$V$V$2$T-T=T-T=2#V.V.V.U#V(2#T=V(V(T=2#2#T=T=T=T=2#T=U@T=2#T=T=2#2$2%2&V(V(2&XJSNSNSN2&SO2&SP2'SPSP2'SOSOS>SPSPS>S>2&S>SPSPSP2&2&2'SR2(S6SRS6SRS6SR2'S6WCWC2'WCU=U=2'2(2(U<V,U<V,U<V,U<U<U<2'U<U<U<2'T;2'TGTGTGTGTG2'TG2'V.V.V.TGV.TG2'2'V.V.V.T=T=V.2'V.T=V.V.2&SNT(T(SPSPSC2&SPSPSPSDSPSDSDSDSC2$SCSCSDSDSC2$SRS6SR2$2$SRSDSRSDSD2$SDX>X;X>X;V,V,V,T6T2T2T6T2T1T5T1T51XT5T5T5T51XT5T5T/T/T/1XT8T01XT0T21XT2T21XT0T/T0T0T0T01X1XT;1YT;1YTGT;TGTGV.V.V.T;T;T;1XT0T0T01XT;T01X1YT0V.V.V.1XV.V.V.SC1XSE1YSC1YSCSESE1YSE1Z1ZSESSSESESESE1ZSESTSESEX;X;XDXDX;X;XDXD1W1XXDXDV,T6V,T6V,T6V,T31VT3T3T3V,T3V,T3V,T3T51UT3T31UT51UT01VT0T0T0T01VT7T0T71VT01V1WT.1WT.T.T.1WT.T.T.1W1X1YUMT01Y1Z2#2#UMUMUM2#V.UM2$2$2%UMV.T.2%T.T.2%UMT.2&SE2&SESEXCXCX?2&2&XDXDXDXB2&XBXBXBXB2&XB2&2'XBXB2'XBXBXBV,2'V,2(2(T5T5T5V,T5V,T/T.T.2'T.T5T5T/T/2&XBXBXBX=XSX@X@V,2%V,T4T/T/T42%T/T/2%2&T4T4V&T4T/T/T4T4YU2$YUYU2$Y72%Y7YHYH2%2&YHYHYHYUYUYUYH2%YUY7Y7Y7YUYDYUYDYDY7YDY7YUY7Y7Y7Y7Y7Y71YY7Y7YGYGY7Y7YGYGYGYGY7YG1VY=Y=Y=1V1WX&X&X&1WX&X&X,X,X,W3V?V?V)V?Y4Y4Y41U1UY@Y@1V1V1WY4Y4Y@Y@Y4Y4Y8Y8Y@Y@1U1V1W1XYH1XYUYUY3YUY3Y3YHYU1WYUY,1WY,Y,1WY3Y,1XY3Y31XY,Y3Y3Y31X1XYUY31YYUYUY,Y,Y3Y3Y,Y3Z&Z&1WZ&1WZ&1X1YXRYVYLYLYVYVYLYLYLYLYL1WYUYUY3YUZ&Y;Z&Z&Z$1UZ$Z$Y;Z$Y;Y;Y7Y7YVYVYLYL1SYLYL1SYLYLYVYGYVYVYGYGYV1RYGYG1RYGYVYVYLYLYLYGYLYLZ$Z$Y;Z$Z$Z$Z$YEZ&1NZ&Z&Z$Z$1NYE1NYEZ&YEZ$1NYEYE1NYEYEYEYLYLZ$YEYEYGYEYEYEYGYE1LYEYGYGYG1KY=Y=Y=Y=Y=YGYGYGYGY=1JY=Y=Y=1JY=Y=Y=1JYGYGYG1JYGYGYX1JYGYX1JYX1J1KYQYN1K1LYGYGYN1LYGYGYGYGYG1LYGYGYG1LYXYX1LYNYXYN1LYNYNYNYN1LYNX.X.X.Y=Y=1KYNYNX.YNYNYNYN1J1KYN1KYN1LX.X.1LX.1LYGYGYGYN1LYG1MYGYGYG1MX.X.1MX.X.1MX.X.X.1MX.WOVN1MVNVNX.X.X.1MX.X.X&X&X.1LX&X&WHWH1LWHVYVYVN1LVYWHVYVYX&X&X&WGX&WHWHWHWGWG1IWGWHWGWHWGWHVYVYVYVY1GVYVYWGWGWGW=W=W=1FW=WGWG1FWGW=1FW=W3W=W=1FW3V=V=V=1FV=V=1F1GV=1GU>U>V=V=U>U>V=V=U>1FV=V=1FU>TWTWTTTTTWTWTTTTU>TEU>1DTT1DTTTT1D1ETLTL1ETLTLTLTL1ETLTLV;1EV;V;1ETU1F1GTUTUUGTU1FUG1G1HTUTUTLTLTU1GTUTU1GV;TUV;V;V;TUTU1FUKUPUKUP1FUPUKUP1FUPUPU-U-U-1FTBTBTBV2Y@Y@Y61E1EY6YI1FY@Y@1FYIYI1FYI1G1G1H1IY.YI1IYIYI1I1JY.Y.1J1KY.Y.Y'Y'1K1L1L1M1NY,1N1O1P1Q1QY.YI1RY.Y.1RY.Y.Y,1R1S1S1TYIYI1TY,1U1V1V1WZ)Z)YI1W1X1Y1YZ)1ZZ)1Z2#2$2%Y,Y,2%2&Y,2&Y,2'Y,Y,Y,2'Y,2'2(2)2)2*2+YKY,YKY,Y,2*YKYKYKYKYKY,YK2)Y,2*Y,2*2+Z)Z)2+2,Z)Z)2,2-2.Z#2.Y,Z#2/Z)Z)Z)2/Z)Z)2/20YM20YMYMZ)20212222YMYMYMY,Y,Y,2222232425Z#25Z#Z#25Z#Z#Z#2526Z#Z#2627YMYM2728292:2:2;Y?Y?2;2<Z'Z'Y?Y?Z'Z'Z&Z&2;2<YKZ&YKYKYKYKYK2;YKYK2;2<2<Z&YKYKZ&Z&2<2=YKYK2=2>YK2>2?Y-2?2@Y-Y-Z&Z&Y-Y-2?2@Y-Y-2@Z&Y-Y-Z#2@Z#Z#Z#2@2A2B2BY-2C2DY02DY0Y02D2EY0Y0Y?2EY?Y?2E2FZ'Z'2F2GZ'Z'Z'Z'2G2HY0Y0Y02HZ'Z'Z'2HZ'2H2I2JY-Y-2J2KY-2K2L2M2M2NY0Y02N2OY0Y0Y0Y/2OY/Y0Y02O2PY0Y02P2Q2QY+2RY+Y02RY/2SY/Y/Y+2SZ&2SZ&Z&2SYEYEYE2SY<Z&2TYEYE2TY<YEYEY<Y<Z&Z&2SY<2SY<Y<Y<YEYEY<YEYYYY2RYYYYY<2R2SY<Y<Y<2SY<Y<Y/Y/Y<2RY2Y2Y2Y2Y/2RY<Y<2R2S2SY<Y22TY2Y2Y22TY22TY<Y<2TY<2U2VY<Y<2VY/YEYEYE2VYEYEY<Y<2U2VY<Y<YGY<Y<Y<YGYGY<Y<Y<2TY<Y<2T2UY<Y<2UY<Y<Y<Y<Y<Y<2UY<Y<2U2VY<2VY<Y<2VZ(Z(Z(Y<Y<Z(Y<Z(Y<Z(Y<Y<Y<2TY<Z(Z(Y<Z(Z(Y<XVXVYGYGY<2RYGYGY<YGY<2QY<YGYGYGYGYQYGYG2PZ%2P2QZ%Z%YQ2QYQYQ2QYQYQYQYQYQZ%2QYQYQZ%Z%Y<2PY<Y<2PYGYGYGY<2P2Q2R2RZ%Z%Z%YG2RYGYGZ%Z%Z%YG2QYGYGYG2QYQYQYQYQYQ2Q2RYQYQ2RYQZ%WJ2RWJYNYNYQYQYNYNYN2Q2Q2RYGY)Y)WJY)Y)Y)VTY)Y)WJ2PWJWJX.X.VRVR2OX.VRX.VTVTVT2OVTVT2O2PVTVT2PVQVYVYVNVNX(X(2OX(2O2PX'X'2PW%W%W%W%W%W&W%2O2PWUWUW%W%2PWUWU2PWUWU2PX,X,X,WUWUWUX+WUWUWUX+2NX+X+X+WRWRX%X%2MTT2NTTTT2NTTTTTTTTTT2NTLTUTLTU2M2NTL2O2OTUU0U0TUTU2O2PTU2PUPUP2PV;UPUPTLTLTLU0TLU0U0U0TL2NTL2OTLU0TL2OU0U0U5U0TL2NTLTL2NU22OTLU0UPU0UPU02NU02OU0UPUPUP2N2OUPUPV;V;V;2O2OV;V;V;V;UPUPUPV;V;V;UPV;2MUPUPV;V;UPUPV;V;UPUP2KUPUPUP2KUPUPUPUPUKUPUKYB2JY>Y>Y>2JY>Y>2J2KY>Y>YBYB2KYBYIYI2KYIYB2KYBYBYIYIYBYBY>2JY>2KY>2KY>YBY>2KY>YBYIYIYBYBYIYIYB2JYIYI2J2KYIYI2K2L2LYM2M2NYI2NYIYIYMYM2NYM2NYMYIXRYIYIYI2N2NYMYIYMYIYMYIXR2MYMYMYMZ'2MZ'Z'YPYP2MYPYPYPZ'2MZ'2MZ'Z'2M2N2O2P2P2Q2R2SY/Y/Y+Y+Y+2RY+Y+YJYJYJ2RYJ2RYW2SYJ2SXRYWYWYWYW2SY+Y+2SY+2S2TYSYS2T2UYWY*2UY*Y*Y*2UY/Y/Y/2U2V2WYTY/Y/YTYTY/2VYTYT2V2WYTYTYSYTYSYTYTYTYTY*YTYT2UYTY/Y/2UY/Y/Y/2UY/2UYTYTYTYT2UYTYT2U2VYTYT2VY92WY9Y*Y*Y*Y9Y*2VY*Y*Y*Y9Y9Y92UY9Y*Y*YGYGYG2UWZWZY9WZYGYGWZWZY92SY92TY92TY9Y92T2U2VX#2VX#X#X#Y9X#Y9X#YGYGWZYGWZWZ2TWZYGYG2TYGYG2TYGVWX/VWX/VWX/X/2SX/VWVWX/VWVWVW2RVW2R2SX#X#2S2TX#X#2TX#X#X#X#VWX#2TVWVW2TVWX#VWX#X#WSWSVSVSWSWS2R2SVSVSX#X#VSVS2RVSVSVS2RVS2RWS2SWSVS2SVSVSWSWSVSWSVS2RVSVSWSWYWS2R2R2SVS2TWSWS2TWSVNVN2TVNWP2TWPVNVNVNVN2TVNVN2TWYWYW#W#W#2SVNW#W#VNVNW#W#W#W#2R2SVNW#W#W#W#2RW#W#2R2S2TWYWYWY2T2U2U2V2WW,WY2W2X2Y2Y2Z3#3$3$3%W#3&3&3'W#W#W,3'WS3(WS3(WSW,W,W,3(W,3(3)3*3+3+3,3-3.3.3/W#W#3/30W#W#VNVNW#W#3/WUWMWMWUWU3/WMWU3/30WMWU30WMWMWMWMWM30303132WTWUWUWU32WUWUWU32WU32WMWM32X+WMX+WMWMWM323233WTWTU>U>U>33U>TTU>UYU>32U>3333UYUYUYU>33XPV:3334V:V:V:34V:V:V:34V:U/TTTT34TT34TTUYUYTTTTUYTTUYTTUY33UYTTUYTTUYUYU/32UYUYU/U/UYTT31U/3132UUUU32TLTLTLTL32TLTLUPUP3233TLUPTLUPTLTLTL3232UPUPUPUPUP32UP32UP33UP33UPTLUPTLUPUPUP32YBYBYBYBYBS:3232YB33S:S:33S:S:S:S0S:33S0S033S033S0S0S0S033S034S0S0S034S034T'T'T'T&34T&Y9Y93435Y*35Y*Y*35Y9Y*XV35Y9Y*Y9WFW-WFWFW-34WF35Y9Y9W-W-Y9Y93435Y935363737W(W(W(W-W-37WF3738393:VZVZ3:3;3;3<3=W/3=W(3>W(3>3?VOVOW(W(VOVOW.3>S93?3?3@W63AY9Y93A3BY9Y9Y9W(Y93AW(W(W(W(W(3AW(3AVUVU3AY9W(W(3A3BVUVU3BVUVUVU3B3CVUVUWQVUWQWQX#X#3BX#3BX#VU3CX#X#3CX#3CX#X#X#VU3C3D3E3EX#3FX#3FX#VU3GVUVUVU3G3GX#3H3IVSX#X#X#3HVSX#X#VSVSVS3HVSVS3HVS3HVSX#VSX#X#X#W7VSVSW7W73F3GW7W7W73GW7W7W7W7X#3GW,3GW7W73GW7W7W7W7W7W73GW7W73G3HW7W93HW9W7W9W9W9W73GW7W7W73G3H3I3IW9W9W9W93IW93J3JW<3KW<W93KW9W9W93K3L3MW93MW93N3NW<W<W<W<W<3NW<WTWTWT3NWTY%X%Y%TMTMULULUU3LUUUUULUEUL3LTM3LTMUL3LULULULUE3LULUEUETLUE3LTLTLUE3LULUL3LUL3L3MUEUEUIULUI3M3MTLUEUETL3MXNUPT&S9T&3MS9S9S93M3MWQWQWQW@3MW@W@W@W@WQ3MWQWQWQ3MWQ3MWQWQVVWN3MWNWNWNWQWNWNWNW+W+X#X#WEX#X#3JW+3KW+W+W+WE3J3KWEWEWEX#3KX#3KXXWEWE3KW7X#3LX#3LX#X#W9W9W9W<W9W9W93KW9W<W<W<3JW<W<W<W<W<3JW:3JW:W<W<W<W:W<W<3I3JW<W<W:3JW:W:W:W:3JW:W<W<3JW<X$X$W<W<W<W<W<3IW)W)3I3J3JW<W)W)3J3K3LW)3L3MW<W)X$X$W<W<W<W<W<X-W)3KW)W)3KW<W)W<W)W)3KW<W)W<W)W)X-WUWUWU3IWUX-X-WUWUVXVXWUWUWU3HWUWU3HWUWUWU3HWUWUWXWXWXWXY$WXX%UFUFT>3FUFUFUIUIUI3EUIUIUH3EUH3FUHUH3FTHTH3FTHTAV%3FV%V5T+T+T+3FV3T,3FT,XFSASA3FSZSZ3FS=S9S9SHSH3EWQVMVMWQWQVMVM3DX-W)X-X-3DVXVXVXVXX-VXX*X*3C3DVX3DVXVXVX3DVXVXVXVXX*VXW0W0X*W03B3CWUWUUI3CUIU*TYV7TYV7V7V7V7UAT:T:3AT:3ATQTITITDTDTD3A3AV#TITIS=S=3AS4S=3A3B3CS=S=S=3CS<S<XFSBSBSBSBSVS-T#S-S-T#3@S.S.3@S.S.S.T#SYT#T#SYSYSKSKSYSKSKSKSMT#SM3=SMT$SMT$SYSKSKSKSK3;SKS@SKS@SKS@3:S@S@S@SKS@SKS@39SXSXSXSXSX39SX39SXSXSXS1S1S/S/S1S1S/S/S1S1S?S?S?S?36SUW<W<W<W'35VXVXVXVXVXWKWKVXWKVXWKX-VXX-VXTITITD3232S-S-S-S-S-S-S.S-S-S-S.S.30S.31SMSMSM31S.31S.S.313233SMT$T$T$33T$33T$XESKSKXRSQS@S@SQS@S331S3S3S3S331S331SOSOSOSOSOSO3131SG32SGSOSO32SGSGSWSWSW3132SGSWW>VXW>W>W>W>W431W431W4W4W>31W432W?W?WLW?W?31W?W?Y$W?W$31W?W?WCWCU+U+U=U+U+U+U+U=U#U#3.U#U#U#U#3.S7S7S73.S73.XRSNSNSJ3.SJ3.SJSJSJ3.SJSNSN3.SJSNSNS7S73.SJSOSGSO3.SO3.3/SISOSOSO3/SISISI3/S8S83/S8SOS>SOS>3.S>SISISI3.3/3030SWSWSWS>30S>S>30SWS>SWSWSW30SW30S>S>S>30WCWCWCUB30V$V$V$V$V$30V.30V.V.V(V(T=30V(V(30U@T=30T=T=30U@T=U@T=U@T=T=V(U#3/V(3/U#V(V(V(V(3/V(V(V(V(U@3.V(U@U@SN3.SNSOSOSO3.SOSP3.SPSP3.SO3/30S>S>SP30SPS6S6S6SPSPSP3/S6S6S63/SR3/SR30S630SRSRW4WCW4WCU=U=U=3/U=V,V,V,V,U<V,V,U<U<3-T5U<U<T5T53,TGTGTGTGTGTG3,TPTP3,V.TGV.3,V.TG3,TGV.V.T=T=T=SNSNT(T(SD3*SCSDSCSDSCSDSDSDSE3)S6S63)SRSD3)SDSDSDSD3)SDT53)T5T5T5T;T53)T/3)T/T/T83)T8T0T/T/T2T/T/T03(3)T0T0T03)T;T;3)T;3)3*T;T;T;3*T;TGT;3*T;T0T03*3+V.3+T0T0T0T0T0V.V.T0V.3*V.SC3*3+SESCSESESESCSCSC3*SESESE3*3*SSSSSSSESESSSSSESE3)ST3)XDXDXDXD3)XDXDT3T6T3T3T53(T53)T3T33)3*3*3+T73,T7T0T7T0T0T0T03+T0T0T5T5T0T03*T.T0T.T5T.T03)T.T.T5T.T5T.T03(3)UMUM3)UMUM3)UM3*UMT03*T03+T0T03+T0T03+T0UM3+UMUMUMV.V.V.3+V.V.UMUMUMV.UMUMV.V.3)V.3)UMT.T.UMUM3)UMUMUMT.T.3(SSSESEXCX:X?X:X:3'X:XDXD3'XBXBX:XB3'XBXDXD3'XBXDXDXBXBXD3&XB3'V,T5V,T5V,T5V,T5T5T5V,T5T5T.T53$3$XBX:XBV,V,V,T/T43#T4T43#T4T4T4T43#T4T4Y7Y73#3$Y7Y73$Y73$Y7Y7Y7YHYH3$YGYHYH3$3%YHYUYUYUY7Y7YGYGYGY=Y=Y=2Z3#X.X&3#3$X&X&3$X.X&X&Y43$3%Y@Y4Y43%Y@Y@Y@3%Y@Y@Y43%Y4Y43%Y4Y4Y'3%Y'Y'3%Y,3&Y,Y'Y'Y'3&3&Y,3'Y,YH3'YUYUYHYH3'YHY3Y3Y,Y,Y3Y3Y,3&Y,3&Y,Y,3&Y,Y,Y,Y3Y3Y,Y,Y33%Y3Y33%YUYUYUY,Z&Y,Z&Y,3$3%3&3&Z&Y,Y,Z&Z&3&Z&YLYL3&3'YLZ$Z$Z$YLYL3&YLYVYV3&3'YV3'YVYG3'YGYGYGZ&Z$Z&Z&Z&YEZ&YEZ&YEZ&Z&Z$Z$YEYEYEZ$YEYEYE2ZYEYE2Z3#YGYGY=YGY=Y=Y=Y=YNYNYNYN2YYN2YYGYXYXYGYGYXYXYG2XYGYGYXYNYX2XYNYN2XYNYG2XYGYG2XYNYGYGYNYN2XYGYGYGYNYNYGYGYG2WYXYNYNYNYN2VYNYNYN2V2WX.Y=Y=YNYNYN2VYNYG2VYNYNYNYNYN2VX.2VX.YNYNX.X.2VX.YNYGYGYGYN2UX.X.2UX.X.X.YGYGYG2U2UX.2VX.2VYGX.2WX.X.2WX.WIWIVNWIX.X.2V2WX.X&X&X&WHWHWHVYVYVYVNVYWHWGWHWHWGWGVYWG2RW=W=W=WGWGVYWG2QW=W3W3W=W32QW3V=2QV=U>2Q2RU>U>2RV=U>U>U>U>2RU>2RV=U>U>V=V=U>U>2QTETETETLTLTTTTUT2PUTUTTLTLUTTLV?2OTLTLTLTUTL2OV;V;2O2PTUTUUGTUTL2OTLTLUG2OTLTL2OUGTLUGTLTLTL2OUGTU2OTLV;V;TU2OV;V;2OV;UKUK2OUKUPUK2OUKUPUKUP2O2OU$U$U$Y6YIY6YIY6Y6Y62NY:Y:YIYIY@2MY@YIY.Y.2MY.2MY.YI2NY.2NY.Y.2NY'2O2PY.Y.2P2Q2Q2RYI2SY'Y'2S2T2T2UY.Y.2U2VY.Y.Y'Y'2V2WY'2WY'2X2X2Y2ZY,2Z3#Y'3$3$Y,3%Y,3%Y,Y,Y,Y'Y'3%3&3&Y,3'Y,3'3(3)3*Y,Y,3*Y,Y.Y.3*3+Y.Y.YIYI3*Y.YI3+Y.YA3+3,Y,Y,YAY,3+3,YIYI3,3-YIYIY,Y,3-Y,3-3.YIYI3.YIYIYIYIYIYI3.YIYIZ)YIYIZ)Z)3-YI3-YI3.3.YI3/YIZ)Z)3/Z)YIZ)YI3/YI3/YI3030YM31YMYIYI3132YMYM32YM3233YIYI33Y,343535Z&36Z&36Z&37Z&Y,Y,3738Y,Y,Y,38Y,3839YK393:YKYKY,Y,Y,YKY,39YKYK39YKY,YK39YKYKYKYI39YI3:3:Y,3;Y,3;3<3=3>3>3?3@Z)3@3AZ)Z)3A3BZ)Z)3BY,3C3DY,Y,Z#Y,3CZ#Z)Z)Y,Y,Y,Z#Z#Z#Z#3B3BYM3CYMZ)Z)YM3CZ)YM3CYM3CYMYMYMZ)Z)3C3D3DYMYMYM3D3EYMYMZ)YM3EYM3E3FY,3GY,Y,Y,3GY,Y,Z#Z#Z#Z#Z#YMZ#Z#YMYMY,3DZ#Z#Y,3D3EZ#YKYKZ#Z#YKZ#Z#Z#YMZ#YMYMZ#Z#YMYMZ#Z#YMYMZ#Z#3@3AYMY?YM3AY?Y?3AY?Z#Z#3AZ#Z#Z#Z#Y?YM3@3A3B3BY?3C3DYKZ&YKYKZ&Z&3CZ&YKYKZ#YKYKYK3BYKYKYK3B3CZ&Z&YKYK3B3CYKYK3CZ&3D3EYKYK3E3FYKYK3FY-YKYKY-Y-YK3EY-Y-Z&Z&Y-Y-3DZ&Y-Y-Z&Z&Y-Y-Z&Z&Y-Y-Z&Z&Y-Y-Z#3AZ#Z#3A3BZ#Y0Z#Z#Z#3B3BY03CY03CY-Y-Y-3CY-3D3EY-Y-3EY-Y03EY0Y03E3FY0Y03F3GY0Y03GZ#Y?Y?3G3HY?3I3IY03JY0Y?Y?Y?Z'3IZ'Z'Z'Z'Z'YPZ'Z'Z'YPYPY0Y03GY0Z'Z'YPZ'Y0Z'Z'Z'Z'Z'3E3FZ'Z'Z'3FY-Y-3FY03FY0Y0Y0Y-Y-Y-3F3FY0Y0Y03FY0Y0Y0Y-Y-Y0Y0Y-Y-Y0Y0Y-Y-3D3E3E3F3G3HY03H3IY/Y0Y0Y03IY03IY03J3JY0Y+Y+Y03J3K3LZ'Y+Z'Y+Z'Y+Z'3KY0Y03KY/3KY/Y/Y/Y/Y/Y+3KZ&YEZ&3KYEYE3KYEZ&Y<Z&Y<Y<Y<Z&Y<YE3IY<Y<Z&Z&Z&3IZ&Z&Z&Y<YYYYY03HYYYYY/3HYYYY3HYYY<Y<Y/Y/Y<Y<3GY<3GY2Y/Y/3GY<Y2Y2Y<Y<Y23G3GY<3HY<Y<Y<3HY<Y23HY2Y2Y23HY23IY2Y23IY23IY<Y/Y/3I3J3KY/3KY/Y/Y/YEY<Y<Y<3JYEY<Y<YEY<Y<Y<Y<YGY<Y<YGYGY<Y<3GYG3HY<YGYGYG3HY<Y<Y<3HY<Y<Y<Z(Y<Y<Z(Z(Y<Y<3F3GY<Z(3GZ(Y<Y<YRYRYGY<Y<Y<Y<YGY<3EYG3EZ%Z%YGYG3EYGYQYQZ%YQ3D3EYQYQ3EYQYQYQ3EZ%Z%Z%Y<Y<Y<YG3D3EYGYGYGYG3EYGY<Y<Y<3E3EYGYGYGYG3EZ%Z%YGZ%YGYGZ%Z%YGYGYG3CYQYQZ%YQZ%YQYQYQYQZ%YQYQ3AYQZ%Z%WJWJ3@X.X.X.Z%Z%Y)Y)3?3@Y)Y)WJ3@WJWJX.X.3@X.VTVTVT3@VTVT3@VQVT3@VQVQ3@VQVQVQ3@X(3AX(W3W33AX'W3W33AX'W3W%W%W%3@3AWUWU3AWUWUWUW%W%W%WUWUX,WU3@X,X,3@X,WUWUWU3@U>TTU>3@U>3@U>TTTETETTTTTTTLTLTLTUTUTU3>TUTUTU3>3>U0U1U0TUTU3>3?TUTUTU3?TUV;3?V;TUTU3?3@TU3@3AUP3AU0TLU03AU03BU03BU53CU5TLU3TLTLU5U5TL3BTL3BTLTLUPUP3BUP3BUPUPUPU9U9U93B3B3C3D3EV;UP3EUP3EV;3FV;3F3G3H3IV;V;3I3J3JUPUPUPYB3J3KY>YBYBY>3KYBYB3KY>YBYBY>Y>Y>3JY>3K3KYI3LYBYBYIYBYBY>YBY>YBY>YBY>YBYBYBY>YBYBYB3HYB3H3IYBYB3IYI3JYBYIYI3JYB3J3KYBYBYIYBYBYB3J3KYIYIYIYMYIYIYMYM3JYMYIYIYI3JYMYM3JYM3JYM3KYMYIYIYI3KYIYMYIYI3J3KYMYMZ'YPZ'Z'Z'YPZ'3JYPYP3JYPZ'3JZ'Z'YPYP3J3KYPYJYPYJZ'3JZ'Z'3JYJZ'YJZ'3JYP3K3KY+3LY+YP3LYPYPY+Y+YPY+Y+3KY+3LYJYJ3LYWY+Y+3LY+Y+Y+3L3M3MYW3NYWYW3NYWYWY+Y+3NYSY+3NYSYS3NYSYSYSYSYSYWYSYSYS3M3NYSYSY*Y*Y/Y/3MY/YT3MYTYT3MY/YTYTYTYTY+Y+Y/Y/YT3LY/Y/3LY/3L3M3NYTYTYTY*Y*Y/Y/Y/3MY/Y/3MY/YT3MYTYTYTY/YTYTY/Y/YT3LY/Y/3LY/YTYTYT3LY*3LY*3MY*3MY*Y*Y9Y9Y*Y93LWZWZWZWZX/3LX/Y9X/X/X/X/X/Y93KX/X/3K3LX/X/3LX/Y9Y9Y93LX#X#Y9X#WZWZWZVWVWYGVW3JYGYGYGVWX/X/3IVW3IVWX#X#3IVWX#X#VWVW3IVWX/X/VWX/3HVWX/X#VWX#X#X#VWVW3GVWVWVW3GVWWSWSVS3GWSWS3GWSVSVSX#X#VSVS3FVSWSWS3FWSVSWSVS3F3FWSVSWSVS3FVSVSWS3FWS3GWSWSVS3GWSWS3GWSVS3GVSVS3GWSVSVSVNVNWP3G3GVNVNVNVNVN3G3H3HWY3IWYVNVN3I3JW#W#3J3KW#W#3KW#3K3LW#W#VNVN3L3M3MWYWYWYVNWYWYWY3L3MW,W,WYWY3M3N3N3OWYWY3O3PW,W,WYW,3PW,WYWYWY3PW,3PW,W,3PW,W,W,WYWY3P3QWY3QWYWYW,3Q3R3S3SWYWY3T3T3UW#W#3UW,W#W#W#W#W,W,W,3T3U3V3V3WW#3XW,W,3XW,WSW,3XW,3XW,WSWSW,W,3XW,3XWYWYWY3X3YWYWYWYWY3YWYWYWYWY3Y3YW#WY3ZW#W#3Z4#4#4$4%W#4%4&W#W#W#4&W#W#4&4'W#W#VNVN4'4(VNVN4(4)WUWUWU4)WUWUWUWM4(4)4*WMWU4*WUWM4*WMWMWMWM4*WTWTWMWMWM4*4*4+WTWT4+WTWTWTWU4+WUWUWUWM4+WM4+WUWMWMWUWU4+X+WMWMWM4+WT4+WTWT4+WTWTWT4+UYU>UYU>UYU>4+4+4,U>UYUYUYU>UYU>U>V:V:U>U>4*4+U>U>V:V:4*4+V:V:4+4,4-UY4-TTTTTTUYTTUYTT4,TTUYTT4,U/U/U/4,U/U/U/UU4,UUUU4,TT4-TT4-TLTLTLTL4-TLTLTL4-TLU:4-UPU:UPTL4-TLUPTLUP4-UPUPUP4-UPUPUP4-4.TLUP4.UP4.UPTLUPYBYB4.YBYBYBS:S:YBYBYB4-YB4-S:S:S:S:S:4-4-4.S:4/S0S04/S04/S0S:S0S0T'S0S0S0T'S0T'S0S0S0T'S0T'T'T'T'T&T'T&4*Y9Y9Y9Y9Y94*Y9Y*4*Y*Y*Y*Y9Y*XVY9Y9Y94)W-W-4)W-4)4*WFWFY9Y9W(W(Y9Y94)Y9Y9Y9Y94)W(4)W(W(Y9W(W(W(W(W(4(W(4(WFWFWFVZ4(VZVZ4(4)VZVZVZVZVZ4)VZVZ4)W(W6VZW6W6VZ4(W6W6W6W6W64(W6W64(4)W64)W64*VZ4*4+W(4+W(W6W(4+4,VO4-W(W(4-W(W6W6W.4-4-W6W6W6W6W6W6W/4,W/W/VOW6VOW64,Y9Y9W(W(4+Y9W(W(Y9Y9Y94+W(4+W(W(W(VU4+VUY9Y94+Y9Y9Y9W(4+Y9Y9VUVU4*VUVUVUY9Y9VU4*Y9Y94*VUX#X#4*X#VUX#VU4*X#X#VUVUX#X#VUX#4(X#VUX#4(X#X#X#VU4(VU4)4)X#4*X#X#X#VUX#4)X#VUVUX#X#VU4)VUX#VUVUVUX#VUVUVUX#VUX#VU4&4'VU4'X#4(X#X#VSX#X#VSVS4'4(VSVS4(4)4)4*X#VSVSVSVSW7VSVSW7W74(WS4)4*X#W7X#X#4)W,4*4+4+W7W7W7W7W74+W9W7W7W9W9W74*W9W9W9W9W7W9W7W7W74)4)4*W7W74*4+4,W9W7W9W9W94+W9W9W9W94+W9W9W94+W9W9W<W<4+W<W<W<W9W<4*W<4+W9W<W<4+W<W9W9W94+W<W<4+W<W9W9W94+W94+W9W<W9W<W<W<W9W<W<W<WTWTWTX%TLTL4(TLUEUEULUETMTMTM4'TM4'TM4(UETLUE4(UE4(UEUETLTL4(TLULUL4(UI4(4)UEUETLTLUE4)UIULUIULTLTL4(UETL4(UPUPS9S9T&S9S94'S9WQ4'WQWQWQ4'4(W@VU4(WQWQWQWQVV4(VV4(VVWQVVVVWNWNWNW+WEW+4'W+4'W+W+W+4'W+WE4'WEWEWE4'W+W+W+4'W+4(WEW7W74(W9W9W94(W94(W9X#W9W9W9W94(W9W<4(W<W<W<W<4(W<4(W<W<W<4(W<W<4(W:W<W:4(WUW:W:W:W:4(W<W<4(W<W)W<4(W<W<W<4(W<W<W)W)W<W)W)W<W)W)W<W<4&W)4&4'W)W)W)W)4'W)W<4'W<W<4'W)W<W)W<W<W)W)W<W<W)W)4%4&4'4(X-WUX-4(WUWU4(4)WUWU4)WUWUWU4)4*UFUF4*UIULUL4*UIUHTH4*TH4*THTHTHUHTHTHTHTHTHTA4)V5V<V54)4)4*4+4,V3V3V3T,SA4+SASZSZSZS=4+WQWQ4+WQW)W)W)X-4*X*VXVXX*X*VX4*X*X*4*VXX*X*4*4+VXX*4+X*WU4+4,WU4,W14-4.4.U*UIU*T:T:TI4.TQTQTITI4-TITDTIV#V#TITIS4S4S44,S=S=4,S4S44,S=S=S4S=S=S=S=S=S5S54*4+S.S.S-S.4+S.SMT$SMT$S@4*S@S@SKS@SKS@4)SXSXSXS@SX4)SXS@4)SXS@4)SUSUSUX-VXX-VXTDTDTD4(S-S-SVS-S.SM4'SM4'SM4(SMSMT$SMT$S.SMS.S.SMSM4&4'SM4'4(4)S.SMS.S.T$T$T$4(T$4(T$T$S3S3S34(S3S3S34(SFSFSOSFSO4'SOSGSGSG4'SG4'SGSOSGSOSOSOSGSGSGSG4&4&SW4'SWW>W>W4W4W>W>W4W>W>W>4%4&4&4'W4W4W?W$W?W?W$W?4&W$U#U#T-4&U#U#V(U#S7S7SNS7S7S7S7SNSNSJSNSJSJ3ZSJSJ3ZSJ4#4$SJSJSNSN4#4$4%SJ4%SG4&SGSGSGSG4&SO4&4'SISO4'SO4(SI4(SISI4(S8SOS8SGSG4(SISISISI4(4(S8S84)S>4)S>S>SGSWSGSWSWSWS>4(SWSW4(SW4(SWS>SWSWS>S>S>WLWC4'WCUBV$V$V$V$4&V$TPV.T-V.V.V(V(4%4&V(V(4&4'4'4(T=T=T=4(T=T=V(U#V(V(U#U#U#4'V(V(U@4'V(V(4'V(SNSOSNSO4&SOSPSO4&SOSPSPSOSOSPSOSPSPSP4%SOSOSPSOS>S>SP4$SP4$SPSPS6S64$S64$S6SR4%SR4%SRSRS6S64%S6U=4%V,V,4%T1T1T5U<U<U<4%TGTG4%TGTPTPTP4%TGTGV.V.TG4$TGV.4$SPSDSDSESDSESES64#SRS6SD4#SDSDSDSD4#SE4#T1T5T5T04#T0T0T8T8T/T8T8T0T8T0T/3YT/T/3YT0T/T0T0T0T03YT;T;T03YT03YT0T03YT;T;T;3YTGT;TG3Y3ZT;4#4#V.V.V.4#V.V.V.T;4#T0T04#V.V.V.SCSC4#SESCSCSC4#SCSESESESESE3Z4#SE4#SE4$SESTSTSTX;X;X;XD3Z4#XDXDT3T34#T34#4$T5T54$T3T54%T3T34%T3T74%T7T7T0T04%T0T7T0T7T04$4%T.T.4%T0T.T.T04%T.T.4%V.4&UMT0UMT0UMV.V.4%4&T0UM4&UM4&UMUMUMT0T0T04&T04&T0T04&T0T.4'T0T0T0UMUMUM4&UMV.V.4&4'V.V.4'V.T0T0T.T.4&UMT.UM4&SSSESSX<X<XDX<XDXD4%XDX:XBX:XBXB4$XBXBXDXD4$4%4%XBXBXBT54%T5T5X:XBX:XB4$4%T4T44%4&T4T4T44&T4T4YU4&YUYU4&4'YU4(Y7Y74(Y74(4)Y7Y7YHYGYGYGYHYHYGYGYHYHYGYGX.4&X.X.4&X.X&X&X.X.4&4'X.X.X&X&X.X.X&4&Y44&Y@Y@Y44&Y@Y@Y44&Y@Y@Y@Y@4&Y@Y44&Y4Y4Y@Y@4&Y@Y'4&Y'Y'Y,Y,Y'Y,Y'Y,Y'Y,4$Y'Y,Y,Y'Y,4$Y,4$Y,Y,Y,YHYUYUYUYHYH4#4$Y3Y3Y34$Y,4$Y,Y,4$Y,Y,Y,4$YUY34%Y3YUY3Y3Y,Z&Y,Z&Y,Y,Y,4#4#Z&4$Z&4$Z&Y,Y,Z&Z&4$Z&4$4%Z$Z$YLYLZ$Z$YLYLZ$Z$YL4#YLYL4#YV4$YVYVYGYVYVYGYG4#YGYEYGYEYEY=Y=YGYGY=Y=YGYGY=YNY=Y=YGYGYGYXYXYXYGYXYXYNYXYXYNYN3TYNYGY=YGYGY=Y=YGYGYNYGYGYGYGYGYGYNYXYNYNYNYNX.3OX.YN3OYNX.YNYNYN3OYNYN3O3PYNYN3P3Q3QX.YNYNX.X.3QX.3QX.X.X.YG3QYGYGYG3QYG3RYGYG3RX.3RX.X.X.3R3SYGYG3SYGX.X.3SX.WOWOX.3SX.X.3S3TX&X&3T3UW=W=W=W=W=3U3UW3W3W3V=V=V=3UV=V=3UV=V=V=V=3UV=V=3UV=V=U>V=U>V=V=3T3UU>TETETEUT3TUTUTV?V?3T3UUGUG3UUGV;V9V;3UV93U3VV;UGUGTLTLTUTUUGUG3TUG3UTLTL3UTLTL3UTU3VTLV;V;TUTUV;V;3UTUUKUK3U3VUPUPUP3VUK3VUPUPU-U$U$U$Y6Y6Y6Y:Y@Y@Y@YIYIY.YI3SYI3SYIYIYIY.YIYIY.Y'Y.Y.Y'Y'3QY'Y.Y'Y.Y.3PY.Y.Y.Y.3P3Q3R3R3SYI3TY.3TYIYIY.Y.3T3UYI3UYIYI3UY'Y.Y.3U3VY.Y.Y'Y'3V3W3WY'Y.Y.3WY'Y.3XY'Y'3X3Y3Y3ZY.Y.3Z4#Y.Y.Y'Y'Y'4#4#4$Y'4%Y'Y'4%4&Y'Y'4&Y,Y,Y,4&Y,Y'4&Y'Y'Y'4&Y'Y'4&4'4(Y,4(Y,Y,Y,4(Y,Y,Y,Y'4(4)4*Y'Y'4*4+Y'4+Y'4,4,4-4.4/4/Y,40Y,Y.40414242Y,Y'434344Y.Y.Y'44Y.Y.Y,Y,44Y,YI44YIYI4445YIYI4546YIY.Y.Y.YIYIY.YAY.45YAYA45YAY.45464747YA4849YAYA49YA49Y,4:Y,Y,Y,4:4;YI4;YIYI4;4<YIYI4<Y,YIYIYIYIYIZ)Z)Z)Z)4;YIYIYI4;YI4;YIYI4;4<4=4>4>YIYIYIZ)Z)4>4?Z)Z)YIYIYI4>YMYMYIYMYI4>4>YMYMYMYMYM4>YMYI4>4?YMYIYMYMYM4>YMYMYMY,Y,YIYIY,Y,YI4=Y,Y,4=Y,YI4=4>4?4?Y,Y,Y,4?Z&4@Z&Y,4@Y,4AY,4A4BZ&Y,4BY,Y,Y,Y,YKYKY,YK4AYKY,Y,Y,4A4A4BYKYK4BYKYKYK4BY,4CY,Y,4C4D4EY,Y,Y,YKYKYKY,Y,Y,YKYKYK4B4C4DY,4DY,Y,Y,YIY,4DY,4DY,4EY,4EY,4F4GY,Y,4GY,4G4HZ)Z)4H4IZ)Z)Y,Y,Y,4IY,Y,4IY,4IZ)Z)Z)Z)4IZ)4J4J4KZ)4LY,Y,4LZ)Y,Y,4LZ)Y,Y,4LY,Z)4LZ)Z)4LZ#4MZ#Z)4MZ)4NZ#Z#4NYMZ)Z)Z)YM4MYMYMYM4M4NYMZ)Z)4N4OYM4O4PYMYMZ)4PZ)Z)4PYMYMYM4PZ)YMYMYMZ)YMYMYMYM4OYM4O4PYMYMY,4PY,4Q4Q4RZ#Z#Z#Z#4RZ#Y,Z#Z#Z#4QZ#Y,Y,Y,Y,4Q4RY,Y,Y,4RZ#Z#YMY?Z#Z#Y?4QYM4QYM4RY?Y?4RY?Z#Z#4RZ#YM4RYMYMYMYMYMZ'YMYMZ'4Q4QY?4R4SYM4SY?Y?4SY?Y?Y?Z&Z&YKYKYKYK4RYKYKYK4R4SYKYK4SYKZ&Z&4S4TZ&Z&YK4TZ&Z&4T4UYK4UYKYK4UZ&4V4WYKYKYK4W4WYK4X4YYKYKY-Y-YKY-4XY-Z&Z&Y-Y-Z#4WZ#Z#4W4X4Y4Z4ZZ#Y0Y0Z#4Z5#Y0Z#Y0Y0Y0Z#Y0Y0Y04YY-Z#Y-4YY-Z#4ZZ#4ZZ#5#5#5$Y0Y0Y-Y-Y05$5$5%Y0Y0Y-5%Y0Y05%5&Y0Y05&5'Y0Y05'5(Y0Y0Z#Z#Z#5(Z#Y?5(Y?Y?Y0Y?Y?Y?Y?Y?Z'Y0Y05&Y05&Y0Z'Z'Y?5&Z'Z'Y0Y05&Y0Z'5&Z'YP5&Z'YPYPZ'Z'YP5&Y0Y05&Y0Y-Y-5&Y-Y-Y0Y0Y0Y-Y-5%Y05%5&Y0Y0Y0Y-Y0Y0Y-Y-Y0Y0Y-5$Y-5%5%YYYYYY5%5&5'Y0YYYY5'YYY0Y/5'Y/Y05'Y0Y/Y0Y0Y0Y+Y0Y0Y05&5&Y+Y+Y+Y0Y05&Y0Y0Y05&Y0Y+Y/Y+5&Y/Y/5&Y/Z'Z'Z'Y+Y05%Y0Y0Y0Y/Y/Y/Y+Y/5$Y/Z&YEZ&Z&YEYEZ&5#YEYE5#5$Z&Z&Z&Y<Y0YY5#Y/Y/5#Y/Y/5#YYY/Y/5#5$Y2Y2Y2Y2Y/5$Y25$Y25%Y2Y<Y2Y2Y2Y<Y2Y<Y2Y<Y2Y2Y2Y<4Z5#Y25#Y2Y2Y25#Y25$Y25$Y2Y2Y2Y2Y25$Y/5$Y/Y/Y<Y<Y<5$Y<Y<5$Y/Y/5$Y/Y/Y<5$Y/Y/YEYEY<Y<YGYG5#YGY<5#Y<Y<5#5$Y<Y<Y<YRYRYR5#5$Z(Z(5$5%Z(Z(5%Z(Z(Z(5%YGY<YGYGYGZ%Z%YGYG5$YGYGYGYQYQYGYGYQYQYGYGYQYG4YZ%Z%Z%Y<Y<YGYGY<YGYGYG4WYG4X4YY<Y<Y<4YY<YG4YYGYGYG4YYGYGYGYQYQYQYQ4XYQYNX.X.X.Z%Z%Y)Y)4VY)Y)Y)X.4VWJWJX.X.X.4VVTVT4V4WVTVTVQVQVTVTVQ4VVTVT4VVQX(X(4VX(4VX(X(X(X'4VX'X'4VX'X'X'WU4VWUWU4V4WWUWUW%W%4W4XWUX,WU4XX,X,4XX,WUX+X+X+U>TT4WTT4WTTU>TTTUTU4WTUTUTUTU4WTL4WTLTLTUTU4WTUTUTU4WTUTU4W4XV;4X4YV;V;TUTUTU4YTUTU4Y4Z4ZV;TUV;TUTU4ZUPTLU0TLU0TLU0TLU0TLU0TLU0TLU5TL4W4WU5U5TLTLU4TL4WTL4WTLTLUPUP4WUP4WUPUPUPU9U9U9UPU94VU9U9UPUP4VUPU9U9UPUPU9UPUPUPV;UPV;4T4TV;4UV;4UV;4VV;V;4VV;V;UPUP4VUPV;V;UPUP4UUPUPUPV;V;V;4UV;V;4UUP4UUPUPUPYBYB4UY>4UY>Y>Y>YBYBY>Y>YBYBY>Y>YBYB4SYB4SYBYBYBYBYI4SYI4S4TYBYBYBYB4TYBY(4TY(Y(4TYIYBYBYIYI4T4U4UYIYBYBYBYIYBYBYIYI4T4UYIYI4U4VYI4VYIYIYMYMYIYIYM4UYIYIYI4UYIYIYMYMYIYIYIYM4TYM4TYMYIYMYIYIYIYMYM4SYM4T4TYM4UYMYPYPZ'YPYPYPZ'YP4SYPZ'YPZ'YPZ'Z'YPYP4RYPZ'4RZ'Z'Z'YPZ'4RZ'Y+YPYPYPYPYP4QY+Y+YPY+4PY+Y+Y+YP4PYPY+Y+Y+Y+YTY+YTY+Y+YJYJYJYWYJY+Y+Y+YWY+YWYWY+Y+YWY+YJYWYJYWYJYWYJYWYWYS4H4IY+Y+YS4IY+YSYSYSYSY+YSYSYSYSY*Y*YSYSY*Y*4EY/4F4GYT4GYTY/4GY/Y/Y/Y/Y/YT4GY/Y/4GY/Y/Y/Y/4GY/Y/4GYTY/4GYTYTY/Y/Y/4GY/Y/4GY/YT4GYTYTY/Y/YTYTY/Y/YTYTYTY9Y9Y94DY94EY9Y*Y9Y9Y9Y*4DY*4EYGYGYG4EX/X/Y9X/Y94DY9Y94DY9Y9Y9Y9X/Y9Y9X/X/4CX/Y9X#4C4DVWYGVWVWVWVW4CVWVWVW4C4D4DVWX#X#VWVW4D4EX/VW4EVWVWVWX#X#VWVW4DVW4DWSVSVSWSWSVSVSVSVS4CVS4CWS4DWSWSWSVSWS4CWSVSWSVSWSVS4CWSWSWSWYWS4BWSWSWSWSVSVSWSWSVS4AVS4AVS4BWSWS4BWSVNVN4B4CWPVNVNVNVN4BVN4C4C4DWYWYVNVNVN4D4DWYWYWYVNVNW#W#VNVNW#W#W#W#W#4BW#W#4B4CW#W#WY4CW#4CW#W#VNVN4C4DVNWYVNWY4CWYWYWY4CWYWYWYWYWYWY4CWYWY4CWY4C4DW,W,4D4EW,W,WYWY4E4FWY4FW,W,4F4GW,W,4G4HW,W,WYW,W,W,WYWYWYW,WY4FW,W,4FW,W,W,WYW,W,W,WYWYW,WY4D4EWYWYW,4E4F4GW,WY4G4HWYWY4HWY4HWYWYWYWYWY4H4IW,W,W,4IW,W,4I4JW,W,W#W#WYWY4I4JW#4JW#W#4JW#W#W#4JWY4KW#4KW#4LW#4L4M4N4OW,W,WSWSWSW,WSW,4M4NWSWSW,W,W,4NW#4NWYWYWY4NWYWYW#4N4O4PWYWY4PWYWY4P4QW#W#W#W#4Q4Q4RWYWYW#W#4R4SW#W#4S4TWYWYWY4TWYWY4TWY4TWYW#W#4T4U4V4W4W4XW#W#4X4YW#4ZWY4Z5#W#5#W#W#W#W#5#W#W#5#W#W#W#W#5#W#W#5#W#W#W#WUWU5#5$WUWUWU5$WUWM5$WMWU5$WMWMWU5$WUWMWUWU5$WMWMWMWT5$WM5$WTWTWM5$5%5&WMWMWTWTWMWT5%5&WUX+WU5&WU5&WMWMWUWU5&WMWUWUWUX+WMWT5%WTWM5%WTWTWM5%5&WTU>UYU>UYUYUY5%UYU>5%U>U>5%UYUYUY5%5&V:V:5&V:V:V:U>U>V:5&U>U>5&5'U>5'V:UY5'UYUYUY5'UYU/U/5'5(5)5*UYTTUYTT5)5*U/U/5*5+U/U/5+5,UU5-TTTT5-TT5-TTUUUU5-TLTTTLUPUPTLUPTLTLU:U:U:UPU:U:TL5*UPUPTLUPUPUPTLUP5)UPTLUPTLTLUPUP5(UPTLTLTL5(TL5(TLTL5(YBY>YBYBYB5(YBYBS:5(S:5(S:S:S:S:S0S:5(S0S05(S0S:S0S:S:S0S05'S05'S0S:S0Y9Y9Y*Y*Y9Y9Y*Y*Y*Y9Y*Y*Y9Y9Y9Y*W-W-5#5$WF5$WFWFW-W-WFWFY9Y95#W(Y95#W(W(Y9Y9W(Y94ZW(W(W(W-4ZWFWF4Z5#VZVZ5#5$VZVZ5$5%VZW(VZVZVZ5%VZVZ5%W(VZ5%VZW6W6W6W6W/5$5%W/W/W6W6W6VOW6W/5$W/W6W/W6W6VZW(VZW(VZVZ4Z5#W65#W6W6W6W(VOVOW(W(VO4ZVO4ZVOVO4Z5#VOVO5#W65$W6W.5$S9W6W6W/5$W/5$VO5%VOY9Y9Y9W(Y9Y9W(5$W(W(W(5$W(5$VUVUY9Y95$Y9Y95$VUVUW(VUW(VUVU5#VUVU5#VUVUVU5#X#5$X#X#X#VUX#VUX#VUX#VUVU4Z5#VUVUVU5#VU5#VUVUVUX#5#X#5#X#VUX#VUVUVU5#5#5$VUVU5$5%VU5&VUVU5&VUX#X#5&X#VUX#VU5&VSVSX#5&VSVS5&X#VSVSX#5&VSVS5&VSX#5&X#X#5&VSVSVSWSWSW7WSW75%W7W75%W7W7W7W,W,5%W,W75%W7W75%W,5&W7W7W75&W75&W95'W95'W95(W9W7W9W7W9W75'W7W75'W9W7W9W7W7W75'W7W7W75'W75'5(5)5)W95*W9W9W<W95*W95*W9W9W9W<5*W<W9W<W9W<W9W<W9W95(W<W9W<W95(W95)W<W<5)W<W9W95)5*5*W<W9W<TLTL5*5+TMTMULTMULUL5*UL5*ULTMUL5*TL5+TL5+TL5,5-TLTLUETLUI5,UIUI5,TLUE5-TLTL5-TLUE5-UE5.TLTL5.UETL5.UPUPS9S9S9WQ5-WQWQWQVU5-W@VU5-X#VUVUW@5-WQWQWQWQWQVVWQVVWQVVW+WEW+WEW+WEW+5*W+5*W+5+5+WE5,WEWEWE5,W+5,W+W+W+W+W+W+WEX#W9X#W9W9W95*W95*W9X#X#W9W9W9W<W9W9W9W<W<W<W<5(W<5(W<W:W<W:W<5(W:W:5(W:WUWUW:5(5(5)W<W<W<W<W)W<W<W<W<W)W)W)W<W)W<W<W)W<W<W<W)W)W<W)W)W)W)W)W<W<W<4ZW<W<4ZW)W<W)W)W)W)4Z4ZW<5#W<W)5#W)W)5#W<5$W<WUWU5$5%WUWU5%5&WUWU5&5'WUWU5'WUWUWU5'WX5'WUWXWUT>T>T>5'5'5(UIUIUHTHUHTHUHTHUHTH5&THTATAV<V<V5V5T+T+T+5%T+T+5%UCUCU?U?U?5$V1V1V1SASZ5$SZSZSZS=S=WQWQWQVMX-X-4ZX-X*4ZVX5#X*5#5$VXVX5$VX5%X*X*5%X*VX5%VXVXWU5%WUWU5%5&5'5(5(W1W1W1W1W1WUWUW1W1WUWUUIUIUIU*T:T:TITITD5$TD5%S4S45%S4S=S4S4S4S45$S4S4T#T#S.S.T#T#S.S.S-S-S-S.S@4YS@S@4YSX4ZSXS@4ZS@S@4Z5#S@S@S?S?S?SUTDTI4ZTIS.SMS.SMS.SMS.SMS.SMS.S.4WSMS.4XSMSM4XSM4XT$SMT$SM4XSMSM4XT$T$T$T$4XT$4YT$4YT$4Z4Z5#SJSJS3S35#5$SO5$SOSGSGSG5$SGSO5$SOSOSG5$SGSWSGSGSGSW5#SWSWSWW>W>5#5$W>W>5$5%5%WVWVWVWVWV5%5&W$5&W?W?5&U#5'U#SJS75'S7SNSNSJSJSJSJSNSJSJSJSJSNS75$S75%5%5&SJSJS7SJSJSJSOSG5%5&5&SGSOSGSGSGSISGSOSO5%SISO5%SOSISOSI5%SI5%SISOSOSISISIS8SO5$SOS8SGSGSG5$SIS>SIS>5#5$S8S8S85$S8S85$S>S>S>SWSWS>5$SWSW5$SWS>S>5$SWWLWCWCWCV$5#V$TPT=V(V(V(V(V(4ZV(T=V(T=4ZV(U@U@U@V(4YT=T=4YT=T=T=4YU@T=T=U#V(V(V(V(V(U@U@V(V(U@U@4VSOSPSPSOSPSPSPSP4USPSPS>S>SP4U4US6SPSPS6S64US64US6SRS6S6S6SR4USR4USRSR4US64V4WU=V,V,V,4VT1T1T1U<4VTGTGTGTG4VTGTPTP4VTPTGTGTG4V4VSPSDSPS6S6S64VSDSDSD4V4VSESESET1T1T5T1T0T;T0T0T/4TT/T/4TT0T/T0T0T0T04TT0T;T04TT04TT0T04TT;4UT;4UTGT;TGT;T;T;4UV.V.4UV.4UV.T0T0T04UT0V.T0T04U4VT;T;4V4WT04WV.V.SCSCSCSESCSCSC4VSE4VSSSS4VSSSSSSSESE4VSS4VSSSSSSX;4VXDXD4VXDXDXDT3T3T5T3T54UT5T5T3T34UT5T3T3T54U4U4VT5T5T3T34VT5T0T0T7T0T0T04U4VT04VT0T.4V4WT.4XT0T0T.T.4WT.T.T.T0T04WV.4WUMUMUMUMV.UM4WV.V.4WV.T0T0T04W4WUMT0UMT04WT0T0T04WT04XT0T04XT0T0T0T.4XUMUM4XUMV.V.V.4XV.V.4XV.4XUMUMUMUMUMT.4XSESSSE4XXDXD4X4YXB4YXBXBXDXD4Y4ZXDXD4ZXBXB4ZXBXB4ZT.T5T54Z5#T4T4T/T/T4T4T/4ZT4T44ZT/T4T4T/4ZT4T4YUY7YU4ZY7Y7YUYUY7Y74YY7YU4YYUYU4YY7YUYUYUYUYUY7YU4XY7Y7X.X.X.4XX.X.4X4YX&4YX&X&4YX&X&X&4Y4ZX&X&Y4Y44Z5#5#5$5%Y@5%5&Y@Y@Y@Y@5&5'5'Y4Y4Y4Y@Y@5'5(Y,Y,5(Y,Y'Y'Y,Y,5'Y,5(Y,5(Y,5)Y,YHYH5)5*YHYH5*YHY3Y3Y,Y,Y35)Y,Y,5)Y,Y,Y,YUYUY3YUY3YUY35(Y,Y,Y,Z&Y,Z&Y,Z&5&Z&Z&Z&Y,Z&Y,5&Y,5&Y,Z&YLYLZ$Z$YLYLZ$5%YV5%YLYLYVYV5%YV5%YLYLYL5%5&5'YG5'5(YXYNYNX.X.X.YN5'YNX.YNYNYN5'YNYN5'5(YNYN5(YNYNYN5(5)5)X.5*X.X.X.YNYNX.X.5)X.YNYN5)X.5)5*YGYGYGYGYG5*YG5*YGX.YGYGYG5*5*X.X.X.YG5*X.X.YGYGX.YGYGYGX.5)X.X.WO5)X.X.X.X&5(5)X&X&5)X&X&X&WGWGW=5)5)WGW=W=W35)W3W3W=W=W=W3V=V=V=5(V=V=5(V=V=V=V=5(V=V=5(5)V=V=V=5)V=V=5)V=5)TLUT5*5*5+V?TL5+TLTLTL5+UG5,5-5-V9V;5.5.V;V;V;5.5/V;V;UGUG5/UG5/50TLTLTLUGTL50UGUG50TU50TLTLTL5051TUTUUKUKUK51UKUK51UKUPUKUPUKUKUK50UKY.Y.YI50YI50YIYIY.Y'Y.50Y'Y'Y.Y.Y.Y.5/505051YIYI51YIYIYIY.Y.5152Y.Y.52Y.5253YI54Y.Y.Y.545455YIYI55Y.56Y.56Y.YIYIY'Y'56Y'Y'Y'56575758Y.Y.Y'Y'5859Y'Y.595:Y'Y'Y.Y'Y'Y'Y'Y.Y.Y'Y.Y.57Y.Y.Y.Y.Y'Y.57Y.57Y.Y.Y'Y'57Y.Y'57Y.Y.57Y'5859Y'Y'Y,Y,Y'58Y'Y'Y,Y,Y'Y,Y'57Y'Y'Y'57Y,Y,5758Y,Y,Y'Y'Y,Y,Y,Y,57Y,Y'Y,Y'Y'Y,56Y'57Y'Y'Y'57Y'5758Y,Y'Y,Y,Y,Y,Y,57Y,57Y,Y,Y,Y'57Y'Y'5758Y,Y,58Y,Y,Y,58Y.Y.Y.Y'58Y.59Y'Y'Y'59Y'59Y'5:Y'5:Y'Y'Y,Y,5:Y,Y'Y'Y'5:Y,Y,5:Y,5:5;Y,Y,5;Y,5<Y,5<Y'5=Y'Y.5=5>5?5?Y'Y'Y'5?Y'5@5A5A5BY'5C5C5DY.5EY'Y'5EY'5E5FY'Y,Y,Y,Y.Y,Y.Y.YIYIY.Y.YI5DY.Y.5DY.Y.5DYIYIYIY.YIY.Y.YAY.5CYAYA5CYAY.Y.Y.5CYI5CYIYI5C5DYIYI5DYAYAYAYAYA5D5EYAYAYA5EYAYA5EYIYAYA5E5F5FY,YAY,YI5FYI5GY,Y,5GY,5GY,YIYI5G5H5IYI5I5JYIYIY,Y,5J5KZ)Z)YIYIYI5JZ)Z)Z)5JYIYI5J5K5LZ)5L5MYIYI5MZ)Z)5NZ)YI5N5O5O5PYIYIZ)Z)YIYIZ)Z)YIYIYIYIYMYMYIYMYI5MZ)Z)YMYMYMYM5LYMYIYI5L5MYIYMYIYI5LYMYMYMY,5LYIYIY,Y,5LY,YI5L5M5NYIYI5NY,5NY,Y,Y,5NY,Y,Y,Y,Z&5NZ&5NZ&5OZ&Y,Z&5OZ&5OZ&Y,Y,Y,5OY,5PY,Y,Y,Z&5OZ&5PZ&5PYKYKYKY,Y,Y,5PY,Y,YKYKY,Y,YKYKY,YKYKYKY,Y,5MY,YKY,YKYKY,5L5MZ&Y,5MY,5N5NZ&Z&Z&YIYIYI5NYI5N5OY,YI5OYI5P5P5Q5RY,YIYIYI5RYI5RYIYIYIY,5RY,5RY,YIY,5RY,YI5SY,Y,5SY,Y,Y,Y,5S5SZ)Z)Z)5S5TZ)Z)5T5UZ)Z)Z)5UZ)Z)Y,Y,Y,5UY,Y,5UY,5U5VZ)Z)Z)Y,Z)Z)5UZ)Z)Z)Y,Y,5UY,Y,Y,5UY,Z)Y,Z)Z)Y,Z)Z)Z)5S5TZ)Z)Y,Y,Z)Y,Y,Y,Z)5SY,Y,Z#Z#5RZ#5SZ#Z)Z#Z)5S5SZ#5TYZZ#Z#Z#YMZ)Z)Z)YMZ)Z)YMYMZ)Z)YMZ)Z)Z)Z)YMZ)Z)Z)5O5OZ)5P5QZ)YM5QYMZ)Z)Z)5Q5QYM5RYMYM5RYMYMZ)5RYMYMZ)Z)Z)5RZ)YM5RYMY,Y,Y,5R5RZ#Z#Z#Y,Y,Z#Z#5QZ#Z#Z#Y,Z#Y,5QY,5QY,Z#Y,Y,Y,5QY,Y,5QZ#Y,Y,Y,Z#Y?Z#Y?Y?YMYMYMY?5NY?5O5PY?Y?5PY?Z#Z#Y?Y?YMYMYM5OY?Y?Z'5O5OY?Y?Y?5O5PYMYMY?Y?5P5QYMYM5QYM5QY?5R5SYKYKZ#YKYKYKYKZ#YKYKZ#5QYKYK5QYKZ&Z&YKYKZ&YKYKYKZ&Z&YK5OZ&Z&5O5PZ&Z&5PZ&YK5PYKYK5PZ&YK5QYK5QYKYKZ&Z&5QZ&YKYKYKY-YKYKYK5P5PY-Y-Y-5PY-Y-Y-YKY-Y-Y-YK5OZ#Z#Z#Z#Z#5OZ#Z#5OY0Z#Y0Z#Z#Y0Y0Z#Z#Z#Z#5MZ#Z#Z#5MZ#Z#5MY0Y05MYKZ#YKZ#5MZ#5N5N5OZ#5PZ#5PZ#5QZ#5QZ#Y05QY-Y0Y0Y-Y-Y0Y0Y-Y-Y05PY05PY0Y0Y-Y-Y0Y0Y-Y-Y0Y0Y-Y-Y05NY-Y-5N5OY-Y-5O5PY-5PY0Y05PY-Y0Y05P5QY0Y0Z#5QY?Y?Z#5Q5R5SY0Y05SY05SY0Y?Y?Y?Y?Y?5SY0Y05SY0Z'Z'5S5TZ'Z'5TZ'5TZ'YP5UY0Y05UY0Y-Y-5U5VY05VY0Y0Y-Y0Y0Y05UY0Y0Y0Y-Y-Y-5UY-YYYYYYY-YY5TYYY-Y-Y-5TYYYY5T5U5U5VY0Y0YYYYY0YYY0Y/Y/Y/Y0Y/Y/Y/Y0Y0Y05SY05SY+Y+Y0Y05SY0Y0Y0Y05SY+Y/Y+Y+Y/Y/5R5SY05SY0Y/Y+Y+Y+Y/5RYEZ&5SY<5SY<Y<5SY<Y<Y<Y0Y/Y/Y/YYYYY/5RYYYY5RY/Y<Y<Y2Y2Y<Y<5QY<5QY2Y/Y2Y<Y<Y2Y2Y25PY2Y2Y2Y<Y2Y2Y<Y<Y2Y<5NY<5OY<Y<Y<Y25OY25OY25PY25PY2Y<Y2Y2Y<Y<5OY<5PY<Y<5PY<Y/5PY<Y/Y/5PY/Y/Y/Y<5PY/Y/YGYGY<5P5PYGY<YGYGYGY<Y<YGYGY<Y<Y<Y<Z(Z(Y<5MZ(Z(5MZ(Z(Z(5M5NZ(Z(Y<Y<Z(Z(YGYG5M5NYGYGZ%Z%YQZ%Z%Z%YGYGY<YGY<5K5L5MYGYG5MYGY<YGYGYGY<YG5LYGYGYGYG5LYQYQZ%Z%Z%Z%5KY)X.X.WJWJX.X.VRVRVTVTVQVQVTVTVQVQVT5GVQVQ5GVQVQVQVNX(VN5G5G5HX(X(5HW3X'X'W35H5I5JW%W%WUWUW%W%WU5IW%W%5IW%WUW%WUWUW%W%WUWUWU5GWUWU5G5HWUWUU>U>U>5H5H5IU>U>TUTU5I5JTUTU5J5KTL5KTL5LTUTU5L5MTUTU5M5NTUTU5N5OTU5OTU5PTUTU5PV;TUV;V;V;TUTUTU5OTUTU5O5PTUTU5P5QTU5QTU5RTUTU5RUPTLU55RU5TLU5U5U5TLU4TLU4TL5PTLTLU0UP5PUP5PUPU0UPU9UPU95P5PUPU9U95PUP5QUPTUTUTU5QTU5Q5RV;5RV;5SV;5SV;V;V;5SUPV;V;5SUPV;5TV;UPUPUPV;V;V;5SV;UP5SUPUP5SUPUP5S5TY>Y>YB5T5UY>Y>Y>Y>5U5UYBYBYBYBYBYB5UYB5UYBYB5UYIYBYBY>YB5UYBY(5UY(Y(YIYIY(Y(YI5T5U5VYIYI5VYIYB5VYBYBYIYI5V5WYIYIYBYBYIYI5V5WYIYI5WYIYIYMYIYMYMYM5VYMYIYI5V5WYIYM5WYM5WYMYIYMYMYMYM5WYM5WYMYMYMYM5W5X5X5YYMYM5Y5ZZ'6#6#YPZ'6$6$YPZ'Z'6$YJZ'6%YPYPYP6%YPYPYPY+YPY+YPY+YW6#YW6$6$YSYSYSY+Y+YSYSY/Y/6#Y/Y+6#Y+Y+6#6$Y+Y+YTYT6$Y/YTY/Y/Y/YTY/YTYTY/Y/5Z6#Y/Y/6#6$6$YTYTYT6$YTYTYTY/Y/Y/6$Y/Y/YT6$6$YTYTYT6$Y96%Y9Y*6%Y*6&Y*Y*Y*Y9Y*Y9Y*Y9YGWZYGWZX/X/Y9Y9X/X/Y9Y9X/X/Y9X/Y9Y95X5YX#X#5YX#VWVW5YVWVWVWX#X#5XVWX#X#X#5XX#X#VWVWX#X#VWVW5W5XX/X/5XVWVWVW5X5YWSWSVSVSX#VSX#X#5WWSVSVSVSVSVSWS5VWS5WWSVSWSVSVSWSWS5VW,5VWSVS5WWSWS5WWSVS5WVSVS5WWSVSVSWP5WWPWPVNVNWP5WVNVNVN5WWY5WWYWY5W5X5YWY5Y5ZWYWYVNWYWYWY5Y5ZWYWYW#W#W#5ZW#W#5Z6#6#WYWYWY6#W#WYW#VNVN6#6$W#6$W#W#VNVNW#W#6#6$WYWYVNVNWYWYWYWYWY6#WYWY6#W,W,6#W,W,WYWYW,W,WYWYW,W,WYWYW,W,WY5XWY5Y5YW,W,W,WYWYWY5YWYWY5YWYWYWYW,5YWY5Y5Z6#6#W,6$W,WYWYWY6$WYWYW,W,W#W#WY6#W#W#6#WYW,W,W,6#W,6#W,WY6#6$WYWYW,WYW,W,WYWY6#6$WYWY6$WY6$WYWYWYWYWYWY6$WYWYWY6$W,W,W,W#W,W,W#W#5Z6#W#W#W,6#W,W,6#6$6%W#W#W,W#6%W,W,6%6&WYWY6&W,6&W#W#W#6&W#6'W#6'W#WYW#WYWYW#6'W#W#6'W#W#6'W#W#6'W#W#W#WS6'WSWS6'W,WSWSW,6'W7W7W#6'W#WY6'W#WYW#W#W#6'6(WY6(WYWY6(6)WYWYWYWY6)WYWYWYWYW#WYWY6(6)W#W#6)6*WY6*WYWYW#W#6*W#W#6*WYWY6*W#WYWYW#W#6*6+W#W#WYWYWYWYWYW#WYWYW#WYWYWYW#6(WYWYWY6(WYWY6(6)WY6)6*6+6+W#W#W#6+6,W#W#6,W#W#W#6,WYW#6-6-WY6.W#W#6.W#W#WYWYW#W#6-W#W#W#6-6.W#W#W#6.W#W#6.6/W#W#VNVN6/60VNW#60W#WU60WUWM60WUWMWMWU6061WM61WMWMWM61WM62WMWUWMWUWMWU61WMWM61WMWT6262WT63WTWMWMWM63WM63WTWT63WTWTWTWM63646565WTWTWTWUX+WUX+WUWUWU6464WMWMWMWM64WMWMWMWM64WMWMWM64WTWT64WTWT64UY65UYU>65U>6666UYUYUYU>66V:V:6667V:V:6768V:V:U>68V:V:6869V:V:696:V:V:U>U>6:6;U>UY6;UY6;UY6<6=TTTTUYUYTTTT6<TTUY6<TTTT6<TTTTTTUYUYU/6<UYUY6<6=UYUYU/6=UYUY6=U/TTTT6=6>TTTT6>TT6>6?UUUU6?TTUU6@UU6@UUUUTTTLTTTLTLUPTLUPTLUPTLUPUPUPUP6=TLTLTL6=TLUPTLUPY>6<Y>6=YBYBY5Y5S:S:6<6=S:S:S:6=S:6=S:S:S0S06=S0S:S0S:S:S:S0S:S0W-W-6;6<W-W-6<W-6<W-WFWF6<6=W(W(Y9Y9Y96=Y9Y96=Y96=W-WF6>W(W(VZVZ6=W(VZVZ6=W(VZVZW(W(VZVZVZW(VZ6<W(W(6<W(VZ6<6=W(VZW(W(W(VZW66<W6W6W6W/W/W6W6W/W66:W6W6W6VZVZVZW6VZW(W6W(6869W66:W(W(6:6;VO6;VOVOW(W(VOVOW(W(VOW(69W6W.W.69W6W6W669W6W.W6696:W/W/W6VO6:VO6:VOVOVOY9Y9W(6:W(W(W(6:W(6:VUVUY9Y96:W(Y9Y96:VUVU6:VUVU6:Y9VUVUX#X#VUX#VUX#VUX#VU68VUX#68X#X#X#VUVUVU68VU68VUVU68X#X#X#68X#VUX#VU68VU69X#X#69X#X#X#696:VU6:VUVUX#X#6:X#6:6;VUVUVUVUW@6;6;X#VU6<X#X#6<X#VSVSX#X#VSVSX#X#VS6:X#6;VSVS6;VSX#6;X#X#6;VSVSVS6;6<W76=WSWS6=W7W,W,W76=6=6>W76?W,W,6?W,6?6@W7W76@W76AW76AW96B6CW76CW7W7W7W7W76CW7W9W9W9W76BW7W76B6CW76DW7W7W7W96CW7W9W96CW9W9W9W7W7W76CW9W96CW9W9W96CW9W7W9W7W9W9W<W9W9W96AW9W9W9W96A6B6BW<W9W<W96BW9W9W9W96B6C6CW<W<W<W9W9W96CW9W96CW<W96CW9W<UUTLUUUUTLTL6BTLTMUL6BULULUL6BULTLTL6BTL6BTLUEUETL6BUE6CUE6CUEUE6CTL6DTLUIULUIUITLTLUE6C6CTLUEUETLTLUEUETLTL6B6CUE6CUEUE6CTLUEUE6CTL6DUPS9WQS9WQVU6CVUVU6CX#VUVUW@WQWQWQW+WEW+W+W+W+W+6AW+6AW+W+W+WE6AWE6A6BW+W+6B6CW+W+WE6CW+W+W9W9X#6CX#6CX#X#W<W<W<6CW<6CW<W:W:W:W<W<W:W:6BW:W:6BW:W:W:W:W<W:W:W:W:W<W)W)W<W<W)W)W<W<W)W)W)6>W)6>W)6?W)W<6?W<W)6?W)W)6?W<W<W<W)W<W)W<WUWUWUX-6=X-X-X-WUWUWU6=WUWU6=6>WUWU6>W1WUWUW1W1WUWUW1WUWU6<6=WXWUWUWXWXT>T>T>6<UI6<UIUI6<UIUIUI6<6=TATAT+6=UC6>UCUC6>UCU?UCU?V1SASZ6=SZX-6=6>VXX*X*6>6?VX6?VXX*X*X*6?VX6?6@6AVXX*X*VX6AVX6AVXVX6AX*6BX*VXVXVX6BWUWUWU6BWU6BWU6CWUWUWAWUWU6BWUWU6BWUWUWU6B6CW1W1TD6CTD6DTDTITDTIS4S4S=S=S46BS4S4SXSXS@6BSXSX6BSXS@SXS@SX6ASXS@S@S@6AS@S@6ASX6BSXTDTDTD6BS.SMS.6B6B6CS.S.6CSM6DSM6DT$SMSMSMSMSM6DSMSM6DT$T$SKT$6D6DSK6ESK6ESK6FSKSKSK6FSKS3S3S36FS3S36FSJS3S36F6G6GSO6HSO6HSGSGSGSGSGSO6H6HSG6I6JSGSGSG6JSGSWSWSWW>W>W>6IW>6I6J6K6KW>6L6MW>W>6MWVW>WV6MWVWVWVWVW4WVW4W4W46KW$6LW$U#U#T-U#T-6KT-T-SJ6KSJ6LS7S7S76LS7SJSJSJS7S76KSJS7S7SJSJSOSOSO6J6JSGSGSGSO6JSOSOSOSISISISO6ISOSISOSISO6ISO6ISOSI6IS86JS86JSISISIS8SIS8S8SI6ISIS8S86IS8S>6I6JS>S>S>SWS>6JSWSW6JSWS>6JS>S>6JTP6KTPV(V(V(6KT=V(T=6KV(V(V(6K6K6LT=T=6LU@T=T=6LSO6M6NSP6NSPSP6N6OSP6PSP6PSPSPS6S66PS6SRS6S6S6S6S6S66OS66O6PSRS6S6S66P6PSRSRSRSRS6SRSR6O6PT1T1U<6PTGTGT;TG6PTGTPTP6PV.TGV.TGV.SPSP6O6PS66PS6S6SRSR6PSRSE6PSESET/6PT/T/6PT06QT0T06QT06R6RT;6S6TT06TT0T0T;T;6T6UT06UT0T;6UTGT;6VT;6VT;T;V.V.6VV.6V6W6XT0T06X6YV.T0T0T06Y6YV.6ZV.T;6ZT0T06ZT;7#T;T07#V.V.SCSESCSESESESS6Z6ZSESSSSSESESE6Z6ZSSSSSSX;6ZXDXD6ZXDXDXDT3T36Z7#T57#T5T5T5T3T5T5T56ZT57#T3T3T37#7#T5T5T5T0T0T07#T0T07#T0T07#T.T.7#T0T.7$T0T07$T0T.T0T.7$T0T0T0T.T0T07#7$7$7%UMUMUM7%UMUM7%V.7&7'7'UM7(UMT07(T0UMT0UMT07(T0UM7(UM7(UMT0UMT0T07(T07(T.T.T.7(UM7)UMV.7)UMUMV.V.7)V.UM7)UMUMUMUMT.UMSE7(SE7)XDXDXB7)7)XD7*7+7+7,XBXBXDXDXB7,XDXD7,XDXDXD7,XDXB7,XBXB7,7-T5T5T/T/T4T4T/T/T4T4T/T/T4T4T/T/T4T4T/T/T4T47(YUYUYUY7Y77(Y7Y7Y7YU7(Y7Y77(Y7YUY7YUY7X.X.X.X&7&7'X&X&X.X.X&X&7&7'X&X&7'X&X&X&X.X.7'7(X.X.X.7(Y4Y4Y@7(7(Y@7)Y@Y4Y4Y47)Y47)Y@Y@7)Y@Y@Y@Y4Y47)Y@Y4Y4Y@Y@Y@Y@Y4Y4Y@Y@7'Y@7'7(Y4Y4Y47(Y4Y47(Y4Y4Y4Y'Y,Y'Y'Y'Y'Y'7'Y'7'Y'Y,Y'Y,Y'Y,Y'Y,Y,Y,YH7%YUYU7%YUYUYUYHYHYUYHY3Y37$Y,Y,7$Y,Y,Y3YUY3Y3Y,Y,7#Z&Y,7#7$Z&7$Z&Y,7%7%YLZ$Z$YVYVYLYLYLYV7$YVYL7$YLYLYV7$YVYV7$YG7%YGYV7%YVYG7%7&YXYXYNYN7&YNYN7&7'X.YN7'YNYG7'7(YGYG7(7)YGYG7)YNYNYNX.7)X.X.YNYNX.X.YNYNYN7(7(X.X.X.YNX.7(X.YNX.X.X.X.YGYGYGYGX.YGYGYG7%YG7&YG7&YGX.YGYGYGX.YG7%X.X.YGYGX.7%X.YGX.YGX.X.WOX.X.X.X.7#X.X.7#X&X.X&X&X&WGW=W=W=WGWG6Y6ZW=W=W3W=V=V=U>U>V=V=U>U>V=V=U>U>V=V=U>U>V=V=U>U>V=V=U>U>V=V=U>U>6RTLUT6S6STLTLTLV?V?V?6SV?V?6STLV?V?TLTLUGUGTL6RTL6RTLTLUGUGTLUGV;V9V;V9V96PV;V;V;V;6PV;V9V96P6QV9V9V9V;TL6P6QUG6QUGTLTLUGUGTLTLUGUGTL6PUGUGUG6P6P6QTLTLV;6QTUTUV;V;TUTUUKUK6P6QUKUK6QUKUKUKUPUKY.Y.6PY.YI6PYIYI6PY'Y.Y'Y.Y.Y.6PY.Y.6PYIY.Y.YIYIY.Y.6O6P6PYIYIYI6P6QYIYI6Q6RYIYIY.Y.6RY.YI6RYIYIY.Y.YIY.6QY.YIY.Y.Y.YIYIYI6PYIYI6P6QYIYIY.Y.6QY.YI6QYI6RYIY.YIY.Y.6QY.6RY'Y'Y.Y.Y'6QY.Y.Y'Y'Y'6QY'6QY.Y.Y.6Q6RY.6R6SY.Y.Y'Y'Y.Y.Y'Y.Y.Y.Y'Y'Y.Y.6PY'Y.Y'Y'Y'6PY'6PY.Y.Y.Y'Y'6PY.Y'Y'6PY'Y.6PY.6QY'Y'6QY'Y'Y'Y'6QY'Y,Y'Y'Y,Y'Y,6PY'Y'6P6QY'Y'6QY'Y,Y,Y'6QY,Y,Y'Y,Y'6PY'Y'Y'Y'Y'Y,Y'Y'Y,6OY'6OY,Y,Y,Y,6OY,6OY,6PY,Y'Y,Y'Y'Y'6OY,Y,6OY,Y,Y,Y,Y'Y,Y,Y.Y'Y.Y.Y'Y'6MY'Y.6M6NY'Y'Y'Y'Y,Y'Y,Y'6MY'Y'6MY,Y'Y,Y'6M6MY,6NY,Y'Y'Y'6N6NY,Y,Y,Y'Y'Y'6N6NY,Y,Y,Y,Y,6NY'6N6OY,Y,Y.Y.Y.Y'Y.Y'6NY'Y.6NY.6OY.Y.6O6P6P6QY'Y'6QY'Y'Y'Y'Y'6Q6R6RY,Y'6SY,Y,6SY,Y'6SY'6TY,Y,6TY,Y'6TY'6U6UY'Y.6VY'Y'6VY'6VY'6W6X6XY'Y.Y.Y'6XY'Y,6X6YY,Y,YI6YYIYIY.Y.6YY.Y.6YYIYIY.YAY.Y.YAYA6XYAY.Y.Y.6XY.Y.YIYI6W6XYIYI6X6YYI6Z6Z7#Y.7$7$7%YIYI7%7&YIYIYAYA7&7'YAYA7'YIYAYAYA7'YAY,Y,Y,YA7&YAY,Y,Y,7&Y,YI7&YIYIY,Y,7&Y,YI7&YI7'Y,7'Y,7(YI7(YIYIYI7(YIYIYI7(YIYI7(Y,YIYI7(Y,7)7*7*7+YIYIYIYI7+7,7,7-YIYIYIZ)YIYIZ)Z)7,Z)YI7,YIZ)Z)Z)Z)7,Z)YIYIYI7+Z)7,Z)Z)Z)Z)7,Z)7,YIYI7,YIYIYIZ)Z)YIYI7+YIYIYIYIYMYIYIYMYM7*YMYIYIYM7*YIYIYMYMYMYIYMYMY,Y,Y,7(7(Y,YIYIYI7(YIY,YIYIYI7(7(Y,Y,Y,YIYI7(YIYIY,YIY,7'Y,Y,Y,Y,Z&7'Z&7'Z&Y,Z&Y,7'Y,Y,Y,7'Y,7(Y,Z&Y,Y,7'Z&7(Z&7(Z&Z&Z&Z&Z&7(Z&7(Z&Y,Y,Y,YKYKYKY,Y,Y,7'Y,Y,YK7'Y,7'Y,Z&Y,Y,Y,7'Y,Y,Y,7'7'Z&7(7)7)Z&7*Z&YIYIYI7*YIYIYIY,YIYI7)Y,YI7)7*Y,7*Y,7+Y,YI7+YIY,7+Y,Y,Y,YIY,Y,Y,7*Y,7+Y,7+Y,YIYIYIYIYI7+YI7+YIY,7+Y,YI7,7,Y,YI7-Y,Y,7-7.Y,Y,Y,7.YI7.Z)Z)Z)7.Z)7/Y,Y,7/70Y,Y,Z)Z)7/Z)Z)Z)Y,7/Z)Z)Y,7/Z)Z)7/Y,Z)Z)Y,Y,Z)Z)7.7/Z)Z)Z)Z)Y,Y,Z)Z)7.Z)Y,Y,Z)Z)Y,Y,Z)7-Y,Y,7-Z)7-Z#Z)7.Z)7.Z)7/Z)Z)7/Z#Z#Z#7/Z#7/YZYZYZ7/YZ70YZ70YMZ)Z)Z)Z)70Z)YMZ)7071Z)Z)71Z)Z)YM71YMZ)Z)Z)YMZ)Z)70YM70YMYMYMYMZ)YM70Z)YM70YMZ)Z)YMYMZ)Z)7/70Y,7071Z#Y,71Z#Z#7172Z#Z#Y,72Y,7373Z#Z#Z#7374Y,Z#74Z#Z#Z#YMY?74Y?74Y?YMYMY?74YMYM7475YM76YM76YM77Y?Y?Z'77YM7778Y?78Y?YMYMY?Y?YM78YM78YMYM78Y?YM79YMYM797:7:Y?YM7;YMYMYM7;7;Y?Y?Y?YKYKZ#Z#YKYKZ#YKYKZ&YKYKZ&Z&78Z&Z&Z&7879Z&Z&797:7:7;YKYK7;YKYKYK7;Z&7<Z&7<Z&YK7=Z&Z&YK7=YKYKYK7=YK7=Y-Y-Y-7=Y-Y-YKYKZ#Z#Z#Z#Z#7<7<Y07=Y07=7>Y0Y0Z#Z#7>Z#Z#7>7?Y0YKYKZ#YKY-Y-7>Y-Z#Y-Z#Z#7=Y-Z#Z#Y-Y-7=Y-Z#7=Z#Y-Z#Y-Z#Z#Z#Z#Z#7<Z#7<Z#Y0Y-Y-Z#Y07;Y-Y0Y-Y-Y-Y07;Y07;Y0Y07;7<Y0Y07<7=Y0Y07=Y-Y0Y07=Y0Y0Y0Y-Y-7=Y-Y-Y-7=Y-Y-Y-Y-7=Y-7=Y0Y0Z#Z#7=Z#Y?Y?7=Y?7=7>Y?Y?Z#7>Y?Y?Y?Y07>Y07>Y0Y?Y?Y?Y?Z'7>7>Y07?7@Z'Z'Z'7@Z'Z'YP7@Z'Z'YPZ'Z'Z'Z'7?7?Z'YPZ'Y-Y-Y-7?Y-Y-Y-Y07>7?Y0Y0Y07?Y0Y07?7@Y0Y0Y-Y-Y-7@Y-7@YYYYY-7@Y-7AYYYY7A7BYYYY7BYYY-Y-Y0Y07A7BY0Y0Y0Y07B7CY07CY+Y+Y0Y07CY0Y0Y0Y07CY/Y/Y+Y+Y/Y/7BY/Y07BY0Y/YEYEZ&Z&Z&7AZ&YEYE7AY<Y<YEYEY<Y<YYYYYY7@YYYY7@7A7AY<Y2Y27AY2Y/Y2Y<Y<Y2Y2Y<Y<Y2Y<Y27?Y2Y<Y<Y<Y2Y<Y2Y<Y2Y<Y2Y<7=Y<7=Y<Y2Y<7=Y<Y/7>Y/7>Y/Y/7>7?Y<Y/Y<Y<Y/Y/7>Y/Y/Y/Y<Y<Y/Y/YGYG7=7>YGYGY<Y<Y<Y<7=Y<Y<Y<Y<Z(Y<Y<Z(Z(Y<Y<Z(Z(Y<7:Y<Y<7:YGY<Y<7:YG7;YGYGYGY<Y<YGYG7:7;YGYGY<YGY<YG7:YGYGYGYG7:Z%Y)Y)Y)VT79VQVQ797:VQVQVNX(VNX(VNVN797:7:X(X(X(X'W3X'W3W3W3W379W379X'X'79X'X'X'797:WUWUW%W%WUW%797:WUWU7:X,WUWUX,X,WU7:U>TTU>7:U>U>U>TTU>79TTTTTUTUTLTLTUTUTLTLTUTUU0U07677U0U0TLU077U07778TLTL78TUU0U0TUTUU0U07778U0U0TUTUU0U0TUTU7778TUTUV;V;TU77TU7878V;79V;797:V;V;TUTUTU7:TUTU7:7;TUTU7;7<TUTU7<7=TUTU7=7>7>V;7?V;7?V;V;V;TUTUUPUP7>U57?U5U4U4TLU4U0UPU0UPU0UPU0UPUPUPU97<U97<U9U9V;7<V;7=V;7=V;7>TUTUTU7>7>V;7?V;TU7?TU7@TUV;TUV;7?V;TUV;TUV;TUV;V;7>V;7?UPUP7?7@7@UP7AUPV;V;V;UP7@UPUPUPV;UPUPUPYB7?YBY>7?YBY>Y>YBYB7?Y>YB7?Y>Y>Y>YB7?YBY>7?Y>YBYBYBYBYIYB7>YBYBYIYIYBYIY>YBYBYBYIYIY(Y(YIYIYI7;YIYIYBYBYIYB7:YI7:YIYIYIYBYIYBYIYIYIYBYBYIYIYBYBYIYIYBYIYIYI7677YIYI77YIYMYMYI77YI77YI78YIYIYFYIYMYM77YM77YMYIYMYMYMYM77YM77YMYMYMYM77YO77YMYOYMYOYO777878YMYMYM78YPZ'Z'YPYP78YP78YPZ'YPYPYPZ'YPYPYPZ'77Z'YPZ'Z'Z'YJZ'7676YJZ'YJYP76YPY+YWYWYW76YSYSYWYSYW7576YS76Y/Y+7777Y/Y+Y+Y/Y/Y+Y+Y/Y/Y+Y/YT7576Y/76Y/YTYTY/Y/YTYTY/Y/Y/7575YTYTYTY/Y/757676YTYTYTY/Y/76Y/YTY/YTYT75YTYTYTY9Y975Y9Y*Y9Y*Y*Y*Y*Y*74Y*74Y*Y*Y9Y9Y9X#Y973X#X#73X#X#X#VWVWX#73VW7374X#74VWX#VWX#74X#X#7475X#X#X/VWX/X/VWVWVW74VWVW7475VSWSVS75VSVSVS75VS75VSVS75WSWSW,WSWS75WSWSWSVSWSWSWS74757576VSVSWSWSVSWSWPVNWPWP74VNWP75VNVN75WY75WYWYWYVNVN7576VN76WYWY76WYWYWYVNVN7677VN77WYWY7778WYWYVNWYWYWYW#77W#WYWY77WYWY7778WYWYW#WYWYWYW#WYWYWYVNVNW#W#VNVN75VNW#VNW#W#VNVNVN7474WY75WYWY75W,W,75WYW,W,WYWYW,W,WYWYWY74WY74WYWYWYWYW,W,WYWY7374WYWY74W,WYWYW,W,WYWYWY73WYWY7374WYWY747575WYW,W,WY75WY76WYWYW,W,W#W#WY75W#W#75WYW,W,7576W,W,W,7676WYWYWY76WYWYWYW,76W,W,76WYW,W,WYWYW,WYWYWY75WYWYWYWY75WYWYW#W#W,W,W#W#73W#W#W#7374W,W,7475W,W,75W,W,W,W,W,W#W#W#W#W#74W#W,74W,W,W,W,W#WYWY73WYW,W,W,W#WYWYW#W#71W#W#W#7172WYWYW#727374WYWYWYW#W#WYWYWY72WYWYWYWS72WS73W,W,73WSW,W,7374W#WYW#WYWY73WYW#W#W#W#73W#W#WYW#WY72WYWY72WYWYWYWYW#WYWYWYWY7172WYWY72W#72W#W#W#W#W#WYWYW#W#71W#W#W#717272W#WYWYW#W#W#72W#W#727373W#WY747475WYWYWYWYW#WYWYWYWY74WYWYWY74WY7475W#WYWYWY757576W#W#7677W#W#77W#W#W#WYWYWY77WY7778W#78W#W#W#WYWYW#WYWYWYW#W#WYWY767777W#W#W#W#77W#W#WY7778W#WY78WY7979W#7:W#VNVNW#W#VNVNW#W#VNVNW#78W#78W#W#78VNW#W#VNW#W#W#WUWUWU77WUWU77WUWUWUWU77WUWU77WM77WMWMWMWMWM77WMWUWMWMWMWU76WMWMWMWMWT76WT76WTWTWMWMWM767677WTWTWMWMWM77WM7778WT78WTWTWTWMWMWM78WM78WTWT78WTWTWT78WTWTWTWU78WMWMWUWM7879WM79WM7:WMWMWM7:WMWM7:7;WT7;WTWTU>UYU>UYU>7:U>7;U>U>U>7;U>7;U>U>U>UYUYUYU>U>7:7;U>U>7;V:U>U>V:V:U>U>V:V:U>79V:V:U>U>79V:U>U>V:V:U>U>V:V:U>77V:V:77U>V:V:U>77UYUY77U>UYUY7778UYUYV:UYV:78V:UY78U/UYUY7879UYUYUYTTUYUYTTTT77TTTTTTUY77U/U/7778U/U/78U/U/U/U/78U/U/7879U/U/TTTTUUUUTTTTUUUUTTTT77TTUU77UUUUUU77UUUU77TTUU78TTTT78TTUUTTUUUUUPUP77UPTLUP77UP77YBY>YBY>YBY>777778S:79797:S:S:S:7:7;S;S0S07;7<7<S0S:S:W-W-7<7=W-7=7>WFW-W-7>W-WFW-WFWFY9Y9W(7=7=W(W(W(Y9Y9W(7=Y9Y97=Y9W-W-WFW-W-W-WFWFW(W(7;7<W(W(7<7=VZ7=VZW(7=W(W(W(VZVZVZW(VZVZVZW(VZW6VZW6W6W6W6W/W679W6W6W(W(79W(79W(W6W(VO79VOVOW(W(79W(VOW(VOW(W6W6W.78W.W.78W6W.W.W.W6W6W6W/W/W6W/W/W/W6W6W675W6VOW6VO7475W(W(W(VUW(VUW(74W(VU74W(W(W(Y9Y9Y974VU74VUVUY9Y9VUY9X#73X#X#7374X#X#VUVU747575X#VUVU75X#76X#X#X#VUX#VU7576X#X#X#VUX#X#X#7576X#X#X#76X#X#VUVUX#X#VU7575X#VUX#VUX#VUVU7475VUVUVUVUW@W@X#X#74X#X#X#VUX#VU73VU74VSVSX#VSX#73X#X#VSVS73VSX#X#X#7373VSVSVSW773W7W773WSW7WSW773W7W77374W7W77475W77676W,W777W,W,77W,77W,W778W,W,78W,W778W7W778W,W7W,W7W7W,W7W,W7W,W,W7W9W7W9W775W7W7W9W975W975W9W7W7W775W9W97576W7W7W9W9W7W7W9W975W975W9W7W9W7W775W975W9W9W9W7W9W7W974W9W9W9W7W9W7W773W<W<W<W9W9W97373W<W<W<73W<W9W9W9W<W9W9W9W9W972W972W<W<W9W<W<W<W9W9W971W9W9W9W<W970W9W970TLUU71TM7172UL72UL737474TLUE75UE75UEUETLTL75TL75TLUE76UETLUE76TLTL76TL76TLTLTLTLTLUE767677UE78UE78UEUE78TL79TLUE79UEUE797:UEUETLUPTL7:TL7:UPUP7:X#VUVUX#X#7:7;W+W+W+7;W+WEW+W+7:WE7;WEWEWE7;7<WEWE7<7=WEWE7=W+WEW+W+W+WE7<WEW+W9W97<W9X#7<X#W9W<7<W<7=W<W:W<W:7<W:W<W<7<WUW:7=W)W<W)7=W<W<7=W<7=W<W<W<W<W<7=W<W)7=W)7>7>W<W<W<WU7>7?7@WUWUWU7@WUWUWU7@WU7@W1W17@W1W1W1WUWUWUWXWUWXWXWX7>UIUIUIULUL7>7?UL7?7@UITHTHTATATHTHTATHT+T+UCUCUCUCUC7=UCUC7=UCSA7=SASZX-X-X-7=7=VXVXVX7=X*VXVXX*X*7=X*7=X*X*X*X*X*7=X*X*X*X*7=X*X*7=7>X*VXX*VXX*X*VXX*VX7<VXVXX*X*7<X*VX7<VX7=VXX*VXX*WUW1WUW1WUWUWU7;WU7;WU7<WU7<WUWUWAWA7<WAWU7<W1W17<W1W1W17<TI7=TI7=TITDTI7=S4S4S4SX7=S@7>7>SXS@7?S@7?S@S@S@7?S@S@SXSX7?SXS@7?S@S@TD7?TD7@S.SMS.S.S.SMS.S.SMSM7>7?SMSM7?SMS.SMS.SMSM7>SMSMSMSMSM7>7>7?T$T$T$SK7?SKT$7?T$7@T$7@T$7AT$7A7BSKT$SKSKSK7ASKT$SKS3S37A7BS3S3SJSJS3S3S37A7AS3SO7BS3SOS3SO7ASOSOSOSO7A7BSG7BSGSOSOSOSGSOSGSO7ASOSO7ASOSOSOSGSGSWSWW>W>W>WVW>W>W>7?WV7?WVWV7?WVWVWVW>W>7?W>WV7?WVWVW>W>7?7@W>W>WVWVW>WVW>WVW$W$W$W?W$W?W?W?7<U#T-U#SJSJSJ7<SJ7<SJSJS7S77<7=S77=7>SJSOSOSO7>SGSG7>SGSO7>SOSG7>SISISISISI7>SISISISOSISOS8SOS8SOS8SOS8SG7;SG7<SISISIS8S8S8S8S>SISIS>S>SISIS>S>S>78S>S>78SWS>79S>S>S>SWV$TPV$78V$TPV$TPV(V(V(7777U@T=78V(V(T=T=V(V(77T=V(7778T=U@U@78U@SPSOSP78SP78SPSP78SOSPSPSP78SPSPS>S>SPSPS>S>77S>SP77SPSPSPS6SPSPS6S6SRS6S6S6S6SRSRSR74SR7475SRSRS6S67576S676SRSRU<U<U<76U<U<76U<U<TGTGTGT;TGT;TG747576V.SD76SDSDSPSP76SPS6S6S676SRSR76SRSESDSESET/75T/7676T077T077T0T/T0T0T0T077T077T0T0T0T;T077T077T0T0T;T;77T;T0T;T0T07677T0T0T;T;77T;T077T0T;T;77T;78T;TGT;T;T;T;T;7777V.78V.78V.797:V.V.7:V.T0T0T;T0T0T079V.79V.V.V.T0T079V.T0T0T0V.78V.V.V.T;T;7879T;T;79T;T079T0T0T0T079V.SESESSSSSESESESSSESE7778SE78SESSX;X;7879X;X;797:T57:T5T5T3T37:7;7;7<T5T5T5T3T5T3T5T3T5T5T3T37:T3T57:T5T5T0T0T7T7T0T0T7T7T0T.T.T.T.T0T.T.7677T.T.T0T077T0T.77T.T.UMUMT0UMV.V.UMV.T075T0UMUMV.UMUMUMV.UM74V.V.74V.UM74UMUMV.V.UMV.T0UMT0UM72UM73UM7374UMUM74UMT075T0T0T0UMT0UMT0T073T.T.T.T0T073T073UMT0UMT0UM73UMV.V.UM7373V.UM747475UMUMSSSSSE75SESSSSSS74XBXBXBXDXD74XD7475XBXB75XD76XD76XDXBXBXDXBXBXBXDXDXB75XDXD7576XDXD76XD7677XBXB7778T5T5T.T.T5T.YUY7YUYUYUY7YUYUY7Y7YUYUY7Y7YUY7X.X.X&X&X.X.X&X&X&X.X&X&X.X.X&X&X.X&X&X&X.X.X&X&X.X.X&X&X.X.X.X&Y4Y4Y@Y@Y4Y@Y4Y@Y4Y@Y@Y@Y4Y4Y@Y@Y4Y4Y@Y@Y4Y@Y@Y@Y4Y@Y@Y@Y4Y@Y4Y4Y@Y@Y4Y4Y@Y@Y4Y4Y4Y@Y4Y4Y@Y@Y4Y4Y'Y,Y'Y,Y'Y,Y'Y,YHYHYUYUYHYHYUYUY3Y3Y,Y,Y,Y3Y,Y,Y,Y,Y,Z&Z&Z&Y,Z&Y,Y,Y,Z&Z&Z&Y,Z&Z&Z&Y,Z&YLYLZ$Z$YLYVYLYVYVYVYLYLYVYGYVYVYGYGYVYGYVYVYVYGYVYVYVYGYNYNYXYXYNYNYXYNYXYXYXYNYNYNX.X.YNYNYNX.YNYGYNYNYGYNYGYGYNYNYGYGYGYNYGYGYNYNYGYGYNYNYNYGYNYNX.X.YNX.X.X.YNYNX.X.YNX.YNX.YGYGYGX.YGX.YGX.YGYGYGX.YGYGX.X.X.YGX.YGX.X.X.X&X.X&X&X&WGWGW=W=WGWGW=W=UTTLUTUTUTTLUTUTUTTLUTTLV?V?V?TLV?V?TLTLUGUGTLUGTLUGTLTLV9V;V9V;V9V9V9V;V9V9V;V;V9V9V;V;TLUGUGUGTLUGUGUGUGUGTLUGUGUGTLUGUGUGUGTUUGUGTLTLUGTUTLTLV;V;TUV;UKUKUKUPUKUKUPUPUKUKUPUPY.Y.YIY.Y.Y.YIY.Y.Y'Y.Y.Y.Y.YIYIY.YIYIYIY.Y.YIYIY.Y.YIYIY.YIYIYIY.Y.YIY.Y.Y.Y.YIY.Y.YIYIY.Y.YIY.Y.Y.YIY.Y.Y.YIY.YIYIYIY.Y.Y.YIYIY.Y.YIYIY.Y.YIY.Y.Y.YIYIY.Y.YIY.YIY.YIY.Y'Y'Y.Y'Y.Y'Y.Y'Y'Y'Y.Y.Y'Y'Y.Y.Y'Y.Y.Y.Y'Y'Y.Y.Y'Y.Y.Y.Y'Y'Y.Y.Y'Y'Y.Y.Y'Y'Y.Y'Y.Y'Y.Y'Y.Y'Y.Y.Y'Y'Y.Y.Y.Y'Y.Y.Y.Y'Y.Y'Y.Y'Y.Y.Y'Y'Y.Y'Y'Y'Y,Y,Y,Y'Y,Y,Y'Y'Y,Y,Y'Y'Y,Y,Y'Y'Y,Y,Y,Y,Y'Y'Y'Y,Y'Y,Y'Y'Y,Y,Y'Y'Y'Y,Y,Y,Y'Y'Y'Y,Y'Y'Y'Y,Y,Y,Y'Y'Y,Y,Y'Y'Y,Y,Y'Y'Y.Y.Y.Y'Y'Y'Y.Y'Y.Y.Y'Y,Y'Y'Y'Y'Y'Y,Y'Y,Y'Y'Y,Y,Y'Y,Y'Y,Y'Y,Y'Y'Y,Y,Y'Y,Y'Y,Y'Y,Y,Y,Y'Y,Y,Y,Y,Y'Y'Y'Y'Y'Y,Y,Y'Y,Y,Y,Y.Y.Y.Y'Y.Y'Y.Y.Y.Y.Y.Y'Y.Y.Y.Y'Y.Y'Y'Y'Y.Y'Y.Y'Y.Y'Y'Y'Y'Y'Y.Y'Y'Y'Y'Y,Y'Y,Y,Y,Y'Y,Y'Y'Y'Y,Y'Y,Y,Y,Y,Y'Y'Y,Y,Y,Y'Y,Y'Y'Y,Y,Y'Y,Y'Y,Y'Y,Y'Y,Y'Y,Y.Y'Y.Y'Y'Y'Y.Y.Y'Y'Y.Y'Y.Y'Y.Y'Y'Y'Y.Y.Y'Y'Y.Y.Y'Y'Y'Y.Y'Y'Y'Y,Y'Y,Y,Y,Y'Y,Y,Y,Y.Y.YIYIYIY.YIYIY.Y.YIYIY.Y.Y.YAY.YAY.Y.Y.Y.Y.YIY.Y.YIYIY.Y.YIYAY.YAYAYAYIYAYIYAYAYAY.Y.YAYAY.YAY.YAY.YAYAYAYIYIYAYAYIYIYAYAYIYIYAYAYIYAYAYAYAYIYAYAYIYAYAYAYIYIYAY,YAY,YAY,YAY,Y,Y,YIYIYIY,YIYIYIY,YIY,YIY,YIY,Y,Y,YIYIY,YIY,Y,Y,Y,Y,YIY,YIYIYIY,YIYIYIY,Y,YIYIY,Y,YIYIY,Y,YIY,YIY,YIYIY,YIYIYIYIY,YIYIY,Y,YIY,YIYIYIZ)YIYIZ)Z)Z)Z)Z)YIZ)Z)Z)YIYIZ)Z)Z)YIZ)YIZ)Z)Z)Z)YIYIZ)YIZ)YIYIZ)Z)Z)Z)Z)YIZ)Z)Z)YIZ)YIYIYIZ)Z)YIYIYIYMYIYMYMYIYMYMY,Y,YIY,Y,Y,YIYIYIY,YIYIYIY,YIY,YIY,Y,Y,YIYIY,Y,Y,Y,YIY,Y,Z&Z&Z&Y,Z&Y,Z&Y,Z&Y,Z&Y,Z&Y,Z&Y,Y,Y,Z&Y,Y,Y,Z&Y,Z&Z&Z&Z&Z&Y,Z&Y,Z&Y,Z&Y,Z&Y,Y,Y,Z&Y,Z&YKY,YKYKY,Z&Z&Z&Y,Z&Z&Z&Y,Y,Y,Z&Y,Y,Y,Z&Z&Z&YKYKZ&Z&YKYKY,Y,Y,Z&Y,Z&Z&Z&YIYIYIY,YIY,Y,Y,YIY,Y,Y,YIY,YIY,YIY,YIY,YIY,YIY,YIYIYIY,YIY,Y,Y,YIY,YIY,YIY,YIY,YIY,YIY,YIYIYIY,YIY,Y,Y,YIY,YIY,Y,Y,YIY,YIY,YIY,Y,Y,Z)Y,Y,Y,Y,Z)Y,Y,Z)Z)Y,Y,Z)Y,YIYIZ)Z)Z)Z)Y,Y,Z)Y,Z)Z)Y,Y,Z)Z)Y,Z)Z)Z)Y,Z)Z)Z)Y,Y,Y,Z)Y,Y,Y,Z)Y,Y,Z)Y,Y,Y,Y,Z)Y,Y,Z)Z)Z)Z)Y1Y1Y,Y,Z)Z)Y,Y,Z)Z)Z)Z#Z)Z#Z#Z#Z)Z#Z)Z#Z)Z#Z)Z#Z)Z#Z)Z#Z#Z#YZZ#YZZ#Z)YZYZYZYZYZZ)YZZ)YZZ)Z)Z)Z)YMZ)YMZ)YMYMYMZ)YMYMZ)Z)YMYMZ)Z)YMYMZ)YMZ)YMZ)Z)Z)YMZ)YMYMYMYMZ)YMYMZ)Z)Z)YMZ)Z)YMYMZ)YMYMYMY,Y,Y,Z#Y,Y,Y,Z#Y,Y,Z#Z#Y,Y,Y,Z#Y,Y,Z#Z#Y,Z#Y,Y,Y,Z#Z#Z#Y,Z#Z#Z#Y,Y,Y,Z#Y,Y,Z#Z#Y,Z#Z#Z#YMY?Y?Y?YMY?YMYMY?Y?Y?YMY?Y?YMYMY?Y?YMY?YMY?YMY?YMYMYMY?YMY?YMYMZ'Y?Z'Z'YMY?Y?Y?YMY?Y?Y?Y?Y?YMYMYMY?YMYMYMY?YMYMY?Y?YMYMYMY?YMYMYMYMY?Y?YMYMY?YMY?Y?YMY?Y?Y?YMYMYMY?Y?Y?YMYMYMY?Z&Z&YKZ&Z&Z&YKYKZ&Z&YKYKZ&Z&YKYKZ&Z&YKZ&YKZ&YKYKZ&Z&YKYKZ&Z&YKYKYKYKYKZ&Z&Z&YKZ&YKZ&YKYKZ&Z&YKZ&Z&Z&YKYKYKYKY-YKYKYKYKY-Y-YKY-Y-Z#Z#Y0Y0Z#Z#Z#Y0Z#Y0Y0Y0Z#Z#Y0Y0Z#Z#Y0Y0Z#Z#Y0Y0Z#Y0Z#Y0Z#Y0Y0Y0Z#Y-Z#Y-Z#Y-Z#Z#Z#Y-Z#Z#Z#Y-Y-Y-Z#Z#Z#Y0Z#Z#Z#Y0Y0Y-Y0Y0Y0Y-Y0Y0Y0Y-Y0Y0Y-Y-Y0Y0Y-Y-Y0Y0Y-Y-Y0Y0Y-Y-Y0Y0Y-Y-Y-Y0Y-Y-Y0Y0Y-Y-Y0Y-Y-Y-Y-Y0Y-Y-Y0Y0Y-Y0Y0Y0Z#Z#Z#Y?Y?Y?Z#Z#Z#Z#Y?Y?Z#Z#Y?Y?Z#Y?Z#Y?Y?Y0Y0Y0Y0Y0Y?Y0Y?Z'Z'Z'Y0Z'Z'Z'Z'Y0Y0Y0Y0Y0Z'Y0Z'Z'Z'YPYPZ'YPYPYPYPYPZ'Z'Z'YPYPY-Y-Y0Y0Y-Y-Y-Y0Y-Y-Y0Y0Y0Y-Y0Y0Y-Y-Y0Y0Y-Y0Y0Y0Y-Y-Y-YYY-Y-YYYYY-YYY-YYY-YYY-Y-YYYYY0Y0YYY0Y0Y0Y0YYY0Y0Y-Y-Y0Y0Y-Y0Y0Y0Y0Y0Y0Y+Y0Y0Y+Y+Y0Y+Y+Y+Y0Y0Y+Y+Y0Y0Y0Y/Y+Y/Y+Y+Y0Y0Y0Y/YEYEZ&YEYEYEY<Y<YYYYY/Y/YYYYY/Y/YYY/Y/Y/Y<Y<Y2Y2Y2Y2Y/Y2Y2Y<Y2Y2Y2Y<Y<Y<Y2Y<Y2Y<Y<Y<Y/Y/Y/Y<Y/Y<Y/Y<Y/Y/Y<Y<Y<Y/Y<Y<Y/Y/Y<Y/Y/Y/Y<YGY<Y<YGYGY<YGY<Y<Z(Z(YGYGY<Y<YGYGY<YGY<YGY<YGY<Y<Y<YGYGYGY<YGYGYGY<Y<YGYGY<YGYGYGZ%Z%VTVTVTVQVTVTVQVQVTVQVQVQVNVNX(X(VNX(X(X(VNVNVNX(W3W3W3X'W3W3X'X'W3W3X'X'W%W%WUWUW%W%WUW%WUX,WUWUX,X,WUWUX,X,WUWUWUX,WUX,U>TTU>TTU>TTTTTTTUTUU0U0TUTUU0U0TLU0TLU0TLU0TLTLU0U0TLTLTUTUU0U0TUTUU0U0TUTUU0U0TUTUTUV;TUTUV;V;TUTUTUV;TUV;V;V;TUV;TUV;TUV;TUV;TUTUTUV;TUTUV;V;TUTUTUUPTUTUUPUPTUTUUPUPTUTUUPUPTUTUUPUPTUTUUPUPTUTUUPUPTUTUUPUPTUTUUPUPTUV;TUV;TUV;TUV;TUTUTUV;TLTLTLU5TLU5U5U5UPUPU9U9UPUPU9U9V;UPV;UPV;UPV;UPV;UPV;V;V;V;V;UPTUV;V;V;TUV;TUV;TUTUTUV;TUTUTUV;TUV;V;V;TUTUTUV;V;UPV;UPUPUPV;V;UPUPV;V;UPUPV;UPV;UPV;UPV;UPV;UPV;V;UPUPYBYBYBY>YBYBY>Y>YBYBYBY>YBYBYBY>Y>YBYBYBY>YBYBYBYIYIYBYBYIYIYIYBYBYIYBYIYIYIYBYIYIYIYBYBYIYIYBYBYIYIYBYBYMYMYIYMYIYIYIYFYFYFYIYFYMYMYIYMYIYMYIYMYMYMYMYOYMYOYMYOYMYMYOYOYMYMYOYOYOYOYMYMYOYOYMYMYOYOYOYMYPYPZ'Z'YPYPZ'YPZ'YPZ'Z'YPYPZ'YPZ'YJZ'YJYJYJZ'YJYPY+Y+Y+YWYWYSYSYWYSYWYSYWYSYSYSY/Y/Y+Y/Y/Y/Y+Y/Y+Y/Y+Y+YTYTY/Y/YTYTYTY/Y/Y/YTYTY/YTYTYTY/Y/YTYTY/Y/Y/YTY/YTYTYTY/YTYTYTY/Y/Y/YTY/YTYTYTY9Y9Y*Y9Y*Y9Y*Y*Y*Y*Y*Y9Y9Y9X#X#Y9X#X#X#VWVWX#VWVWVWVWX#VWVWX#X#VWVWX#X#VWVWX#X#VWVWX#X#VWVWX#X#VWVWX#X#VWVWX#X#VWVWX#X#WSWSVSVSVSWSVSWSVSWSVSWSWSWSWSW,WSWSVSVSVSWSVSVSWSWSVSWSVSWSVSVSWSWSVSWSVNVNWPVNVNVNWPWPVNVNVNWYVNWYWYWYVNVNVNWYVNWYWYWYVNVNVNWYVNWYVNVNWYVNWYWYVNVNWYWYVNVNWYWYVNVNWYWYVNVNWYWYW#WYWYWYWYW#WYWYW#W#WYWYW#WYWYWYVNVNW#VNVNVNWYWYVNWYVNWYVNWYWYWYWYWYW,W,WYWYW,WYWYWYWYW,W,W,WYW,WYWYW,W,WYWYW,W,WYW,W,W,WYW,WYWYWYWYW,W,WYWYW,W,WYWYW,W,WYWYW,W,WYWYW,W,W,W,WYW,W,W,WYW,W#W#WYWYW#WYWYWYW,W,W,WYW,WYWYWYW,WYWYWYW,W,W,WYW,WYWYWYWYWYW,W,WYWYW,W,WYWYW,WYWYWYW#W#W,W,W#W#W,WYW,W,WYWYW,W,WYWYW,W,WYW,W,W,W,WYW,W,W#W#W#W,W#W,W,W,WYWYWYW,W#WYW#WYW#W#WYWYW#W#WYW#W#WYW#WYW#WYW#W#WYWYW#WYWYW#WYWYWSWSWSW,W,W,WSWSW,W,WSWSW,W,W7W7W,W,W7W7WYW#WYW#W#W#WYWYWYW#WYWYW#WYWYWYWYW#W#W#W#WYW#WYWYWYWYW#WYWYW#W#WYW#WYWYWYW#WYWYW#W#WYW#WYW#WYWYW#W#WYWYW#W#WYWYW#W#WYWYW#W#WYW#WYW#WYWYW#W#W#WYW#WYWYWYWYWYWYW#WYWYW#W#WYWYW#W#WYWYW#W#WYW#WYW#WYWYWYW#WYWYW#W#WYWYW#WYW#W#WYW#WYW#W#W#WYWYWYW#WYWYW#W#WYW#W#W#WYWYW#W#WYWYWYW#WYWYW#W#WYW#WYW#WYWYW#W#WYW#W#W#WYW#W#W#W#W#WYWYWYWYW#W#W#W#WYWYWYWYW#W#W#VNW#W#VNVNW#W#VNVNW#VNWUWUWMWMWMWMWMWUWUWUWUWMWUWUWUWMWUWUWUWMWUWMWUWUWUWUWMWMWMWMWTWTWMWMWTWTWMWTWMWTWMWMWMWTWMWTWTWTWMWMWTWMWMWMWTWTWMWTWTWTWMWMWTWTWMWTWTWTWMWMWMWTWMWMWTWTWMWTWTWTWUWUWMWMWUWMWMWMWMWUWMWMWMWTWMWMWMWTWMWTWMWMWTWMWMWMWMWTWMWMWTWTWMWTWTWTUYUYU>UYU>UYU>UYU>UYUYUYU>UYU>U>U>U>V:V:U>U>V:V:U>U>V:V:U>U>V:V:U>U>V:V:U>U>U>V:U>U>V:V:U>U>UYUYU>U>UYUYU>U>UYUYU>UYUYUYV:UYV:UYV:V:U/U/U/UYU/U/UYUYU/U/UYUYUYTTUYUYU/U/UYUYU/U/UYUYU/U/UYUYU/U/UYUYU/U/UYUYU/U/UYUYU/U/TTTTUUTTTTUUUUUUUUTTUUUUTTTTUUTTTTTTUUTTUUTTUUUUUPUPTLUPTLTLUPUPY>YBY>YBY>YBY>YBS:S;S:S;S:S:S;S;S;S;S:S:S:S:S;S:S:S:S;S:S:S:S;S:S:S;S:S:S:S0S:S:S0S0S:S0S0S0S:S0W-W-WFWFW-WFWFWFW-W-W-WFWFW-WFWFWFW-WFW-Y9Y9W(W(Y9Y9Y9W(W(Y9W(W(W(Y9W(W(W(W(VZVZW(W(VZW(W(W(W(VZW(W(VZW(VZVZW(VZVZW(VZW(W6W(W6W6W6W(W6W(W6W(W6W6VOW(VOW(W(W(VOW(W6W6W.W6W.W.W.W6W6W6W6VOY9Y9W(Y9Y9Y9W(W(W(W(W(VUY9Y9W(W(Y9VUY9VUY9Y9VUY9X#VUX#X#VUVUX#X#VUVUX#X#VUVUVUX#VUX#X#X#X#X#VUX#VUVUVUX#X#X#VUX#VUVUVUX#VUVUX#X#VUX#VUVUX#X#VUX#X#VUVUVUVUX#VUVUVUX#VUX#X#X#X#VUX#X#VUVUVUX#VUVUVUX#VUX#VUX#VUX#X#VSX#X#VSVSX#VSX#X#X#VSX#VSVSVSW7WSW7W7WSWSW7WSWSWSW7WSWSWSWSW7WSWSW7W7W7W,W7W7W,W,W7W,W7W,W7W7W,W,W7W,W7W,W7W7W,W,W7W,W7W,W7W7W7W,W7W7W,W,W7W,W7W,W7W7W,W,W7W,W7W9W7W7W7W9W7W9W7W9W7W7W7W9W9W9W9W9W7W7W9W9W7W9W9W9W7W9W7W9W7W9W7W7W7W9W7W7W7W9W7W9W9W9W9W9W9W<W9W9W<W<W9W9W9W<W9W<W9W<W9W<W<W<W9W9W9W<W9W9W9W<W9W<W9W<TLTLUUTLTLTLUUTLTMULTMULTMTMTMULULULTMULTMULTMTMULULTMULUETLUEUEUETLUETLTLTLUETLTLTLUETLUETLUEUEUETLTLTLTLTLUEUETLTLUETLUETLTLTLUETLUETLTLTLUEUETLTLUETLUETLUEUETLTLUETLTLTLUETLUETLUEUEUETLUEUETLTLUEUETLTLUETLTLUPTLUPTLUPUPUPX#X#VUVUX#X#VUVUX#X#VUX#W+W+W+WEW+W+W+WEW+WEWEWEW+WEW+W+WEWEW+WEWEWEW+W+WEWEW+W+WEW+WEW+W+W+WEW+X#W9X#X#X#W9W9W9W<W<W<W:W<W:W:W:W<W:W<W:WUWUW:W:W:WUW:W:W)W<W)W)W)W<W)W<W)W)W)W<W<W<W)W)W)W)W)W<W)W<W)W<W)W)W<W)WUX-X-X-WUWUX-X-WUX-X-X-WUWUW1WUWUW1W1W1WUWUWUW1WUW1W1W1T>UIUIUIUIULUIUIULULUIULULULUIUIULUIULUIUCUCU?U?UCUCU?U?SASZSASZX-X-X-VXX-VXX-VXX*X*VXVXVXX*VXX*VXX*VXX*X*X*X*VXX*X*X*VXX*X*VXVXX*VXVXVXVXX*VXVXVXX*VXVXX*X*VXX*VXX*VXX*WUWUWUWAWUWAWAWAWUWAWUWAWUWUWUWAWAWAWUWAWUWUWUW1WUW1W1W1TDTITITITITITDTITDTITDTDS4S=S4S4SXSXSXS@SXSXS@S@SXSXS@S@SXSXS@SXSXSXS@SXSXSXS@S@S@SXS@S@S@SXS@SXTDTITDTITDTITDTISMSMS.S.SMSMS.S.SMSMS.S.SMT$SMSMSMT$SMSMSMSMSMT$SMSMT$T$T$T$T$SKT$T$T$SKT$SKT$SKT$SKT$SKT$SKT$T$T$SKSKSKT$SKT$SKT$SKT$SKS3SJSJSJSJS3SJSJS3SOS3SOS3S3SOSOSOS3SOSOS3SOS3SOSOSGSGSGSOSOSOSGSOSGSOSOSOSGSOSOSGSGSOSOW>W>WVWVW>W>WVWVW>WVWVWVW>W>WVW>WVW>WVWVWVW>WVWVW>WVWVWVT-U#T-U#SJS7SJS7SJS7SJSJS7S7S7SJS7S7SJSJS7S7S7SJS7S7SJSJSOSGSOSGSOSGSGSGSOSGSOSGSOSOSOSISISISOSISGSGSGSISGSISGSIS>SWS>S>SWSWS>SWSWSWS>S>V$TPTPTPV(V(V(T=T=V(T=T=T=U@T=T=V(V(T=T=V(T=T=T=V(V(T=T=U@U@T=T=SOSOSPSOSPSOSPSPSOSOSOSPSOSPSPSPS>S>SPS>SPS>SPSPS6S6S6SRSRS6SRSRS6S6S6SRS6S6S6SRS6S6SRSRS6S6SRSRU<U<U<T1U<U<T1U<TPTPTPV.TPTPV.V.TPV.V.V.SPSPSDSPSDSPSDSPS6SRS6S6SDSRSDSRT/T/T0T0T/T0T/T/T/T/T0T0T0T0T/T0T/T0T/T0T0T0T;T;T0T;T0T0T;T;T0T;T0T;T0T0T0T;T0T;T0T;T0T0T;T;T0T;T;T;T0T;T;T;T0T;TGTGT;TGT;TGT;T;T;V.T;T;V.V.T;V.T;V.T;V.T;V.T;V.T;V.T;T0V.V.T0T0V.V.T0V.T0T0V.V.T0V.V.V.T0T0T0V.T0V.V.V.T;T;T0T0T;T;T0T0T;T;T0T;T;T;T0T;T0V.V.V.SESESESSSESSSSSSSESSSESSX;XDXDXDXDX;XDXDX;X;XDXDX;XDXDXDT3T3T5T3T5T3T5T5T3T3T5T3T3T3T5T3T3T3T5T5T3T3T5T5T3T3T5T5T.T0T.T.T0T0T.T0T.T0T.T.T.T0T.T.UMUMT0UMUMV.UMUMV.UMUMUMV.V.UMV.T0UMT0UMT0T0T0UMT0T0T0UMT0UMUMUMT0UMT0T0T0UMT0T0T0T0T.T.T.T0T.T.T0UMT0UMT0UMUMUMUMV.UMV.V.V.UMUMUMV.UMUMUMV.UMUMV.V.UMUMSESSSSSSXDXDXBXBXDXDXBXDXBXDXBXDXDXDXBXDXDXDXBXDXBXDXBXBXDXDXBXDXBXDXBXBXDXDXBXBXDXDXBXDXDXDXBXDXBXDXBXBXDXDXBXBT5T.T5T5T.T.T5T5", W = ["Africa/Abidjan", "Africa/Accra", "Africa/Addis_Ababa", "Africa/Algiers", "Africa/Asmara", "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/Tripoli", "Africa/Tunis", "Africa/Windhoek", "America/Adak", "America/Anchorage", "America/Anguilla", "America/Antigua", "America/Araguaina", "America/Argentina/Buenos_Aires", "America/Argentina/Catamarca", "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/Bahia", "America/Bahia_Banderas", "America/Barbados", "America/Belem", "America/Belize", "America/Blanc-Sablon", "America/Boa_Vista", "America/Bogota", "America/Boise", "America/Cambridge_Bay", "America/Campo_Grande", "America/Cancun", "America/Caracas", "America/Cayenne", "America/Cayman", "America/Chicago", "America/Chihuahua", "America/Costa_Rica", "America/Creston", "America/Cuiaba", "America/Curacao", "America/Danmarkshavn", "America/Dawson_Creek", "America/Denver", "America/Detroit", "America/Dominica", "America/Edmonton", "America/Eirunepe", "America/El_Salvador", "America/Fort_Nelson", "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/Vincennes", "America/Iqaluit", "America/Jamaica", "America/Juneau", "America/Kentucky/Louisville", "America/Kentucky/Monticello", "America/Kralendijk", "America/La_Paz", "America/Lima", "America/Los_Angeles", "America/Lower_Princes", "America/Maceio", "America/Managua", "America/Manaus", "America/Marigot", "America/Martinique", "America/Matamoros", "America/Mazatlan", "America/Menominee", "America/Merida", "America/Mexico_City", "America/Miquelon", "America/Moncton", "America/Monterrey", "America/Montevideo", "America/Montserrat", "America/Nassau", "America/New_York", "America/Nome", "America/Noronha", "America/North_Dakota/Beulah", "America/North_Dakota/New_Salem", "America/Ojinaga", "America/Panama", "America/Pangnirtung", "America/Paramaribo", "America/Phoenix", "America/Port-au-Prince", "America/Port_of_Spain", "America/Porto_Velho", "America/Puerto_Rico", "America/Punta_Arenas", "America/Rankin_Inlet", "America/Recife", "America/Regina", "America/Rio_Branco", "America/Santarem", "America/Santiago", "America/Santo_Domingo", "America/Sao_Paulo", "America/Scoresbysund", "America/Sitka", "America/St_Barthelemy", "America/St_Johns", "America/St_Kitts", "America/St_Lucia", "America/St_Thomas", "America/St_Vincent", "America/Tegucigalpa", "America/Thule", "America/Thunder_Bay", "America/Tijuana", "America/Toronto", "America/Tortola", "America/Vancouver", "America/Whitehorse", "America/Winnipeg", "America/Yakutat", "America/Yellowknife", "Antarctica/Casey", "Antarctica/Davis", "Antarctica/DumontDUrville", "Antarctica/Macquarie", "Antarctica/Mawson", "Antarctica/McMurdo", "Antarctica/Rothera", "Antarctica/Syowa", "Antarctica/Troll", "Antarctica/Vostok", "Arctic/Longyearbyen", "Asia/Aden", "Asia/Almaty", "Asia/Amman", "Asia/Anadyr", "Asia/Aqtau", "Asia/Aqtobe", "Asia/Ashgabat", "Asia/Atyrau", "Asia/Baghdad", "Asia/Bahrain", "Asia/Baku", "Asia/Bangkok", "Asia/Barnaul", "Asia/Beirut", "Asia/Bishkek", "Asia/Brunei", "Asia/Chita", "Asia/Choibalsan", "Asia/Colombo", "Asia/Damascus", "Asia/Dhaka", "Asia/Dili", "Asia/Dubai", "Asia/Dushanbe", "Asia/Famagusta", "Asia/Gaza", "Asia/Hebron", "Asia/Ho_Chi_Minh", "Asia/Hong_Kong", "Asia/Hovd", "Asia/Irkutsk", "Asia/Jakarta", "Asia/Jayapura", "Asia/Jerusalem", "Asia/Kabul", "Asia/Kamchatka", "Asia/Karachi", "Asia/Kathmandu", "Asia/Khandyga", "Asia/Kolkata", "Asia/Krasnoyarsk", "Asia/Kuala_Lumpur", "Asia/Kuching", "Asia/Kuwait", "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/Riyadh", "Asia/Sakhalin", "Asia/Samarkand", "Asia/Seoul", "Asia/Shanghai", "Asia/Singapore", "Asia/Srednekolymsk", "Asia/Taipei", "Asia/Tashkent", "Asia/Tbilisi", "Asia/Tehran", "Asia/Thimphu", "Asia/Tokyo", "Asia/Tomsk", "Asia/Ulaanbaatar", "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/Faroe", "Atlantic/Madeira", "Atlantic/Reykjavik", "Atlantic/South_Georgia", "Atlantic/St_Helena", "Atlantic/Stanley", "Australia/Adelaide", "Australia/Brisbane", "Australia/Broken_Hill", "Australia/Currie", "Australia/Darwin", "Australia/Eucla", "Australia/Hobart", "Australia/Lord_Howe", "Australia/Melbourne", "Australia/Perth", "Australia/Sydney", "Etc/GMT", "Etc/GMT+1", "Etc/GMT+10", "Etc/GMT+11", "Etc/GMT+12", "Etc/GMT+2", "Etc/GMT+3", "Etc/GMT+4", "Etc/GMT+5", "Etc/GMT+6", "Etc/GMT+7", "Etc/GMT+8", "Etc/GMT+9", "Etc/GMT-1", "Etc/GMT-10", "Etc/GMT-11", "Etc/GMT-12", "Etc/GMT-2", "Etc/GMT-3", "Etc/GMT-4", "Etc/GMT-5", "Etc/GMT-6", "Etc/GMT-7", "Etc/GMT-8", "Etc/GMT-9", "Etc/UTC", "Europe/Amsterdam", "Europe/Andorra", "Europe/Astrakhan", "Europe/Athens", "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/Lisbon", "Europe/Ljubljana", "Europe/London", "Europe/Luxembourg", "Europe/Madrid", "Europe/Malta", "Europe/Mariehamn", "Europe/Minsk", "Europe/Monaco", "Europe/Moscow", "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/Ulyanovsk", "Europe/Uzhgorod", "Europe/Vaduz", "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", "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/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/Port_Moresby", "Pacific/Rarotonga", "Pacific/Saipan", "Pacific/Tahiti", "Pacific/Tarawa", "Pacific/Tongatapu", "Pacific/Wake", "Pacific/Wallis"];
270
270
  if (b = +b, !(-90 <= (p = +p) && p <= 90 && -180 <= b && b <= 180))
271
271
  throw new RangeError("invalid coordinates");
272
272
  if (90 <= p)
273
273
  return "Etc/GMT";
274
- var o = -1, A = 48 * (180 + b) / 360.00000000000006, q = 24 * (90 - p) / 180.00000000000003, a = 0 | A, Y = 0 | q, e = 96 * Y + 2 * a;
275
- for (e = 56 * O.charCodeAt(e) + O.charCodeAt(e + 1) - 1995; e + W.length < 3136; )
276
- e = 56 * O.charCodeAt(e = 8 * (o = o + e + 1) + 4 * (Y = 0 | (q = 2 * (q - Y) % 2)) + 2 * (a = 0 | (A = 2 * (A - a) % 2)) + 2304) + O.charCodeAt(e + 1) - 1995;
277
- return W[e + W.length - 3136];
274
+ var o = -1, A = 48 * (180 + b) / 360.00000000000006, q = 24 * (90 - p) / 180.00000000000003, d = 0 | A, n = 0 | q, a = 96 * n + 2 * d;
275
+ for (a = 56 * O.charCodeAt(a) + O.charCodeAt(a + 1) - 1995; a + W.length < 3136; )
276
+ a = 56 * O.charCodeAt(a = 8 * (o = o + a + 1) + 4 * (n = 0 | (q = 2 * (q - n) % 2)) + 2 * (d = 0 | (A = 2 * (A - d) % 2)) + 2304) + O.charCodeAt(a + 1) - 1995;
277
+ return W[a + W.length - 3136];
278
278
  }
279
- M.exports = z;
279
+ z.exports = M;
280
280
  })(t0);
281
281
  var P0 = t0.exports;
282
282
  const G0 = /* @__PURE__ */ I0(P0);
283
283
  var N0 = { exports: {} };
284
- (function(M) {
284
+ (function(z) {
285
285
  //! moment-timezone.js
286
286
  //! version : 0.5.48
287
287
  //! Copyright (c) JS Foundation and other contributors
288
288
  //! license : MIT
289
289
  //! github.com/moment/moment-timezone
290
- (function(z, p) {
291
- M.exports ? M.exports = p(L) : p(z.moment);
292
- })(E0, function(z) {
293
- z.version === void 0 && z.default && (z = z.default);
290
+ (function(M, p) {
291
+ z.exports ? z.exports = p(L) : p(M.moment);
292
+ })(E0, function(M) {
293
+ M.version === void 0 && M.default && (M = M.default);
294
294
  var p = "0.5.48", b = {}, O = {}, W = {}, o = {}, A = {}, q;
295
- (!z || typeof z.version != "string") && j("Moment Timezone requires Moment.js. See https://momentjs.com/timezone/docs/#/use-it/browser/");
296
- var a = z.version.split("."), Y = +a[0], e = +a[1];
297
- (Y < 2 || Y === 2 && e < 6) && j("Moment Timezone requires Moment.js >= 2.6.0. You are using Moment.js " + z.version + ". See momentjs.com");
298
- function d(c) {
295
+ (!M || typeof M.version != "string") && j("Moment Timezone requires Moment.js. See https://momentjs.com/timezone/docs/#/use-it/browser/");
296
+ var d = M.version.split("."), n = +d[0], a = +d[1];
297
+ (n < 2 || n === 2 && a < 6) && j("Moment Timezone requires Moment.js >= 2.6.0. You are using Moment.js " + M.version + ". See momentjs.com");
298
+ function Y(c) {
299
299
  return c > 96 ? c - 87 : c > 64 ? c - 29 : c - 48;
300
300
  }
301
301
  function t(c) {
302
- var n = 0, R = c.split("."), X = R[0], f = R[1] || "", u = 1, C, B = 0, G = 1;
303
- for (c.charCodeAt(0) === 45 && (n = 1, G = -1), n; n < X.length; n++)
304
- C = d(X.charCodeAt(n)), B = 60 * B + C;
305
- for (n = 0; n < f.length; n++)
306
- u = u / 60, C = d(f.charCodeAt(n)), B += C * u;
302
+ var R = 0, X = c.split("."), e = X[0], f = X[1] || "", u = 1, _, B = 0, G = 1;
303
+ for (c.charCodeAt(0) === 45 && (R = 1, G = -1), R; R < e.length; R++)
304
+ _ = Y(e.charCodeAt(R)), B = 60 * B + _;
305
+ for (R = 0; R < f.length; R++)
306
+ u = u / 60, _ = Y(f.charCodeAt(R)), B += _ * u;
307
307
  return B * G;
308
308
  }
309
309
  function i(c) {
310
- for (var n = 0; n < c.length; n++)
311
- c[n] = t(c[n]);
310
+ for (var R = 0; R < c.length; R++)
311
+ c[R] = t(c[R]);
312
312
  }
313
- function U(c, n) {
314
- for (var R = 0; R < n; R++)
315
- c[R] = Math.round((c[R - 1] || 0) + c[R] * 6e4);
316
- c[n - 1] = 1 / 0;
313
+ function U(c, R) {
314
+ for (var X = 0; X < R; X++)
315
+ c[X] = Math.round((c[X - 1] || 0) + c[X] * 6e4);
316
+ c[R - 1] = 1 / 0;
317
317
  }
318
- function s(c, n) {
319
- var R = [], X;
320
- for (X = 0; X < n.length; X++)
321
- R[X] = c[n[X]];
322
- return R;
318
+ function s(c, R) {
319
+ var X = [], e;
320
+ for (e = 0; e < R.length; e++)
321
+ X[e] = c[R[e]];
322
+ return X;
323
323
  }
324
324
  function V(c) {
325
- var n = c.split("|"), R = n[2].split(" "), X = n[3].split(""), f = n[4].split(" ");
326
- return i(R), i(X), i(f), U(f, X.length), {
327
- name: n[0],
328
- abbrs: s(n[1].split(" "), X),
329
- offsets: s(R, X),
325
+ var R = c.split("|"), X = R[2].split(" "), e = R[3].split(""), f = R[4].split(" ");
326
+ return i(X), i(e), i(f), U(f, e.length), {
327
+ name: R[0],
328
+ abbrs: s(R[1].split(" "), e),
329
+ offsets: s(X, e),
330
330
  untils: f,
331
- population: n[5] | 0
331
+ population: R[5] | 0
332
332
  };
333
333
  }
334
334
  function S(c) {
335
335
  c && this._set(V(c));
336
336
  }
337
- function r(c, n) {
338
- var R = n.length;
339
- if (c < n[0])
337
+ function r(c, R) {
338
+ var X = R.length;
339
+ if (c < R[0])
340
340
  return 0;
341
- if (R > 1 && n[R - 1] === 1 / 0 && c >= n[R - 2])
342
- return R - 1;
343
- if (c >= n[R - 1])
341
+ if (X > 1 && R[X - 1] === 1 / 0 && c >= R[X - 2])
342
+ return X - 1;
343
+ if (c >= R[X - 1])
344
344
  return -1;
345
- for (var X, f = 0, u = R - 1; u - f > 1; )
346
- X = Math.floor((f + u) / 2), n[X] <= c ? f = X : u = X;
345
+ for (var e, f = 0, u = X - 1; u - f > 1; )
346
+ e = Math.floor((f + u) / 2), R[e] <= c ? f = e : u = e;
347
347
  return u;
348
348
  }
349
349
  S.prototype = {
@@ -351,22 +351,22 @@ var N0 = { exports: {} };
351
351
  this.name = c.name, this.abbrs = c.abbrs, this.untils = c.untils, this.offsets = c.offsets, this.population = c.population;
352
352
  },
353
353
  _index: function(c) {
354
- var n = +c, R = this.untils, X;
355
- if (X = r(n, R), X >= 0)
356
- return X;
354
+ var R = +c, X = this.untils, e;
355
+ if (e = r(R, X), e >= 0)
356
+ return e;
357
357
  },
358
358
  countries: function() {
359
359
  var c = this.name;
360
- return Object.keys(W).filter(function(n) {
361
- return W[n].zones.indexOf(c) !== -1;
360
+ return Object.keys(W).filter(function(R) {
361
+ return W[R].zones.indexOf(c) !== -1;
362
362
  });
363
363
  },
364
364
  parse: function(c) {
365
- var n = +c, R = this.offsets, X = this.untils, f = X.length - 1, u, C, B, G;
365
+ var R = +c, X = this.offsets, e = this.untils, f = e.length - 1, u, _, B, G;
366
366
  for (G = 0; G < f; G++)
367
- if (u = R[G], C = R[G + 1], B = R[G && G - 1], u < C && m.moveAmbiguousForward ? u = C : u > B && m.moveInvalidForward && (u = B), n < X[G] - u * 6e4)
368
- return R[G];
369
- return R[f];
367
+ if (u = X[G], _ = X[G + 1], B = X[G && G - 1], u < _ && m.moveAmbiguousForward ? u = _ : u > B && m.moveInvalidForward && (u = B), R < e[G] - u * 6e4)
368
+ return X[G];
369
+ return X[f];
370
370
  },
371
371
  abbr: function(c) {
372
372
  return this.abbrs[this._index(c)];
@@ -378,12 +378,12 @@ var N0 = { exports: {} };
378
378
  return this.offsets[this._index(c)];
379
379
  }
380
380
  };
381
- function l(c, n) {
382
- this.name = c, this.zones = n;
381
+ function l(c, R) {
382
+ this.name = c, this.zones = R;
383
383
  }
384
384
  function I(c) {
385
- var n = c.toTimeString(), R = n.match(/\([a-z ]+\)/i);
386
- R && R[0] ? (R = R[0].match(/[A-Z]/g), R = R ? R.join("") : void 0) : (R = n.match(/[A-Z]{3,5}/g), R = R ? R[0] : void 0), R === "GMT" && (R = void 0), this.at = +c, this.abbr = R, this.offset = c.getTimezoneOffset();
385
+ var R = c.toTimeString(), X = R.match(/\([a-z ]+\)/i);
386
+ X && X[0] ? (X = X[0].match(/[A-Z]/g), X = X ? X.join("") : void 0) : (X = R.match(/[A-Z]{3,5}/g), X = X ? X[0] : void 0), X === "GMT" && (X = void 0), this.at = +c, this.abbr = X, this.offset = c.getTimezoneOffset();
387
387
  }
388
388
  function P(c) {
389
389
  this.zone = c, this.offsetScore = 0, this.abbrScore = 0;
@@ -391,56 +391,56 @@ var N0 = { exports: {} };
391
391
  P.prototype.scoreOffsetAt = function(c) {
392
392
  this.offsetScore += Math.abs(this.zone.utcOffset(c.at) - c.offset), this.zone.abbr(c.at).replace(/[^A-Z]/g, "") !== c.abbr && this.abbrScore++;
393
393
  };
394
- function E(c, n) {
395
- for (var R, X; X = ((n.at - c.at) / 12e4 | 0) * 6e4; )
396
- R = new I(new Date(c.at + X)), R.offset === c.offset ? c = R : n = R;
394
+ function E(c, R) {
395
+ for (var X, e; e = ((R.at - c.at) / 12e4 | 0) * 6e4; )
396
+ X = new I(new Date(c.at + e)), X.offset === c.offset ? c = X : R = X;
397
397
  return c;
398
398
  }
399
- function _() {
400
- var c = (/* @__PURE__ */ new Date()).getFullYear() - 2, n = new I(new Date(c, 0, 1)), R = n.offset, X = [n], f, u, C, B;
399
+ function C() {
400
+ var c = (/* @__PURE__ */ new Date()).getFullYear() - 2, R = new I(new Date(c, 0, 1)), X = R.offset, e = [R], f, u, _, B;
401
401
  for (B = 1; B < 48; B++)
402
- C = new Date(c, B, 1).getTimezoneOffset(), C !== R && (u = new I(new Date(c, B, 1)), f = E(n, u), X.push(f), X.push(new I(new Date(f.at + 6e4))), n = u, R = C);
402
+ _ = new Date(c, B, 1).getTimezoneOffset(), _ !== X && (u = new I(new Date(c, B, 1)), f = E(R, u), e.push(f), e.push(new I(new Date(f.at + 6e4))), R = u, X = _);
403
403
  for (B = 0; B < 4; B++)
404
- X.push(new I(new Date(c + B, 0, 1))), X.push(new I(new Date(c + B, 6, 1)));
405
- return X;
404
+ e.push(new I(new Date(c + B, 0, 1))), e.push(new I(new Date(c + B, 6, 1)));
405
+ return e;
406
406
  }
407
- function v(c, n) {
408
- return c.offsetScore !== n.offsetScore ? c.offsetScore - n.offsetScore : c.abbrScore !== n.abbrScore ? c.abbrScore - n.abbrScore : c.zone.population !== n.zone.population ? n.zone.population - c.zone.population : n.zone.name.localeCompare(c.zone.name);
407
+ function v(c, R) {
408
+ return c.offsetScore !== R.offsetScore ? c.offsetScore - R.offsetScore : c.abbrScore !== R.abbrScore ? c.abbrScore - R.abbrScore : c.zone.population !== R.zone.population ? R.zone.population - c.zone.population : R.zone.name.localeCompare(c.zone.name);
409
409
  }
410
- function K(c, n) {
411
- var R, X;
412
- for (i(n), R = 0; R < n.length; R++)
413
- X = n[R], A[X] = A[X] || {}, A[X][c] = !0;
410
+ function g(c, R) {
411
+ var X, e;
412
+ for (i(R), X = 0; X < R.length; X++)
413
+ e = R[X], A[e] = A[e] || {}, A[e][c] = !0;
414
414
  }
415
415
  function k(c) {
416
- var n = c.length, R = {}, X = [], f = {}, u, C, B, G;
417
- for (u = 0; u < n; u++)
416
+ var R = c.length, X = {}, e = [], f = {}, u, _, B, G;
417
+ for (u = 0; u < R; u++)
418
418
  if (B = c[u].offset, !f.hasOwnProperty(B)) {
419
419
  G = A[B] || {};
420
- for (C in G)
421
- G.hasOwnProperty(C) && (R[C] = !0);
420
+ for (_ in G)
421
+ G.hasOwnProperty(_) && (X[_] = !0);
422
422
  f[B] = !0;
423
423
  }
424
- for (u in R)
425
- R.hasOwnProperty(u) && X.push(o[u]);
426
- return X;
424
+ for (u in X)
425
+ X.hasOwnProperty(u) && e.push(o[u]);
426
+ return e;
427
427
  }
428
428
  function O0() {
429
429
  try {
430
430
  var c = Intl.DateTimeFormat().resolvedOptions().timeZone;
431
431
  if (c && c.length > 3) {
432
- var n = o[x(c)];
433
- if (n)
434
- return n;
432
+ var R = o[x(c)];
433
+ if (R)
434
+ return R;
435
435
  j("Moment Timezone found " + c + " from the Intl api, but did not have that data loaded.");
436
436
  }
437
437
  } catch {
438
438
  }
439
- var R = _(), X = R.length, f = k(R), u = [], C, B, G;
439
+ var X = C(), e = X.length, f = k(X), u = [], _, B, G;
440
440
  for (B = 0; B < f.length; B++) {
441
- for (C = new P(y(f[B])), G = 0; G < X; G++)
442
- C.scoreOffsetAt(R[G]);
443
- u.push(C);
441
+ for (_ = new P(y(f[B])), G = 0; G < e; G++)
442
+ _.scoreOffsetAt(X[G]);
443
+ u.push(_);
444
444
  }
445
445
  return u.sort(v), u.length > 0 ? u[0].zone.name : void 0;
446
446
  }
@@ -451,85 +451,85 @@ var N0 = { exports: {} };
451
451
  return (c || "").toLowerCase().replace(/\//g, "_");
452
452
  }
453
453
  function W0(c) {
454
- var n, R, X, f;
455
- for (typeof c == "string" && (c = [c]), n = 0; n < c.length; n++)
456
- X = c[n].split("|"), R = X[0], f = x(R), b[f] = c[n], o[f] = R, K(f, X[2].split(" "));
454
+ var R, X, e, f;
455
+ for (typeof c == "string" && (c = [c]), R = 0; R < c.length; R++)
456
+ e = c[R].split("|"), X = e[0], f = x(X), b[f] = c[R], o[f] = X, g(f, e[2].split(" "));
457
457
  }
458
- function y(c, n) {
458
+ function y(c, R) {
459
459
  c = x(c);
460
- var R = b[c], X;
461
- return R instanceof S ? R : typeof R == "string" ? (R = new S(R), b[c] = R, R) : O[c] && n !== y && (X = y(O[c], y)) ? (R = b[c] = new S(), R._set(X), R.name = o[c], R) : null;
460
+ var X = b[c], e;
461
+ return X instanceof S ? X : typeof X == "string" ? (X = new S(X), b[c] = X, X) : O[c] && R !== y && (e = y(O[c], y)) ? (X = b[c] = new S(), X._set(e), X.name = o[c], X) : null;
462
462
  }
463
463
  function H() {
464
- var c, n = [];
464
+ var c, R = [];
465
465
  for (c in o)
466
- o.hasOwnProperty(c) && (b[c] || b[O[c]]) && o[c] && n.push(o[c]);
467
- return n.sort();
466
+ o.hasOwnProperty(c) && (b[c] || b[O[c]]) && o[c] && R.push(o[c]);
467
+ return R.sort();
468
468
  }
469
469
  function T() {
470
470
  return Object.keys(W);
471
471
  }
472
472
  function M0(c) {
473
- var n, R, X, f;
474
- for (typeof c == "string" && (c = [c]), n = 0; n < c.length; n++)
475
- R = c[n].split("|"), X = x(R[0]), f = x(R[1]), O[X] = f, o[X] = R[0], O[f] = X, o[f] = R[1];
473
+ var R, X, e, f;
474
+ for (typeof c == "string" && (c = [c]), R = 0; R < c.length; R++)
475
+ X = c[R].split("|"), e = x(X[0]), f = x(X[1]), O[e] = f, o[e] = X[0], O[f] = e, o[f] = X[1];
476
476
  }
477
- function g(c) {
478
- var n, R, X, f;
477
+ function K(c) {
478
+ var R, X, e, f;
479
479
  if (!(!c || !c.length))
480
- for (n = 0; n < c.length; n++)
481
- f = c[n].split("|"), R = f[0].toUpperCase(), X = f[1].split(" "), W[R] = new l(
482
- R,
483
- X
480
+ for (R = 0; R < c.length; R++)
481
+ f = c[R].split("|"), X = f[0].toUpperCase(), e = f[1].split(" "), W[X] = new l(
482
+ X,
483
+ e
484
484
  );
485
485
  }
486
486
  function h(c) {
487
487
  return c = c.toUpperCase(), W[c] || null;
488
488
  }
489
- function U0(c, n) {
489
+ function U0(c, R) {
490
490
  if (c = h(c), !c)
491
491
  return null;
492
- var R = c.zones.sort();
493
- return n ? R.map(function(X) {
494
- var f = y(X);
492
+ var X = c.zones.sort();
493
+ return R ? X.map(function(e) {
494
+ var f = y(e);
495
495
  return {
496
- name: X,
496
+ name: e,
497
497
  offset: f.utcOffset(/* @__PURE__ */ new Date())
498
498
  };
499
- }) : R;
499
+ }) : X;
500
500
  }
501
501
  function B0(c) {
502
- W0(c.zones), M0(c.links), g(c.countries), m.dataVersion = c.version;
502
+ W0(c.zones), M0(c.links), K(c.countries), m.dataVersion = c.version;
503
503
  }
504
504
  function a0(c) {
505
505
  return a0.didShowError || (a0.didShowError = !0, j("moment.tz.zoneExists('" + c + "') has been deprecated in favor of !moment.tz.zone('" + c + "')")), !!y(c);
506
506
  }
507
507
  function n0(c) {
508
- var n = c._f === "X" || c._f === "x";
509
- return !!(c._a && c._tzm === void 0 && !n);
508
+ var R = c._f === "X" || c._f === "x";
509
+ return !!(c._a && c._tzm === void 0 && !R);
510
510
  }
511
511
  function j(c) {
512
512
  typeof console < "u" && typeof console.error == "function" && console.error(c);
513
513
  }
514
514
  function m(c) {
515
- var n = Array.prototype.slice.call(arguments, 0, -1), R = arguments[arguments.length - 1], X = z.utc.apply(null, n), f;
516
- return !z.isMoment(c) && n0(X) && (f = y(R)) && X.add(f.parse(X), "minutes"), X.tz(R), X;
515
+ var R = Array.prototype.slice.call(arguments, 0, -1), X = arguments[arguments.length - 1], e = M.utc.apply(null, R), f;
516
+ return !M.isMoment(c) && n0(e) && (f = y(X)) && e.add(f.parse(e), "minutes"), e.tz(X), e;
517
517
  }
518
518
  m.version = p, m.dataVersion = "", m._zones = b, m._links = O, m._names = o, m._countries = W, m.add = W0, m.link = M0, m.load = B0, m.zone = y, m.zoneExists = a0, m.guess = d0, m.names = H, m.Zone = S, m.unpack = V, m.unpackBase60 = t, m.needsOffset = n0, m.moveInvalidForward = !0, m.moveAmbiguousForward = !1, m.countries = T, m.zonesForCountry = U0;
519
- var F = z.fn;
520
- z.tz = m, z.defaultZone = null, z.updateOffset = function(c, n) {
521
- var R = z.defaultZone, X;
522
- if (c._z === void 0 && (R && n0(c) && !c._isUTC && c.isValid() && (c._d = z.utc(c._a)._d, c.utc().add(R.parse(c), "minutes")), c._z = R), c._z)
523
- if (X = c._z.utcOffset(c), Math.abs(X) < 16 && (X = X / 60), c.utcOffset !== void 0) {
519
+ var F = M.fn;
520
+ M.tz = m, M.defaultZone = null, M.updateOffset = function(c, R) {
521
+ var X = M.defaultZone, e;
522
+ if (c._z === void 0 && (X && n0(c) && !c._isUTC && c.isValid() && (c._d = M.utc(c._a)._d, c.utc().add(X.parse(c), "minutes")), c._z = X), c._z)
523
+ if (e = c._z.utcOffset(c), Math.abs(e) < 16 && (e = e / 60), c.utcOffset !== void 0) {
524
524
  var f = c._z;
525
- c.utcOffset(-X, n), c._z = f;
525
+ c.utcOffset(-e, R), c._z = f;
526
526
  } else
527
- c.zone(X, n);
528
- }, F.tz = function(c, n) {
527
+ c.zone(e, R);
528
+ }, F.tz = function(c, R) {
529
529
  if (c) {
530
530
  if (typeof c != "string")
531
531
  throw new Error("Time zone name must be a string, got " + c + " [" + typeof c + "]");
532
- return this._z = y(c), this._z ? z.updateOffset(this, n) : j("Moment Timezone has no data for " + c + ". See http://momentjs.com/timezone/docs/#/data-loading/."), this;
532
+ return this._z = y(c), this._z ? M.updateOffset(this, R) : j("Moment Timezone has no data for " + c + ". See http://momentjs.com/timezone/docs/#/data-loading/."), this;
533
533
  }
534
534
  if (this._z)
535
535
  return this._z.name;
@@ -549,15 +549,15 @@ var N0 = { exports: {} };
549
549
  return arguments.length > 0 && (this._z = null), c.apply(this, arguments);
550
550
  };
551
551
  }
552
- F.zoneName = L0(F.zoneName), F.zoneAbbr = L0(F.zoneAbbr), F.utc = i0(F.utc), F.local = i0(F.local), F.utcOffset = s0(F.utcOffset), z.tz.setDefault = function(c) {
553
- return (Y < 2 || Y === 2 && e < 9) && j("Moment Timezone setDefault() requires Moment.js >= 2.9.0. You are using Moment.js " + z.version + "."), z.defaultZone = c ? y(c) : null, z;
552
+ F.zoneName = L0(F.zoneName), F.zoneAbbr = L0(F.zoneAbbr), F.utc = i0(F.utc), F.local = i0(F.local), F.utcOffset = s0(F.utcOffset), M.tz.setDefault = function(c) {
553
+ return (n < 2 || n === 2 && a < 9) && j("Moment Timezone setDefault() requires Moment.js >= 2.9.0. You are using Moment.js " + M.version + "."), M.defaultZone = c ? y(c) : null, M;
554
554
  };
555
- var A0 = z.momentProperties;
556
- return Object.prototype.toString.call(A0) === "[object Array]" ? (A0.push("_z"), A0.push("_a")) : A0 && (A0._z = null), z;
555
+ var A0 = M.momentProperties;
556
+ return Object.prototype.toString.call(A0) === "[object Array]" ? (A0.push("_z"), A0.push("_a")) : A0 && (A0._z = null), M;
557
557
  });
558
558
  })(N0);
559
- var C0 = N0.exports;
560
- const _0 = "2025b", h0 = [
559
+ var _0 = N0.exports;
560
+ const C0 = "2025b", h0 = [
561
561
  "Africa/Abidjan|LMT GMT|g.8 0|01|-2ldXH.Q|48e5",
562
562
  "Africa/Nairobi|LMT +0230 EAT +0245|-2r.g -2u -30 -2J|012132|-2ua2r.g N6nV.g 3Fbu h1cu dzbJ|47e5",
563
563
  "Africa/Algiers|LMT PMT WET WEST CET CEST|-c.c -9.l 0 -10 -10 -20|01232323232323232454542423234542324|-3bQ0c.c MDA2.P cNb9.l HA0 19A0 1iM0 11c0 1oo0 Wo0 1rc0 QM0 1EM0 UM0 DA0 Imo0 rd0 De0 9Xz0 1fb0 1ap0 16K0 2yo0 mEp0 hwL0 jxA0 11A0 dDd0 17b0 11B0 1cN0 2Dy0 1cN0 1fB0 1cL0|26e5",
@@ -1404,25 +1404,25 @@ const _0 = "2025b", h0 = [
1404
1404
  "ZA|Africa/Johannesburg",
1405
1405
  "ZM|Africa/Maputo Africa/Lusaka",
1406
1406
  "ZW|Africa/Maputo Africa/Harare"
1407
- ], K0 = {
1408
- version: _0,
1407
+ ], g0 = {
1408
+ version: C0,
1409
1409
  zones: h0,
1410
1410
  links: D0,
1411
1411
  countries: w0
1412
1412
  };
1413
- var g0 = C0;
1414
- g0.tz.load(K0);
1413
+ var K0 = _0;
1414
+ K0.tz.load(g0);
1415
1415
  var R0 = {};
1416
1416
  Object.defineProperty(R0, "__esModule", { value: !0 });
1417
1417
  var z0 = R0.Variable = void 0, r0;
1418
- (function(M) {
1419
- M[M.undefined = 0] = "undefined", M[M.apparent_temperature = 1] = "apparent_temperature", M[M.cape = 2] = "cape", M[M.cloud_cover = 3] = "cloud_cover", M[M.cloud_cover_high = 4] = "cloud_cover_high", M[M.cloud_cover_low = 5] = "cloud_cover_low", M[M.cloud_cover_mid = 6] = "cloud_cover_mid", M[M.daylight_duration = 7] = "daylight_duration", M[M.dew_point = 8] = "dew_point", M[M.diffuse_radiation = 9] = "diffuse_radiation", M[M.diffuse_radiation_instant = 10] = "diffuse_radiation_instant", M[M.direct_normal_irradiance = 11] = "direct_normal_irradiance", M[M.direct_normal_irradiance_instant = 12] = "direct_normal_irradiance_instant", M[M.direct_radiation = 13] = "direct_radiation", M[M.direct_radiation_instant = 14] = "direct_radiation_instant", M[M.et0_fao_evapotranspiration = 15] = "et0_fao_evapotranspiration", M[M.evapotranspiration = 16] = "evapotranspiration", M[M.freezing_level_height = 17] = "freezing_level_height", M[M.growing_degree_days = 18] = "growing_degree_days", M[M.is_day = 19] = "is_day", M[M.latent_heat_flux = 20] = "latent_heat_flux", M[M.leaf_wetness_probability = 21] = "leaf_wetness_probability", M[M.lifted_index = 22] = "lifted_index", M[M.lightning_potential = 23] = "lightning_potential", M[M.precipitation = 24] = "precipitation", M[M.precipitation_hours = 25] = "precipitation_hours", M[M.precipitation_probability = 26] = "precipitation_probability", M[M.pressure_msl = 27] = "pressure_msl", M[M.rain = 28] = "rain", M[M.relative_humidity = 29] = "relative_humidity", M[M.runoff = 30] = "runoff", M[M.sensible_heat_flux = 31] = "sensible_heat_flux", M[M.shortwave_radiation = 32] = "shortwave_radiation", M[M.shortwave_radiation_instant = 33] = "shortwave_radiation_instant", M[M.showers = 34] = "showers", M[M.snow_depth = 35] = "snow_depth", M[M.snow_height = 36] = "snow_height", M[M.snowfall = 37] = "snowfall", M[M.snowfall_height = 38] = "snowfall_height", M[M.snowfall_water_equivalent = 39] = "snowfall_water_equivalent", M[M.sunrise = 40] = "sunrise", M[M.sunset = 41] = "sunset", M[M.soil_moisture = 42] = "soil_moisture", M[M.soil_moisture_index = 43] = "soil_moisture_index", M[M.soil_temperature = 44] = "soil_temperature", M[M.surface_pressure = 45] = "surface_pressure", M[M.surface_temperature = 46] = "surface_temperature", M[M.temperature = 47] = "temperature", M[M.terrestrial_radiation = 48] = "terrestrial_radiation", M[M.terrestrial_radiation_instant = 49] = "terrestrial_radiation_instant", M[M.total_column_integrated_water_vapour = 50] = "total_column_integrated_water_vapour", M[M.updraft = 51] = "updraft", M[M.uv_index = 52] = "uv_index", M[M.uv_index_clear_sky = 53] = "uv_index_clear_sky", M[M.vapour_pressure_deficit = 54] = "vapour_pressure_deficit", M[M.visibility = 55] = "visibility", M[M.weather_code = 56] = "weather_code", M[M.wind_direction = 57] = "wind_direction", M[M.wind_gusts = 58] = "wind_gusts", M[M.wind_speed = 59] = "wind_speed", M[M.vertical_velocity = 60] = "vertical_velocity", M[M.geopotential_height = 61] = "geopotential_height", M[M.wet_bulb_temperature = 62] = "wet_bulb_temperature", M[M.river_discharge = 63] = "river_discharge", M[M.wave_height = 64] = "wave_height", M[M.wave_period = 65] = "wave_period", M[M.wave_direction = 66] = "wave_direction", M[M.wind_wave_height = 67] = "wind_wave_height", M[M.wind_wave_period = 68] = "wind_wave_period", M[M.wind_wave_peak_period = 69] = "wind_wave_peak_period", M[M.wind_wave_direction = 70] = "wind_wave_direction", M[M.swell_wave_height = 71] = "swell_wave_height", M[M.swell_wave_period = 72] = "swell_wave_period", M[M.swell_wave_peak_period = 73] = "swell_wave_peak_period", M[M.swell_wave_direction = 74] = "swell_wave_direction", M[M.pm10 = 75] = "pm10", M[M.pm2p5 = 76] = "pm2p5", M[M.dust = 77] = "dust", M[M.aerosol_optical_depth = 78] = "aerosol_optical_depth", M[M.carbon_monoxide = 79] = "carbon_monoxide", M[M.nitrogen_dioxide = 80] = "nitrogen_dioxide", M[M.ammonia = 81] = "ammonia", M[M.ozone = 82] = "ozone", M[M.sulphur_dioxide = 83] = "sulphur_dioxide", M[M.alder_pollen = 84] = "alder_pollen", M[M.birch_pollen = 85] = "birch_pollen", M[M.grass_pollen = 86] = "grass_pollen", M[M.mugwort_pollen = 87] = "mugwort_pollen", M[M.olive_pollen = 88] = "olive_pollen", M[M.ragweed_pollen = 89] = "ragweed_pollen", M[M.european_aqi = 90] = "european_aqi", M[M.european_aqi_pm2p5 = 91] = "european_aqi_pm2p5", M[M.european_aqi_pm10 = 92] = "european_aqi_pm10", M[M.european_aqi_nitrogen_dioxide = 93] = "european_aqi_nitrogen_dioxide", M[M.european_aqi_ozone = 94] = "european_aqi_ozone", M[M.european_aqi_sulphur_dioxide = 95] = "european_aqi_sulphur_dioxide", M[M.us_aqi = 96] = "us_aqi", M[M.us_aqi_pm2p5 = 97] = "us_aqi_pm2p5", M[M.us_aqi_pm10 = 98] = "us_aqi_pm10", M[M.us_aqi_nitrogen_dioxide = 99] = "us_aqi_nitrogen_dioxide", M[M.us_aqi_ozone = 100] = "us_aqi_ozone", M[M.us_aqi_sulphur_dioxide = 101] = "us_aqi_sulphur_dioxide", M[M.us_aqi_carbon_monoxide = 102] = "us_aqi_carbon_monoxide", M[M.sunshine_duration = 103] = "sunshine_duration", M[M.convective_inhibition = 104] = "convective_inhibition", M[M.shortwave_radiation_clear_sky = 105] = "shortwave_radiation_clear_sky", M[M.global_tilted_irradiance = 106] = "global_tilted_irradiance", M[M.global_tilted_irradiance_instant = 107] = "global_tilted_irradiance_instant", M[M.ocean_current_velocity = 108] = "ocean_current_velocity", M[M.ocean_current_direction = 109] = "ocean_current_direction", M[M.cloud_base = 110] = "cloud_base", M[M.cloud_top = 111] = "cloud_top", M[M.mass_density = 112] = "mass_density", M[M.boundary_layer_height = 113] = "boundary_layer_height", M[M.formaldehyde = 114] = "formaldehyde", M[M.glyoxal = 115] = "glyoxal", M[M.non_methane_volatile_organic_compounds = 116] = "non_methane_volatile_organic_compounds", M[M.pm10_wildfires = 117] = "pm10_wildfires", M[M.peroxyacyl_nitrates = 118] = "peroxyacyl_nitrates", M[M.secondary_inorganic_aerosol = 119] = "secondary_inorganic_aerosol", M[M.residential_elementary_carbon = 120] = "residential_elementary_carbon", M[M.total_elementary_carbon = 121] = "total_elementary_carbon", M[M.pm2_5_total_organic_matter = 122] = "pm2_5_total_organic_matter", M[M.sea_salt_aerosol = 123] = "sea_salt_aerosol", M[M.nitrogen_monoxide = 124] = "nitrogen_monoxide", M[M.thunderstorm_probability = 125] = "thunderstorm_probability", M[M.rain_probability = 126] = "rain_probability", M[M.freezing_rain_probability = 127] = "freezing_rain_probability", M[M.ice_pellets_probability = 128] = "ice_pellets_probability", M[M.snowfall_probability = 129] = "snowfall_probability", M[M.carbon_dioxide = 130] = "carbon_dioxide", M[M.methane = 131] = "methane", M[M.sea_level_height_msl = 132] = "sea_level_height_msl", M[M.sea_surface_temperature = 133] = "sea_surface_temperature", M[M.invert_barometer_height = 134] = "invert_barometer_height", M[M.hail = 135] = "hail", M[M.albedo = 136] = "albedo", M[M.precipitation_type = 137] = "precipitation_type", M[M.convective_cloud_base = 138] = "convective_cloud_base", M[M.convective_cloud_top = 139] = "convective_cloud_top", M[M.snow_depth_water_equivalent = 140] = "snow_depth_water_equivalent", M[M.secondary_swell_wave_height = 141] = "secondary_swell_wave_height", M[M.secondary_swell_wave_period = 142] = "secondary_swell_wave_period", M[M.secondary_swell_wave_peak_period = 143] = "secondary_swell_wave_peak_period", M[M.secondary_swell_wave_direction = 144] = "secondary_swell_wave_direction", M[M.tertiary_swell_wave_height = 145] = "tertiary_swell_wave_height", M[M.tertiary_swell_wave_period = 146] = "tertiary_swell_wave_period", M[M.tertiary_swell_wave_peak_period = 147] = "tertiary_swell_wave_peak_period", M[M.tertiary_swell_wave_direction = 148] = "tertiary_swell_wave_direction";
1418
+ (function(z) {
1419
+ z[z.undefined = 0] = "undefined", z[z.apparent_temperature = 1] = "apparent_temperature", z[z.cape = 2] = "cape", z[z.cloud_cover = 3] = "cloud_cover", z[z.cloud_cover_high = 4] = "cloud_cover_high", z[z.cloud_cover_low = 5] = "cloud_cover_low", z[z.cloud_cover_mid = 6] = "cloud_cover_mid", z[z.daylight_duration = 7] = "daylight_duration", z[z.dew_point = 8] = "dew_point", z[z.diffuse_radiation = 9] = "diffuse_radiation", z[z.diffuse_radiation_instant = 10] = "diffuse_radiation_instant", z[z.direct_normal_irradiance = 11] = "direct_normal_irradiance", z[z.direct_normal_irradiance_instant = 12] = "direct_normal_irradiance_instant", z[z.direct_radiation = 13] = "direct_radiation", z[z.direct_radiation_instant = 14] = "direct_radiation_instant", z[z.et0_fao_evapotranspiration = 15] = "et0_fao_evapotranspiration", z[z.evapotranspiration = 16] = "evapotranspiration", z[z.freezing_level_height = 17] = "freezing_level_height", z[z.growing_degree_days = 18] = "growing_degree_days", z[z.is_day = 19] = "is_day", z[z.latent_heat_flux = 20] = "latent_heat_flux", z[z.leaf_wetness_probability = 21] = "leaf_wetness_probability", z[z.lifted_index = 22] = "lifted_index", z[z.lightning_potential = 23] = "lightning_potential", z[z.precipitation = 24] = "precipitation", z[z.precipitation_hours = 25] = "precipitation_hours", z[z.precipitation_probability = 26] = "precipitation_probability", z[z.pressure_msl = 27] = "pressure_msl", z[z.rain = 28] = "rain", z[z.relative_humidity = 29] = "relative_humidity", z[z.runoff = 30] = "runoff", z[z.sensible_heat_flux = 31] = "sensible_heat_flux", z[z.shortwave_radiation = 32] = "shortwave_radiation", z[z.shortwave_radiation_instant = 33] = "shortwave_radiation_instant", z[z.showers = 34] = "showers", z[z.snow_depth = 35] = "snow_depth", z[z.snow_height = 36] = "snow_height", z[z.snowfall = 37] = "snowfall", z[z.snowfall_height = 38] = "snowfall_height", z[z.snowfall_water_equivalent = 39] = "snowfall_water_equivalent", z[z.sunrise = 40] = "sunrise", z[z.sunset = 41] = "sunset", z[z.soil_moisture = 42] = "soil_moisture", z[z.soil_moisture_index = 43] = "soil_moisture_index", z[z.soil_temperature = 44] = "soil_temperature", z[z.surface_pressure = 45] = "surface_pressure", z[z.surface_temperature = 46] = "surface_temperature", z[z.temperature = 47] = "temperature", z[z.terrestrial_radiation = 48] = "terrestrial_radiation", z[z.terrestrial_radiation_instant = 49] = "terrestrial_radiation_instant", z[z.total_column_integrated_water_vapour = 50] = "total_column_integrated_water_vapour", z[z.updraft = 51] = "updraft", z[z.uv_index = 52] = "uv_index", z[z.uv_index_clear_sky = 53] = "uv_index_clear_sky", z[z.vapour_pressure_deficit = 54] = "vapour_pressure_deficit", z[z.visibility = 55] = "visibility", z[z.weather_code = 56] = "weather_code", z[z.wind_direction = 57] = "wind_direction", z[z.wind_gusts = 58] = "wind_gusts", z[z.wind_speed = 59] = "wind_speed", z[z.vertical_velocity = 60] = "vertical_velocity", z[z.geopotential_height = 61] = "geopotential_height", z[z.wet_bulb_temperature = 62] = "wet_bulb_temperature", z[z.river_discharge = 63] = "river_discharge", z[z.wave_height = 64] = "wave_height", z[z.wave_period = 65] = "wave_period", z[z.wave_direction = 66] = "wave_direction", z[z.wind_wave_height = 67] = "wind_wave_height", z[z.wind_wave_period = 68] = "wind_wave_period", z[z.wind_wave_peak_period = 69] = "wind_wave_peak_period", z[z.wind_wave_direction = 70] = "wind_wave_direction", z[z.swell_wave_height = 71] = "swell_wave_height", z[z.swell_wave_period = 72] = "swell_wave_period", z[z.swell_wave_peak_period = 73] = "swell_wave_peak_period", z[z.swell_wave_direction = 74] = "swell_wave_direction", z[z.pm10 = 75] = "pm10", z[z.pm2p5 = 76] = "pm2p5", z[z.dust = 77] = "dust", z[z.aerosol_optical_depth = 78] = "aerosol_optical_depth", z[z.carbon_monoxide = 79] = "carbon_monoxide", z[z.nitrogen_dioxide = 80] = "nitrogen_dioxide", z[z.ammonia = 81] = "ammonia", z[z.ozone = 82] = "ozone", z[z.sulphur_dioxide = 83] = "sulphur_dioxide", z[z.alder_pollen = 84] = "alder_pollen", z[z.birch_pollen = 85] = "birch_pollen", z[z.grass_pollen = 86] = "grass_pollen", z[z.mugwort_pollen = 87] = "mugwort_pollen", z[z.olive_pollen = 88] = "olive_pollen", z[z.ragweed_pollen = 89] = "ragweed_pollen", z[z.european_aqi = 90] = "european_aqi", z[z.european_aqi_pm2p5 = 91] = "european_aqi_pm2p5", z[z.european_aqi_pm10 = 92] = "european_aqi_pm10", z[z.european_aqi_nitrogen_dioxide = 93] = "european_aqi_nitrogen_dioxide", z[z.european_aqi_ozone = 94] = "european_aqi_ozone", z[z.european_aqi_sulphur_dioxide = 95] = "european_aqi_sulphur_dioxide", z[z.us_aqi = 96] = "us_aqi", z[z.us_aqi_pm2p5 = 97] = "us_aqi_pm2p5", z[z.us_aqi_pm10 = 98] = "us_aqi_pm10", z[z.us_aqi_nitrogen_dioxide = 99] = "us_aqi_nitrogen_dioxide", z[z.us_aqi_ozone = 100] = "us_aqi_ozone", z[z.us_aqi_sulphur_dioxide = 101] = "us_aqi_sulphur_dioxide", z[z.us_aqi_carbon_monoxide = 102] = "us_aqi_carbon_monoxide", z[z.sunshine_duration = 103] = "sunshine_duration", z[z.convective_inhibition = 104] = "convective_inhibition", z[z.shortwave_radiation_clear_sky = 105] = "shortwave_radiation_clear_sky", z[z.global_tilted_irradiance = 106] = "global_tilted_irradiance", z[z.global_tilted_irradiance_instant = 107] = "global_tilted_irradiance_instant", z[z.ocean_current_velocity = 108] = "ocean_current_velocity", z[z.ocean_current_direction = 109] = "ocean_current_direction", z[z.cloud_base = 110] = "cloud_base", z[z.cloud_top = 111] = "cloud_top", z[z.mass_density = 112] = "mass_density", z[z.boundary_layer_height = 113] = "boundary_layer_height", z[z.formaldehyde = 114] = "formaldehyde", z[z.glyoxal = 115] = "glyoxal", z[z.non_methane_volatile_organic_compounds = 116] = "non_methane_volatile_organic_compounds", z[z.pm10_wildfires = 117] = "pm10_wildfires", z[z.peroxyacyl_nitrates = 118] = "peroxyacyl_nitrates", z[z.secondary_inorganic_aerosol = 119] = "secondary_inorganic_aerosol", z[z.residential_elementary_carbon = 120] = "residential_elementary_carbon", z[z.total_elementary_carbon = 121] = "total_elementary_carbon", z[z.pm2_5_total_organic_matter = 122] = "pm2_5_total_organic_matter", z[z.sea_salt_aerosol = 123] = "sea_salt_aerosol", z[z.nitrogen_monoxide = 124] = "nitrogen_monoxide", z[z.thunderstorm_probability = 125] = "thunderstorm_probability", z[z.rain_probability = 126] = "rain_probability", z[z.freezing_rain_probability = 127] = "freezing_rain_probability", z[z.ice_pellets_probability = 128] = "ice_pellets_probability", z[z.snowfall_probability = 129] = "snowfall_probability", z[z.carbon_dioxide = 130] = "carbon_dioxide", z[z.methane = 131] = "methane", z[z.sea_level_height_msl = 132] = "sea_level_height_msl", z[z.sea_surface_temperature = 133] = "sea_surface_temperature", z[z.invert_barometer_height = 134] = "invert_barometer_height", z[z.hail = 135] = "hail", z[z.albedo = 136] = "albedo", z[z.precipitation_type = 137] = "precipitation_type", z[z.convective_cloud_base = 138] = "convective_cloud_base", z[z.convective_cloud_top = 139] = "convective_cloud_top", z[z.snow_depth_water_equivalent = 140] = "snow_depth_water_equivalent", z[z.secondary_swell_wave_height = 141] = "secondary_swell_wave_height", z[z.secondary_swell_wave_period = 142] = "secondary_swell_wave_period", z[z.secondary_swell_wave_peak_period = 143] = "secondary_swell_wave_peak_period", z[z.secondary_swell_wave_direction = 144] = "secondary_swell_wave_direction", z[z.tertiary_swell_wave_height = 145] = "tertiary_swell_wave_height", z[z.tertiary_swell_wave_period = 146] = "tertiary_swell_wave_period", z[z.tertiary_swell_wave_peak_period = 147] = "tertiary_swell_wave_peak_period", z[z.tertiary_swell_wave_direction = 148] = "tertiary_swell_wave_direction";
1420
1420
  })(r0 || (z0 = R0.Variable = r0 = {}));
1421
1421
  var X0 = {};
1422
1422
  Object.defineProperty(X0, "__esModule", { value: !0 });
1423
1423
  var c0 = X0.Aggregation = void 0, f0;
1424
- (function(M) {
1425
- M[M.none = 0] = "none", M[M.minimum = 1] = "minimum", M[M.maximum = 2] = "maximum", M[M.mean = 3] = "mean", M[M.p10 = 4] = "p10", M[M.p25 = 5] = "p25", M[M.median = 6] = "median", M[M.p75 = 7] = "p75", M[M.p90 = 8] = "p90", M[M.dominant = 9] = "dominant", M[M.sum = 10] = "sum", M[M.spread = 11] = "spread";
1424
+ (function(z) {
1425
+ z[z.none = 0] = "none", z[z.minimum = 1] = "minimum", z[z.maximum = 2] = "maximum", z[z.mean = 3] = "mean", z[z.p10 = 4] = "p10", z[z.p25 = 5] = "p25", z[z.median = 6] = "median", z[z.p75 = 7] = "p75", z[z.p90 = 8] = "p90", z[z.dominant = 9] = "dominant", z[z.sum = 10] = "sum", z[z.spread = 11] = "spread";
1426
1426
  })(f0 || (c0 = X0.Aggregation = f0 = {}));
1427
1427
  let D;
1428
1428
  try {
@@ -1431,7 +1431,7 @@ try {
1431
1431
  } finally {
1432
1432
  }
1433
1433
  class b0 {
1434
- constructor(z, p) {
1434
+ constructor(M, p) {
1435
1435
  Q(this, "apikey");
1436
1436
  Q(this, "debug");
1437
1437
  Q(this, "FORECAST", {
@@ -1480,7 +1480,7 @@ class b0 {
1480
1480
  etime: L().unix(),
1481
1481
  version: 0
1482
1482
  });
1483
- this.apikey = z || "smE3JnDLHy3TizVv", this.debug = p;
1483
+ this.apikey = M || "smE3JnDLHy3TizVv", this.debug = p;
1484
1484
  }
1485
1485
  async standardWeatherModels() {
1486
1486
  return w.standardWeatherModels();
@@ -1488,11 +1488,11 @@ class b0 {
1488
1488
  async standardMarineModels() {
1489
1489
  return w.standardMarineModels();
1490
1490
  }
1491
- async autoPickMeteoModel(z = "best_match") {
1492
- return w.autoPickMeteoModel(z);
1491
+ async autoPickMeteoModel(M = "best_match") {
1492
+ return w.autoPickMeteoModel(M);
1493
1493
  }
1494
- static range(z, p, b) {
1495
- return Array.from({ length: (p - z) / b }, (O, W) => z + W * b);
1494
+ static range(M, p, b) {
1495
+ return Array.from({ length: (p - M) / b }, (O, W) => M + W * b);
1496
1496
  }
1497
1497
  /**
1498
1498
  * 大气数据
@@ -1500,32 +1500,32 @@ class b0 {
1500
1500
  * @param callback
1501
1501
  * @param options
1502
1502
  */
1503
- async weatherForecast(z, p, b = {}) {
1503
+ async weatherForecast(M, p, b = {}) {
1504
1504
  try {
1505
1505
  const O = L();
1506
1506
  let W;
1507
- if (z.start_dates instanceof Array)
1508
- for (let A = 0; A < z.start_dates.length; A++) {
1509
- z.start_date = z.start_dates[A], z.end_date = z.end_dates[A], z.fake = z.fakes[A];
1510
- const q = z.url[A];
1507
+ if (M.start_dates instanceof Array)
1508
+ for (let A = 0; A < M.start_dates.length; A++) {
1509
+ M.start_date = M.start_dates[A], M.end_date = M.end_dates[A], M.fake = M.fakes[A];
1510
+ const q = M.url[A];
1511
1511
  this.debug && D.debug("[%s] fetch weather via %s with %j", b.requestId, q, {
1512
- start_date: z.start_date,
1513
- end_date: z.end_date,
1514
- fake: z.fake,
1512
+ start_date: M.start_date,
1513
+ end_date: M.end_date,
1514
+ fake: M.fake,
1515
1515
  step: A
1516
1516
  });
1517
- const a = await o0(q, z), Y = p ? await p(a, z, b) : await this.parseWeatherData(a, z, b);
1518
- W ? await this.mergeSegments(W, Y) : W = Y;
1517
+ const d = await o0(q, M), n = p ? await p(d, M, b) : await this.parseWeatherData(d, M, b);
1518
+ W ? await this.mergeSegments(W, n) : W = n;
1519
1519
  }
1520
1520
  else {
1521
- const A = await o0(z.url, z);
1522
- W = p ? await p(A, z, b) : await this.parseWeatherData(A, z, b);
1521
+ const A = await o0(M.url, M);
1522
+ W = p ? await p(A, M, b) : await this.parseWeatherData(A, M, b);
1523
1523
  }
1524
- delete z.apikey;
1524
+ delete M.apikey;
1525
1525
  const o = L();
1526
- return this.debug && D.info("[%s] fetch weather api (%j) cost: %d ms", b.requestId, z.url, o.diff(O, "ms")), W;
1526
+ return this.debug && D.info("[%s] fetch weather api (%j) cost: %d ms", b.requestId, M.url, o.diff(O, "ms")), W;
1527
1527
  } catch (O) {
1528
- return D.warn("[%s] weather forecast failed: %s, with %j", b.requestId, O, z), [];
1528
+ return D.warn("[%s] weather forecast failed: %s, with %j", b.requestId, O, M), [];
1529
1529
  }
1530
1530
  }
1531
1531
  /**
@@ -1544,35 +1544,35 @@ class b0 {
1544
1544
  * @param params
1545
1545
  * @param options
1546
1546
  */
1547
- async marineForecast(z, p = {}) {
1548
- var b, O, W, o, A, q, a, Y;
1547
+ async marineForecast(M, p = {}) {
1548
+ var b, O, W, o, A, q, d, n;
1549
1549
  try {
1550
- const e = L();
1551
- let d;
1552
- if (z.start_dates instanceof Array)
1553
- for (let r = 0; r < z.start_dates.length; r++) {
1554
- z.start_date = z.start_dates[r], z.end_date = z.end_dates[r], z.fake = z.fakes[r];
1555
- const l = z.url[r];
1550
+ const a = L();
1551
+ let Y;
1552
+ if (M.start_dates instanceof Array)
1553
+ for (let r = 0; r < M.start_dates.length; r++) {
1554
+ M.start_date = M.start_dates[r], M.end_date = M.end_dates[r], M.fake = M.fakes[r];
1555
+ const l = M.url[r];
1556
1556
  this.debug && D.debug("[%s] fetch marine via %s with %j", p.requestId, l, {
1557
- start_date: z.start_date,
1558
- end_date: z.end_date,
1559
- fake: z.fake,
1557
+ start_date: M.start_date,
1558
+ end_date: M.end_date,
1559
+ fake: M.fake,
1560
1560
  step: r
1561
1561
  });
1562
- const I = await o0(l, z), P = await this.parseWeatherData(I, z, p);
1563
- d ? await this.mergeSegments(d, P) : d = P;
1562
+ const I = await o0(l, M), P = await this.parseWeatherData(I, M, p);
1563
+ Y ? await this.mergeSegments(Y, P) : Y = P;
1564
1564
  }
1565
1565
  else {
1566
- const r = await o0(z.url, z);
1567
- d = await this.parseWeatherData(r, z, p);
1566
+ const r = await o0(M.url, M);
1567
+ Y = await this.parseWeatherData(r, M, p);
1568
1568
  }
1569
- delete z.apikey;
1569
+ delete M.apikey;
1570
1570
  const t = L();
1571
- this.debug && D.info("[%s] fetch marine api (%j) cost: %d ms", p.requestId, z.url, t.diff(e, "ms"));
1572
- const i = await this.mergeMarineData(d), U = i.find((r) => r.model === "ncep_gfswave016"), s = i.find((r) => r.model === "ncep_gfswave025"), V = i.find((r) => r.model === "meteofrance_wave"), S = i.find((r) => r.model === "best_match");
1573
- return (O = (b = S == null ? void 0 : S.hourly) == null ? void 0 : b.wave_height) != null && O.every((r) => r !== null) ? [S] : (o = (W = V == null ? void 0 : V.hourly) == null ? void 0 : W.wave_height) != null && o.every((r) => r !== null) ? [V] : (q = (A = U == null ? void 0 : U.hourly) == null ? void 0 : A.wave_height) != null && q.every((r) => r !== null) ? [U] : (Y = (a = s == null ? void 0 : s.hourly) == null ? void 0 : a.wave_height) != null && Y.every((r) => r !== null) ? [s] : i != null && i.length ? [i[0]] : [];
1574
- } catch (e) {
1575
- return D.warn("[%s] marine forecast failed: %s, with %j", p.requestId, e, z), [];
1571
+ this.debug && D.info("[%s] fetch marine api (%j) cost: %d ms", p.requestId, M.url, t.diff(a, "ms"));
1572
+ const i = await this.mergeMarineData(Y), U = i.find((r) => r.model === "ncep_gfswave016"), s = i.find((r) => r.model === "ncep_gfswave025"), V = i.find((r) => r.model === "meteofrance_wave"), S = i.find((r) => r.model === "best_match");
1573
+ return (O = (b = S == null ? void 0 : S.hourly) == null ? void 0 : b.wave_height) != null && O.every((r) => r !== null) ? [S] : (o = (W = V == null ? void 0 : V.hourly) == null ? void 0 : W.wave_height) != null && o.every((r) => r !== null) ? [V] : (q = (A = U == null ? void 0 : U.hourly) == null ? void 0 : A.wave_height) != null && q.every((r) => r !== null) ? [U] : (n = (d = s == null ? void 0 : s.hourly) == null ? void 0 : d.wave_height) != null && n.every((r) => r !== null) ? [s] : i != null && i.length ? [i[0]] : [];
1574
+ } catch (a) {
1575
+ return D.warn("[%s] marine forecast failed: %s, with %j", p.requestId, a, M), [];
1576
1576
  }
1577
1577
  }
1578
1578
  /**
@@ -1582,19 +1582,19 @@ class b0 {
1582
1582
  * @param options
1583
1583
  * @private
1584
1584
  */
1585
- async parseWeatherData(z, p, b = {}) {
1586
- var o, A, q, a, Y, e, d;
1585
+ async parseWeatherData(M, p, b = {}) {
1586
+ var o, A, q, d, n, a, Y;
1587
1587
  const O = [], W = Math.pow(10, b.precision || 6);
1588
- for (let t = 0; t < z.length; t++) {
1589
- const i = z[t], U = i.utcOffsetSeconds(), s = i.timezone(), V = i.current(), S = i.hourly(), r = i.daily(), l = {};
1588
+ for (let t = 0; t < M.length; t++) {
1589
+ const i = M[t], U = i.utcOffsetSeconds(), s = i.timezone(), V = i.current(), S = i.hourly(), r = i.daily(), l = {};
1590
1590
  if (l.timezone = s || void 0, l.offset = b0.prettyTimezoneOffset(U), l.model = p.models instanceof Array ? (o = p.models) == null ? void 0 : o[t] : p.models || "best_match", V) {
1591
1591
  const I = L();
1592
1592
  l.current = {
1593
1593
  time: L.unix(Number(V.time())).utc().format()
1594
1594
  };
1595
1595
  for (let E = 0; E < V.variablesLength(); E++) {
1596
- const _ = V.variables(E).value();
1597
- l.current[p.current[E]] = isNaN(_) ? null : Math.round(_ * W) / W;
1596
+ const C = V.variables(E).value();
1597
+ l.current[p.current[E]] = isNaN(C) ? null : Math.round(C * W) / W;
1598
1598
  }
1599
1599
  const P = L();
1600
1600
  this.debug && D.debug("[%s] fetch current variables cost: %d ms", b.requestId, P.diff(I, "ms"));
@@ -1604,12 +1604,12 @@ class b0 {
1604
1604
  l.hourly = {
1605
1605
  date: P.utc().format(),
1606
1606
  time: b0.range(Number(S.time()), Number(S.timeEnd()), S.interval()).map(
1607
- (_) => L.unix(_).add(p.fake ? 1 : 0, "year").diff(P, "h")
1607
+ (C) => L.unix(C).add(p.fake ? 1 : 0, "year").diff(P, "h")
1608
1608
  )
1609
1609
  };
1610
- for (let _ = 0; _ < S.variablesLength(); _++) {
1611
- const v = (a = (q = (A = S.variables(_).valuesArray()) == null ? void 0 : A.toString()) == null ? void 0 : q.split(",")) == null ? void 0 : a.map((K) => isNaN(K) ? null : Math.round(Number(K) * W) / W);
1612
- l.hourly[p.hourly[_]] = v;
1610
+ for (let C = 0; C < S.variablesLength(); C++) {
1611
+ const v = (d = (q = (A = S.variables(C).valuesArray()) == null ? void 0 : A.toString()) == null ? void 0 : q.split(",")) == null ? void 0 : d.map((g) => isNaN(g) ? null : Math.round(Number(g) * W) / W);
1612
+ l.hourly[p.hourly[C]] = v;
1613
1613
  }
1614
1614
  const E = L();
1615
1615
  this.debug && D.debug("[%s] fetch hourly variables cost: %d ms", b.requestId, E.diff(I, "ms"));
@@ -1622,8 +1622,8 @@ class b0 {
1622
1622
  )
1623
1623
  };
1624
1624
  for (let E = 0; E < r.variablesLength(); E += b.memberLength ?? 1) {
1625
- const _ = (d = (e = (Y = r.variables(E).valuesArray()) == null ? void 0 : Y.toString()) == null ? void 0 : e.split(",")) == null ? void 0 : d.map((v) => isNaN(v) ? null : Math.round(Number(v) * W) / W);
1626
- l.daily[p.daily[E / (b.memberLength ?? 1)]] = _;
1625
+ const C = (Y = (a = (n = r.variables(E).valuesArray()) == null ? void 0 : n.toString()) == null ? void 0 : a.split(",")) == null ? void 0 : Y.map((v) => isNaN(v) ? null : Math.round(Number(v) * W) / W);
1626
+ l.daily[p.daily[E / (b.memberLength ?? 1)]] = C;
1627
1627
  }
1628
1628
  const P = L();
1629
1629
  this.debug && D.debug("[%s] fetch daily variables cost: %d ms", b.requestId, P.diff(I, "ms"));
@@ -1638,11 +1638,11 @@ class b0 {
1638
1638
  * @param options
1639
1639
  * @private
1640
1640
  */
1641
- async parseSeasonalDailyVariable(z, p, b = {}) {
1642
- var o, A, q, a, Y, e, d, t, i, U, s, V, S, r, l, I;
1641
+ async parseSeasonalDailyVariable(M, p, b = {}) {
1642
+ var o, A, q, d, n, a, Y, t, i, U, s, V, S, r, l, I;
1643
1643
  const O = [], W = Math.pow(10, b.precision || 6);
1644
- for (let P = 0; P < z.length; P++) {
1645
- const E = z[P], _ = E.utcOffsetSeconds(), v = E.timezone(), K = E.daily(), k = [...Array(K.variablesLength())].map((T, M0) => K.variables(M0)), O0 = k.filter(
1644
+ for (let P = 0; P < M.length; P++) {
1645
+ const E = M[P], C = E.utcOffsetSeconds(), v = E.timezone(), g = E.daily(), k = [...Array(g.variablesLength())].map((T, M0) => g.variables(M0)), O0 = k.filter(
1646
1646
  (T) => (T == null ? void 0 : T.variable()) === z0.temperature && (T == null ? void 0 : T.altitude()) === 2 && (T == null ? void 0 : T.aggregation()) === c0.maximum
1647
1647
  ), d0 = k.filter(
1648
1648
  (T) => (T == null ? void 0 : T.variable()) === z0.temperature && (T == null ? void 0 : T.altitude()) === 2 && (T == null ? void 0 : T.aggregation()) === c0.minimum
@@ -1651,23 +1651,23 @@ class b0 {
1651
1651
  ), y = k.filter(
1652
1652
  (T) => (T == null ? void 0 : T.variable()) === z0.wind_direction && (T == null ? void 0 : T.altitude()) === 10 && (T == null ? void 0 : T.aggregation()) === c0.dominant
1653
1653
  ), H = {};
1654
- if (H.timezone = v || void 0, H.offset = b0.prettyTimezoneOffset(_), H.model = p.models instanceof Array ? (o = p.models) == null ? void 0 : o[P] : p.models || "best_match", K) {
1654
+ if (H.timezone = v || void 0, H.offset = b0.prettyTimezoneOffset(C), H.model = p.models instanceof Array ? (o = p.models) == null ? void 0 : o[P] : p.models || "best_match", g) {
1655
1655
  const T = L();
1656
1656
  H.daily = {
1657
- time: b0.range(Number(K.time()), Number(K.timeEnd()), K.interval()).map(
1658
- (g) => L.unix(g).add(p.fake ? 1 : 0, "year").utc().format()
1657
+ time: b0.range(Number(g.time()), Number(g.timeEnd()), g.interval()).map(
1658
+ (K) => L.unix(K).add(p.fake ? 1 : 0, "year").utc().format()
1659
1659
  )
1660
1660
  };
1661
- for (const g of O0)
1662
- H.daily.temperature_2m_max = (a = (q = (A = g.valuesArray()) == null ? void 0 : A.toString()) == null ? void 0 : q.split(",")) == null ? void 0 : a.map((h) => isNaN(h) ? null : Math.round(Number(h) * W) / W);
1663
- for (const g of d0)
1664
- H.daily.temperature_2m_min = (d = (e = (Y = g.valuesArray()) == null ? void 0 : Y.toString()) == null ? void 0 : e.split(",")) == null ? void 0 : d.map((h) => isNaN(h) ? null : Math.round(Number(h) * W) / W);
1665
- for (const g of x)
1666
- H.daily.precipitation_sum = (U = (i = (t = g.valuesArray()) == null ? void 0 : t.toString()) == null ? void 0 : i.split(",")) == null ? void 0 : U.map((h) => isNaN(h) ? null : Math.round(Number(h) * W) / W);
1667
- for (const g of y)
1668
- H.daily.wind_direction_10m_dominant = (S = (V = (s = g.valuesArray()) == null ? void 0 : s.toString()) == null ? void 0 : V.split(",")) == null ? void 0 : S.map((h) => isNaN(h) ? null : Math.round(Number(h) * W) / W);
1669
- for (const g of W0)
1670
- H.daily.wind_speed_10m_max = (I = (l = (r = g.valuesArray()) == null ? void 0 : r.toString()) == null ? void 0 : l.split(",")) == null ? void 0 : I.map((h) => isNaN(h) ? null : Math.round(Number(h) * W) / W);
1661
+ for (const K of O0)
1662
+ H.daily.temperature_2m_max = (d = (q = (A = K.valuesArray()) == null ? void 0 : A.toString()) == null ? void 0 : q.split(",")) == null ? void 0 : d.map((h) => isNaN(h) ? null : Math.round(Number(h) * W) / W);
1663
+ for (const K of d0)
1664
+ H.daily.temperature_2m_min = (Y = (a = (n = K.valuesArray()) == null ? void 0 : n.toString()) == null ? void 0 : a.split(",")) == null ? void 0 : Y.map((h) => isNaN(h) ? null : Math.round(Number(h) * W) / W);
1665
+ for (const K of x)
1666
+ H.daily.precipitation_sum = (U = (i = (t = K.valuesArray()) == null ? void 0 : t.toString()) == null ? void 0 : i.split(",")) == null ? void 0 : U.map((h) => isNaN(h) ? null : Math.round(Number(h) * W) / W);
1667
+ for (const K of y)
1668
+ H.daily.wind_direction_10m_dominant = (S = (V = (s = K.valuesArray()) == null ? void 0 : s.toString()) == null ? void 0 : V.split(",")) == null ? void 0 : S.map((h) => isNaN(h) ? null : Math.round(Number(h) * W) / W);
1669
+ for (const K of W0)
1670
+ H.daily.wind_speed_10m_max = (I = (l = (r = K.valuesArray()) == null ? void 0 : r.toString()) == null ? void 0 : l.split(",")) == null ? void 0 : I.map((h) => isNaN(h) ? null : Math.round(Number(h) * W) / W);
1671
1671
  const M0 = L();
1672
1672
  D.debug("[%s] fetch daily variables cost: %d ms", b.requestId, M0.diff(T, "ms"));
1673
1673
  }
@@ -1675,49 +1675,49 @@ class b0 {
1675
1675
  }
1676
1676
  return O;
1677
1677
  }
1678
- async mergeSegments(z, p) {
1679
- for (let b = 0; b < z.length; b++)
1680
- for (const O in z[b])
1678
+ async mergeSegments(M, p) {
1679
+ for (let b = 0; b < M.length; b++)
1680
+ for (const O in M[b])
1681
1681
  if (O === "hourly") {
1682
1682
  for (const W in p[b][O])
1683
- if (z[b][O][W] instanceof Array)
1684
- if (z[b][O].date === p[b][O].date) {
1685
- for (let o = 0; o < z[b][O][W].length; o++)
1686
- z[b][O][W][o] === null && (z[b][O][W][o] = p[b][O][W][o]);
1687
- for (let o = z[b][O][W].length; o < p[b][O][W].length; o++)
1688
- z[b][O][W].push(p[b][O][W][o]);
1683
+ if (M[b][O][W] instanceof Array)
1684
+ if (M[b][O].date === p[b][O].date) {
1685
+ for (let o = 0; o < M[b][O][W].length; o++)
1686
+ M[b][O][W][o] === null && (M[b][O][W][o] = p[b][O][W][o]);
1687
+ for (let o = M[b][O][W].length; o < p[b][O][W].length; o++)
1688
+ M[b][O][W].push(p[b][O][W][o]);
1689
1689
  } else {
1690
- const o = L(p[b][O].date), A = L(z[b][O].date);
1690
+ const o = L(p[b][O].date), A = L(M[b][O].date);
1691
1691
  for (let q = 0; q < p[b][O][W].length; q++) {
1692
- const a = o.clone().add(q, "h").diff(A, "h");
1693
- a < z[b][O][W].length ? z[b][O][W][a] === null && (z[b][O][W][a] = p[b][O][W][q]) : W === "time" ? z[b][O][W].push(a) : z[b][O][W].push(p[b][O][W][q]);
1692
+ const d = o.clone().add(q, "h").diff(A, "h");
1693
+ d < M[b][O][W].length ? M[b][O][W][d] === null && (M[b][O][W][d] = p[b][O][W][q]) : W === "time" ? M[b][O][W].push(d) : M[b][O][W].push(p[b][O][W][q]);
1694
1694
  }
1695
1695
  }
1696
1696
  } else if (O === "daily") {
1697
1697
  for (const W in p[b][O])
1698
- if (z[b][O][W] instanceof Array && W !== "time")
1698
+ if (M[b][O][W] instanceof Array && W !== "time")
1699
1699
  for (let o = 0; o < p[b][O][W].length; o++)
1700
- z[b][O].time.includes(p[b][O].time[o]) || z[b][O][W].push(p[b][O][W][o]);
1700
+ M[b][O].time.includes(p[b][O].time[o]) || M[b][O][W].push(p[b][O][W][o]);
1701
1701
  for (let W = 0; W < p[b][O].time.length; W++)
1702
- z[b][O].time.includes(p[b][O].time[W]) || z[b][O].time.push(p[b][O].time[W]);
1702
+ M[b][O].time.includes(p[b][O].time[W]) || M[b][O].time.push(p[b][O].time[W]);
1703
1703
  }
1704
- return z;
1704
+ return M;
1705
1705
  }
1706
- async mergeMarineData(z) {
1707
- var o, A, q, a;
1708
- const p = [], b = z.find((Y) => Y.model === "best_match");
1706
+ async mergeMarineData(M) {
1707
+ var A, q, d, n;
1708
+ const p = [], b = M.find((a) => a.model === "best_match");
1709
1709
  b && p.push(b);
1710
- const O = z.find((Y) => Y.model === "meteofrance_currents"), W = z.find((Y) => Y.model === "ecmwf_wam025");
1711
- for (const Y of z)
1712
- ["best_match", "meteofrance_currents"].includes(Y.model) || (Y.hourly.ocean_current_velocity = (o = O == null ? void 0 : O.hourly) == null ? void 0 : o.ocean_current_velocity, Y.hourly.ocean_current_direction = (A = O == null ? void 0 : O.hourly) == null ? void 0 : A.ocean_current_direction, Y.hourly.sea_level_height_msl = (q = O == null ? void 0 : O.hourly) == null ? void 0 : q.sea_level_height_msl, Y.hourly.sea_surface_temperature = (a = O == null ? void 0 : O.hourly) == null ? void 0 : a.sea_surface_temperature, p.push(Y)), Y.model === "meteofrance_wave" && W && (Y.hourly.time = W.hourly.time, Y.hourly.wave_height = W.hourly.wave_height, Y.hourly.wave_direction = W.hourly.wave_direction, Y.hourly.wave_period = W.hourly.wave_period, Y.daily.time = W.daily.time, Y.daily.wave_height_max = W.daily.wave_height_max, Y.daily.wave_direction_dominant = W.daily.wave_direction_dominant, Y.daily.wave_period_max = W.daily.wave_period_max);
1710
+ const O = M.find((a) => a.model === "meteofrance_currents"), W = M.find((a) => a.model === "ecmwf_wam025"), o = M.find((a) => a.model === "meteofrance_wave");
1711
+ for (const a of M)
1712
+ ["best_match", "meteofrance_currents"].includes(a.model) || (a.hourly.ocean_current_velocity = (A = O == null ? void 0 : O.hourly) == null ? void 0 : A.ocean_current_velocity, a.hourly.ocean_current_direction = (q = O == null ? void 0 : O.hourly) == null ? void 0 : q.ocean_current_direction, a.hourly.sea_level_height_msl = (d = O == null ? void 0 : O.hourly) == null ? void 0 : d.sea_level_height_msl, a.hourly.sea_surface_temperature = (n = O == null ? void 0 : O.hourly) == null ? void 0 : n.sea_surface_temperature, p.push(a)), a.model === "meteofrance_wave" && W && (a.hourly.time = W.hourly.time, a.hourly.wave_height = W.hourly.wave_height, a.hourly.wave_direction = W.hourly.wave_direction, a.hourly.wave_period = W.hourly.wave_period, a.daily.time = W.daily.time, a.daily.wave_height_max = W.daily.wave_height_max, a.daily.wave_direction_dominant = W.daily.wave_direction_dominant, a.daily.wave_period_max = W.daily.wave_period_max), a.model === "ecmwf_wam025" && o && (a.hourly.swell_wave_height = o.hourly.swell_wave_height, a.hourly.swell_wave_direction = o.hourly.swell_wave_direction, a.hourly.swell_wave_period = o.hourly.swell_wave_period, a.hourly.wind_wave_height = o.hourly.wind_wave_height, a.hourly.wind_wave_direction = o.hourly.wind_wave_direction, a.hourly.wind_wave_period = o.hourly.wind_wave_period, a.daily.swell_wave_height_max = o.daily.swell_wave_height_max, a.daily.swell_wave_period_max = o.daily.swell_wave_period_max, a.daily.swell_wave_direction_dominant = o.daily.swell_wave_direction_dominant, a.daily.wind_wave_height_max = o.daily.wind_wave_height_max, a.daily.wind_wave_direction_dominant = o.daily.wind_wave_direction_dominant, a.daily.wind_wave_period_max = o.daily.wind_wave_period_max);
1713
1713
  return p;
1714
1714
  }
1715
- pickForecastUrl(z, p, b, O = {}) {
1716
- return z ? b && !O.noFake ? O.selfHistory ? this.FORECAST.ORM_HISTORY_MARINE_URL : this.FORECAST.OM_MARINE_URL : p ? O.marineUrl || this.FORECAST.ORM_MARINE_URL : this.FORECAST.OM_MARINE_URL : b && !O.noFake ? O.selfHistory ? this.FORECAST.ORM_HISTORY_URL : this.FORECAST.OM_HISTORY_URL : p ? O.weatherUrl || this.FORECAST.ORM_URL : this.FORECAST.OM_URL;
1715
+ pickForecastUrl(M, p, b, O = {}) {
1716
+ return M ? b && !O.noFake ? O.selfHistory ? this.FORECAST.ORM_HISTORY_MARINE_URL : this.FORECAST.OM_MARINE_URL : p ? O.marineUrl || this.FORECAST.ORM_MARINE_URL : this.FORECAST.OM_MARINE_URL : b && !O.noFake ? O.selfHistory ? this.FORECAST.ORM_HISTORY_URL : this.FORECAST.OM_HISTORY_URL : p ? O.weatherUrl || this.FORECAST.ORM_URL : this.FORECAST.OM_URL;
1717
1717
  }
1718
- pickMarineModels(z) {
1718
+ pickMarineModels(M) {
1719
1719
  var o;
1720
- const p = (o = z == null ? void 0 : z.trim()) == null ? void 0 : o.split(",");
1720
+ const p = (o = M == null ? void 0 : M.trim()) == null ? void 0 : o.split(",");
1721
1721
  if (!(p != null && p.length))
1722
1722
  return ["best_match"];
1723
1723
  const b = [];
@@ -1727,8 +1727,8 @@ class b0 {
1727
1727
  }
1728
1728
  const O = b.reduce((A, q) => (A.includes(q) || A.push(q), A), []), W = ["best_match", "meteofrance_currents", "ecmwf_wam025", "meteofrance_wave", "ncep_gfswave025", "gwam", "era5_ocean", "ewam", "ncep_gfswave016"];
1729
1729
  return O.sort((A, q) => {
1730
- const a = W.indexOf(A), Y = W.indexOf(q);
1731
- return a - Y;
1730
+ const d = W.indexOf(A), n = W.indexOf(q);
1731
+ return d - n;
1732
1732
  }), O;
1733
1733
  }
1734
1734
  /**
@@ -1739,33 +1739,33 @@ class b0 {
1739
1739
  * @param options 请求参数
1740
1740
  * @private
1741
1741
  */
1742
- async prepare(z, p, b, O = {}) {
1743
- var Y, e;
1744
- const W = O.maxDays || 14, o = L.utc(), A = z ? L.utc(z) : void 0, q = p ? await this.pickUpdateMeta(b.models) : [], a = (e = (Y = q[0]) == null ? void 0 : Y.meta) != null && e.endTime ? L(q[0].meta.endTime) : o.clone().add(W, "day");
1745
- if (z) {
1746
- const d = A.clone().utc().add(O.forecastDays ?? 1, "day");
1747
- d.isAfter(a) ? (d.subtract(1, "year"), A.isAfter(a) ? (A.subtract(1, "year"), b.start_dates = [
1742
+ async prepare(M, p, b, O = {}) {
1743
+ var n, a;
1744
+ const W = O.maxDays || 14, o = L.utc(), A = M ? L.utc(M) : void 0, q = p ? await this.pickUpdateMeta(b.models) : [], d = (a = (n = q[0]) == null ? void 0 : n.meta) != null && a.endTime ? L(q[0].meta.endTime) : o.clone().add(W, "day");
1745
+ if (M) {
1746
+ const Y = A.clone().utc().add(O.forecastDays ?? 1, "day");
1747
+ Y.isAfter(d) ? (Y.subtract(1, "year"), A.isAfter(d) ? (A.subtract(1, "year"), b.start_dates = [
1748
1748
  A.clone().subtract(O.pastDays || 0, "day").utc().format("YYYY-MM-DD")
1749
- ], b.end_dates = [d.utc().format("YYYY-MM-DD")], b.fakes = [!0], b.url = [this.pickForecastUrl(p, O.selfHosted ?? !0, !0, O)]) : (b.start_dates = [
1749
+ ], b.end_dates = [Y.utc().format("YYYY-MM-DD")], b.fakes = [!0], b.url = [this.pickForecastUrl(p, O.selfHosted ?? !0, !0, O)]) : (b.start_dates = [
1750
1750
  A.clone().subtract(O.pastDays || 0, "day").utc().format("YYYY-MM-DD"),
1751
- a.clone().subtract(1, "year").subtract(1, "day").utc().format("YYYY-MM-DD")
1752
- ], b.end_dates = [a.clone().subtract(1, "day").utc().format("YYYY-MM-DD"), d.utc().format("YYYY-MM-DD")], b.fakes = [!1, !0], b.url = [
1751
+ d.clone().subtract(1, "year").subtract(1, "day").utc().format("YYYY-MM-DD")
1752
+ ], b.end_dates = [d.clone().subtract(1, "day").utc().format("YYYY-MM-DD"), Y.utc().format("YYYY-MM-DD")], b.fakes = [!1, !0], b.url = [
1753
1753
  this.pickForecastUrl(p, O.selfHosted ?? !0, !1, O),
1754
1754
  this.pickForecastUrl(p, O.selfHosted ?? !0, !0, O)
1755
1755
  ])) : (b.start_dates = [
1756
1756
  A.clone().subtract(O.pastDays || 0, "day").utc().format("YYYY-MM-DD")
1757
- ], b.end_dates = [d.utc().format("YYYY-MM-DD")], b.fakes = [!1], b.url = [this.pickForecastUrl(p, O.selfHosted ?? !0, A.isBefore(o.clone().subtract(30, "day")), O)]);
1757
+ ], b.end_dates = [Y.utc().format("YYYY-MM-DD")], b.fakes = [!1], b.url = [this.pickForecastUrl(p, O.selfHosted ?? !0, A.isBefore(o.clone().subtract(30, "day")), O)]);
1758
1758
  } else
1759
1759
  b.forecast_days = O.forecastDays, b.past_days = O.pastDays, b.fake = !1, b.url = this.pickForecastUrl(p, O.selfHosted ?? !0, !1, O);
1760
1760
  return b;
1761
1761
  }
1762
- toStdLng(z, p = 6) {
1763
- z > 180 ? (z = z % 360, z = z > 180 ? z - 360 : z) : z < -180 && (z = z % 360, z = z < -180 ? z + 360 : z);
1762
+ toStdLng(M, p = 6) {
1763
+ M > 180 ? (M = M % 360, M = M > 180 ? M - 360 : M) : M < -180 && (M = M % 360, M = M < -180 ? M + 360 : M);
1764
1764
  const b = Math.pow(10, p);
1765
- return Math.round(z * b) / b;
1765
+ return Math.round(M * b) / b;
1766
1766
  }
1767
- timezoneOffset(z, p) {
1768
- const b = G0(z, p), O = L().tz(b).utcOffset();
1767
+ timezoneOffset(M, p) {
1768
+ const b = G0(M, p), O = L().tz(b).utcOffset();
1769
1769
  return Math.round(O / 60 * 10) / 10;
1770
1770
  }
1771
1771
  /**
@@ -1773,10 +1773,10 @@ class b0 {
1773
1773
  * @param offset 单位秒
1774
1774
  * @private
1775
1775
  */
1776
- static prettyTimezoneOffset(z) {
1777
- z = Math.round(z / 3600 * 10) / 10;
1778
- let p = Math.floor(Math.abs(z)), b = Math.round((Math.abs(z) - p) * 60);
1779
- return b = b > 9 ? b : `0${b}`, p = p > 9 ? p : `0${p}`, z > 0 ? `+${p}:${b}` : `-${p}:${b}`;
1776
+ static prettyTimezoneOffset(M) {
1777
+ M = Math.round(M / 3600 * 10) / 10;
1778
+ let p = Math.floor(Math.abs(M)), b = Math.round((Math.abs(M) - p) * 60);
1779
+ return b = b > 9 ? b : `0${b}`, p = p > 9 ? p : `0${p}`, M > 0 ? `+${p}:${b}` : `-${p}:${b}`;
1780
1780
  }
1781
1781
  /**
1782
1782
  * 预报数据
@@ -1804,7 +1804,7 @@ class b0 {
1804
1804
  * @param withHourly
1805
1805
  * @param options
1806
1806
  */
1807
- async spotForecast(z, p, b, O = !0, W = !0, o = !1, A = {
1807
+ async spotForecast(M, p, b, O = !0, W = !0, o = !1, A = {
1808
1808
  forecastDays: 1,
1809
1809
  pastDays: 0,
1810
1810
  precision: 6,
@@ -1812,31 +1812,31 @@ class b0 {
1812
1812
  maxDays: 14
1813
1813
  }) {
1814
1814
  var i, U, s, V, S, r;
1815
- p = this.toStdLng(p), this.debug && D.info("[%s] spot forecast params: %j", A.requestId, { lat: z, lng: p, datetime: b, simplify: O, withDaily: W, withHourly: o, options: A });
1815
+ p = this.toStdLng(p), this.debug && D.info("[%s] spot forecast params: %j", A.requestId, { lat: M, lng: p, datetime: b, simplify: O, withDaily: W, withHourly: o, options: A });
1816
1816
  const q = {
1817
1817
  apikey: this.apikey,
1818
- latitude: z,
1818
+ latitude: M,
1819
1819
  longitude: p,
1820
1820
  cell_selection: "sea",
1821
1821
  wind_speed_unit: "kn",
1822
1822
  models: ((i = A.weatherModels) == null ? void 0 : i.split(",")) || ["best_match"],
1823
1823
  timezone: "auto"
1824
1824
  };
1825
- let a;
1826
- const Y = this.timezoneOffset(z, p);
1827
- b && (a = L.utc(b).utcOffset(Y), a.subtract(Y > 0 ? Y : -Y, "h"), A.selfHistory = !(a != null && a.isBefore(L.utc().subtract(240, "days")))), W && (q.daily = ((U = this.FORECAST.WEATHER_VARIABLES.NORMAL.DAILY) == null ? void 0 : U.split(",")) || []), a || (A.forecastDays = A.forecastDays || 1, A.pastDays = 0, o = !0), o && (q.hourly = ((s = this.FORECAST.WEATHER_VARIABLES.NORMAL.HOURLY) == null ? void 0 : s.split(",")) || []), A.maxDays = A.maxDays || 14, A.pastDays = A.pastDays || 0, A.pastDays = A.pastDays > 7 ? 7 : A.pastDays < 0 ? 0 : A.pastDays, A.forecastDays = A.forecastDays ?? 1, A.forecastDays = A.forecastDays > A.maxDays ? A.maxDays : A.forecastDays < 0 ? 1 : A.forecastDays, await this.prepare(a == null ? void 0 : a.utc().format(), !1, q, A);
1828
- const e = await this.weatherForecast(q, void 0, A), d = {
1825
+ let d;
1826
+ const n = this.timezoneOffset(M, p);
1827
+ b && (d = L.utc(b).utcOffset(n), d.subtract(n > 0 ? n : -n, "h"), A.selfHistory = !(d != null && d.isBefore(L.utc().subtract(240, "days")))), W && (q.daily = ((U = this.FORECAST.WEATHER_VARIABLES.NORMAL.DAILY) == null ? void 0 : U.split(",")) || []), d || (A.forecastDays = A.forecastDays || 1, A.pastDays = 0, o = !0), o && (q.hourly = ((s = this.FORECAST.WEATHER_VARIABLES.NORMAL.HOURLY) == null ? void 0 : s.split(",")) || []), A.maxDays = A.maxDays || 14, A.pastDays = A.pastDays || 0, A.pastDays = A.pastDays > 7 ? 7 : A.pastDays < 0 ? 0 : A.pastDays, A.forecastDays = A.forecastDays ?? 1, A.forecastDays = A.forecastDays > A.maxDays ? A.maxDays : A.forecastDays < 0 ? 1 : A.forecastDays, await this.prepare(d == null ? void 0 : d.utc().format(), !1, q, A);
1828
+ const a = await this.weatherForecast(q, void 0, A), Y = {
1829
1829
  apikey: this.apikey,
1830
- latitude: z,
1830
+ latitude: M,
1831
1831
  longitude: p,
1832
1832
  cell_selection: "sea",
1833
1833
  timezone: "auto",
1834
1834
  wind_speed_unit: "kn",
1835
1835
  models: this.pickMarineModels(A.marineModels)
1836
1836
  };
1837
- W && (d.daily = this.FORECAST.MARINE_VARIABLES.DAILY.split(",")), a || (A.forecastDays = A.forecastDays || 1, o = !0), o && (d.hourly = this.FORECAST.MARINE_VARIABLES.HOURLY.split(",")), await this.prepare(a == null ? void 0 : a.utc().format(), !0, d, A);
1838
- let t = await this.marineForecast(d, A);
1839
- return (r = (S = (V = t[0]) == null ? void 0 : V.hourly) == null ? void 0 : S.wave_height) != null && r.every((l) => l === null || l === 0) && (d.models = this.pickMarineModels("best_match,ncep_gfswave025,ecmwf_wam025,meteofrance_wave"), t = await this.marineForecast(d, A)), { weather: e, marine: t };
1837
+ W && (Y.daily = this.FORECAST.MARINE_VARIABLES.DAILY.split(",")), d || (A.forecastDays = A.forecastDays || 1, o = !0), o && (Y.hourly = this.FORECAST.MARINE_VARIABLES.HOURLY.split(",")), await this.prepare(d == null ? void 0 : d.utc().format(), !0, Y, A);
1838
+ let t = await this.marineForecast(Y, A);
1839
+ return (r = (S = (V = t[0]) == null ? void 0 : V.hourly) == null ? void 0 : S.wave_height) != null && r.every((l) => l === null || l === 0) && (Y.models = this.pickMarineModels("best_match,ncep_gfswave025,ecmwf_wam025,meteofrance_wave"), t = await this.marineForecast(Y, A)), { weather: a, marine: t };
1840
1840
  }
1841
1841
  /**
1842
1842
  * 历史再分析数据
@@ -1859,32 +1859,32 @@ class b0 {
1859
1859
  * @param withMarine
1860
1860
  * @param options
1861
1861
  */
1862
- async spotHistorical(z, p, b, O, W = !0, o = !0, A = !1, q = {
1862
+ async spotHistorical(M, p, b, O, W = !0, o = !0, A = !1, q = {
1863
1863
  precision: 6
1864
1864
  }) {
1865
1865
  var U, s;
1866
- p = this.toStdLng(p), this.debug && D.info("[%s] spot historical params: %j", q.requestId, { lat: z, lng: p, startDate: b, endDate: O, withMarine: A, options: q });
1867
- const a = this.timezoneOffset(z, p), Y = L.utc(b).utcOffset(a), e = L.utc(O).utcOffset(a);
1868
- Y.subtract(a > 0 ? a : -a, "h"), e.subtract(a > 0 ? a : -a, "h");
1869
- const d = {
1866
+ p = this.toStdLng(p), this.debug && D.info("[%s] spot historical params: %j", q.requestId, { lat: M, lng: p, startDate: b, endDate: O, withMarine: A, options: q });
1867
+ const d = this.timezoneOffset(M, p), n = L.utc(b).utcOffset(d), a = L.utc(O).utcOffset(d);
1868
+ n.subtract(d > 0 ? d : -d, "h"), a.subtract(d > 0 ? d : -d, "h");
1869
+ const Y = {
1870
1870
  apikey: this.apikey,
1871
- latitude: z,
1871
+ latitude: M,
1872
1872
  longitude: p,
1873
1873
  cell_selection: "sea",
1874
1874
  wind_speed_unit: "kn",
1875
1875
  models: ((U = q.weatherModels) == null ? void 0 : U.split(",")) || ["best_match"],
1876
1876
  timezone: "auto",
1877
1877
  url: this.HISTORICAL.OM_URL,
1878
- start_date: Y.format("YYYY-MM-DD"),
1879
- end_date: e.format("YYYY-MM-DD")
1878
+ start_date: n.format("YYYY-MM-DD"),
1879
+ end_date: a.format("YYYY-MM-DD")
1880
1880
  };
1881
- W && (d.daily = this.HISTORICAL.WEATHER_VARIABLES.DAILY.split(",")), o && (d.hourly = this.HISTORICAL.WEATHER_VARIABLES.HOURLY.split(","));
1882
- const t = await this.weatherForecast(d, void 0, q);
1881
+ W && (Y.daily = this.HISTORICAL.WEATHER_VARIABLES.DAILY.split(",")), o && (Y.hourly = this.HISTORICAL.WEATHER_VARIABLES.HOURLY.split(","));
1882
+ const t = await this.weatherForecast(Y, void 0, q);
1883
1883
  let i;
1884
1884
  if (A) {
1885
1885
  const V = {
1886
1886
  apikey: this.apikey,
1887
- latitude: z,
1887
+ latitude: M,
1888
1888
  longitude: p,
1889
1889
  cell_selection: "sea",
1890
1890
  timezone: "auto",
@@ -1893,8 +1893,8 @@ class b0 {
1893
1893
  daily: this.FORECAST.MARINE_VARIABLES.DAILY.split(","),
1894
1894
  hourly: this.FORECAST.MARINE_VARIABLES.HOURLY.split(","),
1895
1895
  url: this.FORECAST.OM_MARINE_URL,
1896
- start_date: Y.format("YYYY-MM-DD"),
1897
- end_date: e.format("YYYY-MM-DD")
1896
+ start_date: n.format("YYYY-MM-DD"),
1897
+ end_date: a.format("YYYY-MM-DD")
1898
1898
  };
1899
1899
  i = await this.marineForecast(V, q);
1900
1900
  }
@@ -1912,25 +1912,25 @@ class b0 {
1912
1912
  * @param with6Hourly
1913
1913
  * @param options
1914
1914
  */
1915
- async spotSeasonal(z, p, b, O, W = !1, o = {
1915
+ async spotSeasonal(M, p, b, O, W = !1, o = {
1916
1916
  precision: 6
1917
1917
  }) {
1918
- p = this.toStdLng(p), this.debug && D.info("[%s] spot seasonal params: %j", o.requestId, { lat: z, lng: p, startDate: b, endDate: O, options: o });
1919
- const A = this.timezoneOffset(z, p), q = L.utc(b).utcOffset(A), a = O ? L.utc(O).utcOffset(A) : q.clone().add(1, "month");
1920
- q.subtract(A > 0 ? A : -A, "h"), a.subtract(A > 0 ? A : -A, "h");
1921
- const Y = {
1918
+ p = this.toStdLng(p), this.debug && D.info("[%s] spot seasonal params: %j", o.requestId, { lat: M, lng: p, startDate: b, endDate: O, options: o });
1919
+ const A = this.timezoneOffset(M, p), q = L.utc(b).utcOffset(A), d = O ? L.utc(O).utcOffset(A) : q.clone().add(1, "month");
1920
+ q.subtract(A > 0 ? A : -A, "h"), d.subtract(A > 0 ? A : -A, "h");
1921
+ const n = {
1922
1922
  apikey: this.apikey,
1923
- latitude: z,
1923
+ latitude: M,
1924
1924
  longitude: p,
1925
1925
  cell_selection: "sea",
1926
1926
  wind_speed_unit: "kn",
1927
1927
  timezone: "auto",
1928
1928
  url: this.SEASONAL.OM_URL,
1929
1929
  start_date: q.format("YYYY-MM-DD"),
1930
- end_date: a.format("YYYY-MM-DD"),
1930
+ end_date: d.format("YYYY-MM-DD"),
1931
1931
  daily: this.SEASONAL.WEATHER_VARIABLES.DAILY.split(",")
1932
1932
  };
1933
- return W && (Y.six_hourly = this.SEASONAL.WEATHER_VARIABLES.SIX_HOURLY.split(",")), o.memberLength = 4, { weather: await this.weatherForecast(Y, this.parseSeasonalDailyVariable, o) };
1933
+ return W && (n.six_hourly = this.SEASONAL.WEATHER_VARIABLES.SIX_HOURLY.split(",")), o.memberLength = 4, { weather: await this.weatherForecast(n, this.parseSeasonalDailyVariable, o) };
1934
1934
  }
1935
1935
  /**
1936
1936
  * 气候态数据
@@ -1952,32 +1952,32 @@ class b0 {
1952
1952
  * @param endDate
1953
1953
  * @param options
1954
1954
  */
1955
- async spotClimate(z, p, b, O, W = {
1955
+ async spotClimate(M, p, b, O, W = {
1956
1956
  precision: 6
1957
1957
  }) {
1958
- var e;
1959
- p = this.toStdLng(p), this.debug && D.info("[%s] spot climate params: %j", W.requestId, { lat: z, lng: p, startDate: b, endDate: O, options: W });
1960
- const o = this.timezoneOffset(z, p), A = L.utc(b).utcOffset(o), q = O ? L.utc(O).utcOffset(o) : A.clone().add(1, "day");
1958
+ var a;
1959
+ p = this.toStdLng(p), this.debug && D.info("[%s] spot climate params: %j", W.requestId, { lat: M, lng: p, startDate: b, endDate: O, options: W });
1960
+ const o = this.timezoneOffset(M, p), A = L.utc(b).utcOffset(o), q = O ? L.utc(O).utcOffset(o) : A.clone().add(1, "day");
1961
1961
  q.subtract(o > 0 ? o : -o, "h"), A.subtract(o > 0 ? o : -o, "h");
1962
- const a = {
1962
+ const d = {
1963
1963
  apikey: this.apikey,
1964
- latitude: z,
1964
+ latitude: M,
1965
1965
  longitude: p,
1966
1966
  cell_selection: "sea",
1967
1967
  wind_speed_unit: "kn",
1968
- models: ((e = W.weatherModels) == null ? void 0 : e.split(",")) || "EC_Earth3P_HR",
1968
+ models: ((a = W.weatherModels) == null ? void 0 : a.split(",")) || "EC_Earth3P_HR",
1969
1969
  timezone: "auto",
1970
1970
  url: this.CLIMATE.OM_URL,
1971
1971
  start_date: A.format("YYYY-MM-DD"),
1972
1972
  end_date: q.format("YYYY-MM-DD"),
1973
1973
  daily: this.CLIMATE.WEATHER_VARIABLES.DAILY.split(",")
1974
1974
  };
1975
- return { weather: await this.weatherForecast(a, void 0, W) };
1975
+ return { weather: await this.weatherForecast(d, void 0, W) };
1976
1976
  }
1977
- async update(z = {}) {
1977
+ async update(M = {}) {
1978
1978
  const p = L.unix(this.METEO2_UPDATE.etime), b = this.METEO2_UPDATE.version, O = L();
1979
1979
  if (!b || p.clone().add(10, "minute").isBefore(O)) {
1980
- const W = z.url || "https://meteo3agent.idmwx.com/api/agents/update", o = await fetch(W, {
1980
+ const W = M.url || "https://meteo3agent.idmwx.com/api/agents/update", o = await fetch(W, {
1981
1981
  headers: {
1982
1982
  "Content-Type": "application/json",
1983
1983
  Authorization: "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6ImNsYmY5M3I0YTAwMDE4Ymx0NWJ4emFwNWMiLCJyb2xlIjoyMDQ3LCJpYXQiOjE2NzA1NTM0NzAsImV4cCI6Mzg3ODA3MzQ3MH0.MxTv0yLGarZCtOSCZfJHMqrXNMNN0-OL4gBGKGcYcc8"
@@ -1986,9 +1986,9 @@ class b0 {
1986
1986
  try {
1987
1987
  const A = await o.json();
1988
1988
  if (A.code === 0) {
1989
- const q = A.data, a = w.standardWeatherModels();
1990
- for (const Y of a) {
1991
- const e = w.autoPickSubCategories(Y.alias), t = q.filter((i) => e.includes(i.category)).map((i) => {
1989
+ const q = A.data, d = w.standardWeatherModels();
1990
+ for (const n of d) {
1991
+ const a = w.autoPickSubCategories(n.alias), t = q.filter((i) => a.includes(i.category)).map((i) => {
1992
1992
  var S, r, l, I, P, E;
1993
1993
  const U = L.unix((S = i.meta) == null ? void 0 : S.data_end_time).utc(), s = L.unix((r = i.meta) == null ? void 0 : r.last_run_availability_time).utc(), V = U.diff(s, "days");
1994
1994
  return {
@@ -2004,24 +2004,24 @@ class b0 {
2004
2004
  }
2005
2005
  };
2006
2006
  });
2007
- t.length && (this.METEO2_UPDATE[Y.alias] = t);
2007
+ t.length && (this.METEO2_UPDATE[n.alias] = t);
2008
2008
  }
2009
2009
  this.METEO2_UPDATE.version = b + 1, this.METEO2_UPDATE.etime = O.unix();
2010
2010
  }
2011
2011
  } catch (A) {
2012
- D.error("[%s] update meteo2 error: %s", z.requestId, A);
2012
+ D.error("[%s] update meteo2 error: %s", M.requestId, A);
2013
2013
  }
2014
2014
  }
2015
2015
  return this.METEO2_UPDATE;
2016
2016
  }
2017
- async pickUpdateMeta(z, p = {}) {
2017
+ async pickUpdateMeta(M, p = {}) {
2018
2018
  const b = await this.update(p);
2019
- z = z instanceof Array ? z : [z];
2019
+ M = M instanceof Array ? M : [M];
2020
2020
  const O = [];
2021
2021
  for (const W in b)
2022
2022
  if (b[W] instanceof Array)
2023
2023
  for (const o of b[W])
2024
- z != null && z.includes(o.category) && o.category !== "meteofrance_currents" && O.push(o);
2024
+ M != null && M.includes(o.category) && o.category !== "meteofrance_currents" && O.push(o);
2025
2025
  return O.sort((W, o) => L(W.meta.endTime).unix() - L(o.meta.endTime).unix()), O;
2026
2026
  }
2027
2027
  }
@@ -2032,15 +2032,15 @@ try {
2032
2032
  } finally {
2033
2033
  }
2034
2034
  class M1 {
2035
- constructor(z, p) {
2035
+ constructor(M, p) {
2036
2036
  Q(this, "apikey");
2037
2037
  Q(this, "debug");
2038
- this.apikey = z || "aaf294e6-be27-40b8-82cb-0d7844d2dd74", this.debug = p;
2038
+ this.apikey = M || "aaf294e6-be27-40b8-82cb-0d7844d2dd74", this.debug = p;
2039
2039
  }
2040
- toStdLng(z, p = 6) {
2041
- z > 180 ? (z = z % 360, z = z > 180 ? z - 360 : z) : z < -180 && (z = z % 360, z = z < -180 ? z + 360 : z);
2040
+ toStdLng(M, p = 6) {
2041
+ M > 180 ? (M = M % 360, M = M > 180 ? M - 360 : M) : M < -180 && (M = M % 360, M = M < -180 ? M + 360 : M);
2042
2042
  const b = Math.pow(10, p);
2043
- return Math.round(z * b) / b;
2043
+ return Math.round(M * b) / b;
2044
2044
  }
2045
2045
  /**
2046
2046
  * 潮汐预报数据
@@ -2070,27 +2070,27 @@ class M1 {
2070
2070
  * @param datum
2071
2071
  * @param options
2072
2072
  */
2073
- async tidesForecast(z, p, b = 7, O = "today", W = !0, o = !1, A = !1, q = "CD", a = {}) {
2074
- O = O || "today", b = b || 7, p = this.toStdLng(p), this.debug && S0.info("[%s] spot tides forecast params: %j", a.requestId, { lat: z, lng: p, date: O, extremes: W, heights: o, datums: A, datum: q });
2075
- let Y = `https://www.worldtides.info/api/v3?lat=${z}&lon=${p}&days=${b}&date=${O}&datum=${q}&key=${this.apikey}&localtime`;
2076
- W && (Y = `${Y}&extremes`), o && (Y = `${Y}&heights`), A && (Y = `${Y}&datums`);
2077
- const d = await (await fetch(Y)).json();
2078
- return d.status === 200 ? {
2073
+ async tidesForecast(M, p, b = 7, O = "today", W = !0, o = !1, A = !1, q = "CD", d = {}) {
2074
+ O = O || "today", b = b || 7, p = this.toStdLng(p), this.debug && S0.info("[%s] spot tides forecast params: %j", d.requestId, { lat: M, lng: p, date: O, extremes: W, heights: o, datums: A, datum: q });
2075
+ let n = `https://www.worldtides.info/api/v3?lat=${M}&lon=${p}&days=${b}&date=${O}&datum=${q}&key=${this.apikey}&localtime`;
2076
+ W && (n = `${n}&extremes`), o && (n = `${n}&heights`), A && (n = `${n}&datums`);
2077
+ const Y = await (await fetch(n)).json();
2078
+ return Y.status === 200 ? {
2079
2079
  rqt: {
2080
- lat: z,
2080
+ lat: M,
2081
2081
  lng: p
2082
2082
  },
2083
2083
  rsp: {
2084
- lat: d.responseLat,
2085
- lng: d.responseLon
2084
+ lat: Y.responseLat,
2085
+ lng: Y.responseLon
2086
2086
  },
2087
- atlas: d.atlas,
2088
- datum: d.responseDatum,
2089
- extremes: d.extremes || [],
2090
- heights: d.heights || [],
2091
- stations: d.stations || [],
2092
- datums: d.datums || []
2093
- } : d;
2087
+ atlas: Y.atlas,
2088
+ datum: Y.responseDatum,
2089
+ extremes: Y.extremes || [],
2090
+ heights: Y.heights || [],
2091
+ stations: Y.stations || [],
2092
+ datums: Y.datums || []
2093
+ } : Y;
2094
2094
  }
2095
2095
  }
2096
2096
  let u0;
@@ -2100,8 +2100,8 @@ try {
2100
2100
  } finally {
2101
2101
  }
2102
2102
  class p0 {
2103
- static async parseHistory(z) {
2104
- return z == null ? void 0 : z.map((p) => {
2103
+ static async parseHistory(M) {
2104
+ return M == null ? void 0 : M.map((p) => {
2105
2105
  const b = Number(p.pressure / 100), O = Number(p.lat), W = Number(p.lon), o = Number(p.windSpeed * 3600 / 1852);
2106
2106
  return {
2107
2107
  updated: L.utc(p.time).format(),
@@ -2131,22 +2131,22 @@ class p0 {
2131
2131
  };
2132
2132
  });
2133
2133
  }
2134
- static async parseForecast(z) {
2135
- return z.map((p) => {
2134
+ static async parseForecast(M) {
2135
+ return M.map((p) => {
2136
2136
  var W;
2137
2137
  const b = L.utc(p.reftime).format(), O = {};
2138
2138
  return (W = p.records) == null || W.forEach((o) => {
2139
- const A = L.utc(o.time), q = A.diff(b, "hour"), a = Number(o.pressure / 100), Y = Number(o.lat), e = Number(o.lon), d = Number(o.windSpeed * 3600 / 1852);
2139
+ const A = L.utc(o.time), q = A.diff(b, "hour"), d = Number(o.pressure / 100), n = Number(o.lat), a = Number(o.lon), Y = Number(o.windSpeed * 3600 / 1852);
2140
2140
  O[q] = {
2141
- lat: isNaN(Y) ? null : Y,
2142
- lng: isNaN(e) ? null : e,
2143
- pressure: isNaN(a) ? null : Math.round(a) || null,
2141
+ lat: isNaN(n) ? null : n,
2142
+ lng: isNaN(a) ? null : a,
2143
+ pressure: isNaN(d) ? null : Math.round(d) || null,
2144
2144
  utc: A.format(),
2145
2145
  wind: {
2146
2146
  datetime: A.format(),
2147
- kts: isNaN(d) ? null : Math.round(d) || null,
2148
- bf: w.beaufort(w.kts2ms(d ?? 0)),
2149
- ...N.parseTropicalType(d),
2147
+ kts: isNaN(Y) ? null : Math.round(Y) || null,
2148
+ bf: w.beaufort(w.kts2ms(Y ?? 0)),
2149
+ ...N.parseTropicalType(Y),
2150
2150
  r7: null,
2151
2151
  r7ne: null,
2152
2152
  r7nw: null,
@@ -2175,19 +2175,19 @@ class p0 {
2175
2175
  };
2176
2176
  });
2177
2177
  }
2178
- static async parseTropical(z) {
2178
+ static async parseTropical(M) {
2179
2179
  var o;
2180
- const { id: p, name: b, strength: O } = z, W = {
2180
+ const { id: p, name: b, strength: O } = M, W = {
2181
2181
  id: p == null ? void 0 : p.toLowerCase(),
2182
2182
  name: (o = b == null ? void 0 : b.toLowerCase()) == null ? void 0 : o.replaceAll(/\s/g, "-"),
2183
2183
  strength: O,
2184
- history: await p0.parseHistory(z.history),
2185
- forecasts: await p0.parseForecast(z.forecast)
2184
+ history: await p0.parseHistory(M.history),
2185
+ forecasts: await p0.parseForecast(M.forecast)
2186
2186
  };
2187
2187
  return await N.tropicalMovement(W), W;
2188
2188
  }
2189
2189
  static async realtimeForecast() {
2190
- const z = "https://node.windy.com/tc/v2/storms", p = await $.get(z).json(), b = [];
2190
+ const M = "https://node.windy.com/tc/v2/storms", p = await $.get(M).json(), b = [];
2191
2191
  for (const O of p.storms) {
2192
2192
  const W = `https://node.windy.com/tc/v2/storms/${O.id}`, o = await $.get(W).json(), A = await p0.parseTropical(o);
2193
2193
  b.push(A);
@@ -2196,24 +2196,24 @@ class p0 {
2196
2196
  }
2197
2197
  }
2198
2198
  const J = class J {
2199
- static async parseHistory(z) {
2200
- const p = `https://hifleet.com/hifleetapi/gettyphooninfo2.do?xuhao=${z}`, b = await $.post(p).text(), O = await J.parser.parseStringPromise(b), W = O.typhoon.position instanceof Array ? O.typhoon.position : [O.typhoon.position], o = [];
2199
+ static async parseHistory(M) {
2200
+ const p = `https://hifleet.com/hifleetapi/gettyphooninfo2.do?xuhao=${M}`, b = await $.post(p).text(), O = await J.parser.parseStringPromise(b), W = O.typhoon.position instanceof Array ? O.typhoon.position : [O.typhoon.position], o = [];
2201
2201
  for (const A of W) {
2202
- const q = L(A.updatetime).utcOffset(8).utc().format(), a = Number(A.lat), Y = Number(A.lon), e = Number(A.pressure), d = Number(A.windspeed * 3600 / 1852), t = N.parseWindCircle(A.c7quad1 / 1.852), i = N.parseWindCircle(A.c7quad2 / 1.852), U = N.parseWindCircle(A.c7quad3 / 1.852), s = N.parseWindCircle(A.c7quad4 / 1.852), V = N.parseWindCircle(A.c10quad1 / 1.852), S = N.parseWindCircle(A.c10quad2 / 1.852), r = N.parseWindCircle(A.c10quad3 / 1.852), l = N.parseWindCircle(A.c10quad4 / 1.852), I = N.parseWindCircle(A.c12quad1 / 1.852), P = N.parseWindCircle(A.c12quad2 / 1.852), E = N.parseWindCircle(A.c12quad3 / 1.852), _ = N.parseWindCircle(A.c12quad4 / 1.852), { r7: v, r10: K, r12: k } = N.estimateWindRadii(d, a), O0 = {
2202
+ const q = L(A.updatetime).utcOffset(8).utc().format(), d = Number(A.lat), n = Number(A.lon), a = Number(A.pressure), Y = Number(A.windspeed * 3600 / 1852), t = N.parseWindCircle(A.c7quad1 / 1.852), i = N.parseWindCircle(A.c7quad2 / 1.852), U = N.parseWindCircle(A.c7quad3 / 1.852), s = N.parseWindCircle(A.c7quad4 / 1.852), V = N.parseWindCircle(A.c10quad1 / 1.852), S = N.parseWindCircle(A.c10quad2 / 1.852), r = N.parseWindCircle(A.c10quad3 / 1.852), l = N.parseWindCircle(A.c10quad4 / 1.852), I = N.parseWindCircle(A.c12quad1 / 1.852), P = N.parseWindCircle(A.c12quad2 / 1.852), E = N.parseWindCircle(A.c12quad3 / 1.852), C = N.parseWindCircle(A.c12quad4 / 1.852), { r7: v, r10: g, r12: k } = N.estimateWindRadii(Y, d), O0 = {
2203
2203
  updated: q,
2204
- lat: isNaN(a) ? null : a,
2205
- lng: isNaN(Y) ? null : Y,
2206
- pressure: isNaN(e) ? null : Math.round(e),
2207
- kts: isNaN(d) ? null : Math.round(d) || null,
2208
- bf: w.beaufort(w.kts2ms(d ?? 0)),
2209
- ...N.parseTropicalType(d),
2204
+ lat: isNaN(d) ? null : d,
2205
+ lng: isNaN(n) ? null : n,
2206
+ pressure: isNaN(a) ? null : Math.round(a),
2207
+ kts: isNaN(Y) ? null : Math.round(Y) || null,
2208
+ bf: w.beaufort(w.kts2ms(Y ?? 0)),
2209
+ ...N.parseTropicalType(Y),
2210
2210
  wind: {
2211
2211
  r7: v,
2212
2212
  r7ne: t,
2213
2213
  r7nw: i,
2214
2214
  r7sw: U,
2215
2215
  r7se: s,
2216
- r10: K,
2216
+ r10: g,
2217
2217
  r10ne: V,
2218
2218
  r10nw: S,
2219
2219
  r10sw: r,
@@ -2222,26 +2222,26 @@ const J = class J {
2222
2222
  r12ne: I,
2223
2223
  r12nw: P,
2224
2224
  r12sw: E,
2225
- r12se: _
2225
+ r12se: C
2226
2226
  }
2227
2227
  };
2228
2228
  o.push(O0);
2229
2229
  }
2230
2230
  return o.sort((A, q) => L(q.updated).unix() - L(A.updated).unix()), o;
2231
2231
  }
2232
- static async parseForecast(z, p) {
2233
- const b = `https://hifleet.com/hifleetapi/gettyphooforecast.do?xuhao=${z}`, O = await $.post(b).text(), W = await J.parser.parseStringPromise(O), o = W.list.forecast instanceof Array ? W.list.forecast : [W.list.forecast], A = [];
2232
+ static async parseForecast(M, p) {
2233
+ const b = `https://hifleet.com/hifleetapi/gettyphooforecast.do?xuhao=${M}`, O = await $.post(b).text(), W = await J.parser.parseStringPromise(O), o = W.list.forecast instanceof Array ? W.list.forecast : [W.list.forecast], A = [];
2234
2234
  for (const q of o)
2235
- if (q.xuhao === z) {
2236
- const a = q.positions.forecastposition instanceof Array ? q.positions.forecastposition : [q.positions.forecastposition];
2237
- if (a.length) {
2238
- p = p || L(a.at(0).forecasttime).utcOffset(8).utc();
2239
- const Y = {};
2240
- for (const d of a) {
2241
- const t = L(d.forecasttime).utcOffset(8).utc(), i = t.diff(p, "hours");
2235
+ if (q.xuhao === M) {
2236
+ const d = q.positions.forecastposition instanceof Array ? q.positions.forecastposition : [q.positions.forecastposition];
2237
+ if (d.length) {
2238
+ p = p || L(d.at(0).forecasttime).utcOffset(8).utc();
2239
+ const n = {};
2240
+ for (const Y of d) {
2241
+ const t = L(Y.forecasttime).utcOffset(8).utc(), i = t.diff(p, "hours");
2242
2242
  if (i) {
2243
- const U = Number(d.forelat), s = Number(d.forelon), V = Number(d.forepressure), S = Number(d.forespeed * 3600 / 1852);
2244
- Y[i] = {
2243
+ const U = Number(Y.forelat), s = Number(Y.forelon), V = Number(Y.forepressure), S = Number(Y.forespeed * 3600 / 1852);
2244
+ n[i] = {
2245
2245
  lat: isNaN(U) ? null : U,
2246
2246
  lng: isNaN(s) ? null : s,
2247
2247
  pressure: V ? Math.round(V) : null,
@@ -2273,29 +2273,29 @@ const J = class J {
2273
2273
  };
2274
2274
  }
2275
2275
  }
2276
- const e = {
2276
+ const a = {
2277
2277
  date: p.utc().format(),
2278
2278
  model: N.parseTropicalModel(q.country).toLowerCase(),
2279
- hours: Y
2279
+ hours: n
2280
2280
  };
2281
- A.push(e);
2281
+ A.push(a);
2282
2282
  }
2283
2283
  }
2284
2284
  return A;
2285
2285
  }
2286
- static async parseTropical(z) {
2286
+ static async parseTropical(M) {
2287
2287
  var o, A, q;
2288
- const p = await J.parseHistory(z.xuhao), b = (o = p.at(0)) == null ? void 0 : o.updated, O = await J.parseForecast(z.xuhao, b ? L(b) : void 0), W = {
2289
- id: (A = z.enname) == null ? void 0 : A.toLowerCase(),
2290
- name: (q = z.enname) == null ? void 0 : q.toLowerCase(),
2291
- cnName: z.name,
2288
+ const p = await J.parseHistory(M.xuhao), b = (o = p.at(0)) == null ? void 0 : o.updated, O = await J.parseForecast(M.xuhao, b ? L(b) : void 0), W = {
2289
+ id: (A = M.enname) == null ? void 0 : A.toLowerCase(),
2290
+ name: (q = M.enname) == null ? void 0 : q.toLowerCase(),
2291
+ cnName: M.name,
2292
2292
  history: p,
2293
2293
  forecasts: O
2294
2294
  };
2295
2295
  return await N.tropicalMovement(W), W;
2296
2296
  }
2297
2297
  static async realtimeForecast() {
2298
- const z = "https://hifleet.com/hifleetapi/getCurrentTyphoon2.do", p = await $.post(z).text(), b = await J.parser.parseStringPromise(p), O = [], W = b.typhoon.position instanceof Array ? b.typhoon.position : [b.typhoon.position];
2298
+ const M = "https://hifleet.com/hifleetapi/getCurrentTyphoon2.do", p = await $.post(M).text(), b = await J.parser.parseStringPromise(p), O = [], W = b.typhoon.position instanceof Array ? b.typhoon.position : [b.typhoon.position];
2299
2299
  for (const o of W)
2300
2300
  if (o) {
2301
2301
  const A = await J.parseTropical(o);
@@ -2306,54 +2306,54 @@ const J = class J {
2306
2306
  };
2307
2307
  Q(J, "parser", Z0.Parser({ explicitArray: !1, mergeAttrs: !0, trim: !0 }));
2308
2308
  let q0 = J;
2309
- var e0 = /* @__PURE__ */ ((M) => (M.CMA = "CMA", M.CNTW = "CNTW", M.CNHK = "CNHK", M.JMA = "JMA", M.KMA = "KMA", M.ECMWF = "ECMWF", M.NOAA_AT = "NOAA-AT", M.NOAA_CP = "NOAA-CP", M.NOAA_EP = "NOAA-EP", M.UKM = "UKM", M.IMD = "IMD", M.GFS = "GFS", M.BOM_ACCESS = "BOM-ACCESS", M.BOM_BULLETIN_EAST = "BOM-BULLETIN-EAST", M.BOM_BULLETIN_NORTH = "BOM-BULLETIN-NORTH", M.BOM_BULLETIN_WEST = "BOM-BULLETIN-WEST", M.OTHER = "OTHER", M))(e0 || {});
2309
+ var e0 = /* @__PURE__ */ ((z) => (z.CMA = "CMA", z.CNTW = "CNTW", z.CNHK = "CNHK", z.JMA = "JMA", z.KMA = "KMA", z.ECMWF = "ECMWF", z.NOAA_AT = "NOAA-AT", z.NOAA_CP = "NOAA-CP", z.NOAA_EP = "NOAA-EP", z.UKM = "UKM", z.IMD = "IMD", z.GFS = "GFS", z.BOM_ACCESS = "BOM-ACCESS", z.BOM_BULLETIN_EAST = "BOM-BULLETIN-EAST", z.BOM_BULLETIN_NORTH = "BOM-BULLETIN-NORTH", z.BOM_BULLETIN_WEST = "BOM-BULLETIN-WEST", z.OTHER = "OTHER", z))(e0 || {});
2310
2310
  class N {
2311
2311
  /**
2312
2312
  * 台风数据
2313
2313
  * @param vendor
2314
2314
  * @param options
2315
2315
  */
2316
- static async realtimeForecast(z = "", p = {}) {
2317
- return u0.info("[%s] try to fetch realtime tropicals forecast from %s", p.requestId, z), z === "windy" ? p0.realtimeForecast() : z === "hifleet" ? q0.realtimeForecast() : N.mergeTropicals(!0, p);
2316
+ static async realtimeForecast(M = "", p = {}) {
2317
+ return u0.info("[%s] try to fetch realtime tropicals forecast from %s", p.requestId, M), M === "windy" ? p0.realtimeForecast() : M === "hifleet" ? q0.realtimeForecast() : N.mergeTropicals(!0, p);
2318
2318
  }
2319
- static async sortTropical(z) {
2319
+ static async sortTropical(M) {
2320
2320
  var b;
2321
2321
  const p = Object.values(e0);
2322
- return (b = z.forecasts) == null || b.sort((O, W) => {
2323
- var q, a;
2324
- const o = p.indexOf((q = O.model) == null ? void 0 : q.toUpperCase()), A = p.indexOf((a = W.model) == null ? void 0 : a.toUpperCase());
2322
+ return (b = M.forecasts) == null || b.sort((O, W) => {
2323
+ var q, d;
2324
+ const o = p.indexOf((q = O.model) == null ? void 0 : q.toUpperCase()), A = p.indexOf((d = W.model) == null ? void 0 : d.toUpperCase());
2325
2325
  return (o === -1 ? 999 : o) - (A === -1 ? 999 : A);
2326
- }), z;
2326
+ }), M;
2327
2327
  }
2328
- static async mergeTropicals(z = !0, p = {}) {
2328
+ static async mergeTropicals(M = !0, p = {}) {
2329
2329
  var W, o;
2330
- const b = await p0.realtimeForecast(), O = z ? await q0.realtimeForecast() : [];
2330
+ const b = await p0.realtimeForecast(), O = M ? await q0.realtimeForecast() : [];
2331
2331
  for (const A of b) {
2332
- const q = O.find((Y) => {
2333
- var e, d;
2334
- return ((e = Y.name) == null ? void 0 : e.toLowerCase()) === ((d = A.name) == null ? void 0 : d.toLowerCase());
2332
+ const q = O.find((n) => {
2333
+ var a, Y;
2334
+ return ((a = n.name) == null ? void 0 : a.toLowerCase()) === ((Y = A.name) == null ? void 0 : Y.toLowerCase());
2335
2335
  });
2336
2336
  if (q) {
2337
- A.cnName = q.cnName, (W = q.history) != null && W.length && (A.history = q.history), A.history.sort((Y, e) => L(e.updated).valueOf() - L(Y.updated).valueOf());
2338
- for (const Y of q.forecasts)
2339
- ["CMA", "JMA", "CNTW", "CNHK", "KMA"].includes((o = Y.model) == null ? void 0 : o.toUpperCase()) && !A.forecasts.find((e) => e.model.toLowerCase() === Y.model.toLowerCase()) && A.forecasts.push(Y);
2337
+ A.cnName = q.cnName, (W = q.history) != null && W.length && (A.history = q.history), A.history.sort((n, a) => L(a.updated).valueOf() - L(n.updated).valueOf());
2338
+ for (const n of q.forecasts)
2339
+ ["CMA", "JMA", "CNTW", "CNHK", "KMA"].includes((o = n.model) == null ? void 0 : o.toUpperCase()) && !A.forecasts.find((a) => a.model.toLowerCase() === n.model.toLowerCase()) && A.forecasts.push(n);
2340
2340
  }
2341
- A.history = A.history.reduce((Y, e) => (Y.find((d) => d.updated === e.updated) || Y.push(e), Y), []);
2342
- const a = A.history[0];
2343
- a && A.forecasts.forEach((Y) => {
2344
- Y.date = a.updated;
2345
- const e = L(a.updated), d = {};
2346
- for (const t in Y.hours) {
2347
- const i = Y.hours[t], U = L(i.utc).diff(e, "h");
2348
- U > 0 && (d[U] = i);
2341
+ A.history = A.history.reduce((n, a) => (n.find((Y) => Y.updated === a.updated) || n.push(a), n), []);
2342
+ const d = A.history[0];
2343
+ d && A.forecasts.forEach((n) => {
2344
+ n.date = d.updated;
2345
+ const a = L(d.updated), Y = {};
2346
+ for (const t in n.hours) {
2347
+ const i = n.hours[t], U = L(i.utc).diff(a, "h");
2348
+ U > 0 && (Y[U] = i);
2349
2349
  }
2350
- Y.hours = d;
2350
+ n.hours = Y;
2351
2351
  }), await N.tropicalMovement(A);
2352
2352
  }
2353
2353
  for (const A of O)
2354
2354
  b.every((q) => {
2355
- var a, Y;
2356
- return ((a = q.name) == null ? void 0 : a.toLowerCase()) !== ((Y = A.name) == null ? void 0 : Y.toLowerCase());
2355
+ var d, n;
2356
+ return ((d = q.name) == null ? void 0 : d.toLowerCase()) !== ((n = A.name) == null ? void 0 : n.toLowerCase());
2357
2357
  }) && b.push(A);
2358
2358
  return b;
2359
2359
  }
@@ -2361,23 +2361,23 @@ class N {
2361
2361
  * 获取热带气旋的移动信息
2362
2362
  * @param tropical
2363
2363
  */
2364
- static async tropicalMovement(z) {
2365
- await N.sortTropical(z);
2364
+ static async tropicalMovement(M) {
2365
+ await N.sortTropical(M);
2366
2366
  let p = null;
2367
- z.forecasts.forEach((O) => {
2367
+ M.forecasts.forEach((O) => {
2368
2368
  const W = O.hours, o = Object.keys(W);
2369
2369
  for (let A = 0; A < o.length - 1; A++) {
2370
2370
  const q = W[o[A]];
2371
2371
  p = p || q;
2372
- const a = W[o[A + 1]];
2373
- q.movement = N.calculateMovement(q, a);
2374
- const Y = N.supplementWindRadii(q);
2375
- q.wind = { ...q.wind || {}, ...Y };
2372
+ const d = W[o[A + 1]];
2373
+ q.movement = N.calculateMovement(q, d);
2374
+ const n = N.supplementWindRadii(q);
2375
+ q.wind = { ...q.wind || {}, ...n };
2376
2376
  }
2377
2377
  });
2378
2378
  let b = null;
2379
- for (let O = 0; O < z.history.length - 1; O++) {
2380
- const W = z.history[O + 1], o = z.history[O];
2379
+ for (let O = 0; O < M.history.length - 1; O++) {
2380
+ const W = M.history[O + 1], o = M.history[O];
2381
2381
  b = b || o, W.movement = N.calculateMovement(W, o);
2382
2382
  const A = N.supplementWindRadii(W);
2383
2383
  W.wind = { ...W.wind || {}, ...A };
@@ -2387,13 +2387,13 @@ class N {
2387
2387
  const O = N.supplementWindRadii(b);
2388
2388
  b.wind = { ...b.wind || {}, ...O };
2389
2389
  }
2390
- return z;
2390
+ return M;
2391
2391
  }
2392
- static calculateMovement(z, p) {
2393
- const b = T0.calculateDistance(z, p), O = L(p.utc || p.updated).diff(z.utc || z.updated, "h", !0);
2392
+ static calculateMovement(M, p) {
2393
+ const b = T0.calculateDistance(M, p), O = L(p.utc || p.updated).diff(M.utc || M.updated, "h", !0);
2394
2394
  return {
2395
2395
  kts: Math.round(b / O * 100) / 100,
2396
- deg: T0.calculateBearing(z, p, !0, 0)
2396
+ deg: T0.calculateBearing(M, p, !0, 0)
2397
2397
  };
2398
2398
  }
2399
2399
  /**
@@ -2401,8 +2401,8 @@ class N {
2401
2401
  * @param ms 最大风速(m/s)
2402
2402
  * @param lat 纬度
2403
2403
  */
2404
- static estimateRMW(z, p) {
2405
- const b = Math.abs(p || 25), O = 51.6 * Math.exp(-0.0223 * z + 0.0281 * b);
2404
+ static estimateRMW(M, p) {
2405
+ const b = Math.abs(p || 25), O = 51.6 * Math.exp(-0.0223 * M + 0.0281 * b);
2406
2406
  return Math.max(10, Math.min(150, O));
2407
2407
  }
2408
2408
  /**
@@ -2411,8 +2411,8 @@ class N {
2411
2411
  * @param rmw 最大风速半径(km)
2412
2412
  * @param lat 中心纬度
2413
2413
  */
2414
- static estimateHollandB(z, p, b) {
2415
- return 1.0036 + 0.0173 * z - 0.0312 * Math.log(p) + 87e-4 * b;
2414
+ static estimateHollandB(M, p, b) {
2415
+ return 1.0036 + 0.0173 * M - 0.0312 * Math.log(p) + 87e-4 * b;
2416
2416
  }
2417
2417
  /**
2418
2418
  * 推算风圈半径
@@ -2421,13 +2421,13 @@ class N {
2421
2421
  * @param rmw 最大风速半径(km)
2422
2422
  * @param b Holland形状参数B
2423
2423
  */
2424
- static findWindRadius(z, p, b, O) {
2425
- if (z >= p)
2424
+ static findWindRadius(M, p, b, O) {
2425
+ if (M >= p)
2426
2426
  return 0;
2427
2427
  let W = b, o = b * 10;
2428
2428
  for (; o - W > 0.1; ) {
2429
- const A = (W + o) / 2, q = b / A, a = Math.pow(q, O) * Math.exp(1 - Math.pow(q, O));
2430
- p * Math.sqrt(a) > z ? W = A : o = A;
2429
+ const A = (W + o) / 2, q = b / A, d = Math.pow(q, O) * Math.exp(1 - Math.pow(q, O));
2430
+ p * Math.sqrt(d) > M ? W = A : o = A;
2431
2431
  }
2432
2432
  return w.kmh2kts(W + o);
2433
2433
  }
@@ -2437,8 +2437,8 @@ class N {
2437
2437
  * @param lat 纬度
2438
2438
  * @returns 风圈半径对象
2439
2439
  */
2440
- static estimateWindRadii(z, p) {
2441
- const b = w.kts2ms(z), O = N.estimateRMW(b, p), W = N.estimateHollandB(b, O, p), o = N.findWindRadius(17.2, b, O, W), A = N.findWindRadius(28.5, b, O, W), q = N.findWindRadius(37, b, O, W);
2440
+ static estimateWindRadii(M, p) {
2441
+ const b = w.kts2ms(M), O = N.estimateRMW(b, p), W = N.estimateHollandB(b, O, p), o = N.findWindRadius(17.2, b, O, W), A = N.findWindRadius(28.5, b, O, W), q = N.findWindRadius(37, b, O, W);
2442
2442
  return {
2443
2443
  r7: o ? Math.round(o) : null,
2444
2444
  r10: A ? Math.round(A) : null,
@@ -2453,36 +2453,36 @@ class N {
2453
2453
  * @param hemisphere N 北半球, N 南半球
2454
2454
  * @returns 四象限风圈半径
2455
2455
  */
2456
- static estimateAsymmetricRadii(z, p = 0, b = 0, O = "N") {
2457
- if (!z)
2456
+ static estimateAsymmetricRadii(M, p = 0, b = 0, O = "N") {
2457
+ if (!M)
2458
2458
  return { ne: null, nw: null, se: null, sw: null };
2459
2459
  if (p < 9)
2460
- return { ne: z, nw: z, se: z, sw: z };
2460
+ return { ne: M, nw: M, se: M, sw: M };
2461
2461
  const o = 0.15 * Math.min(p / (20 / 1.852), 1), A = {
2462
2462
  ne: (45 - b + 360) % 360,
2463
2463
  nw: (315 - b + 360) % 360,
2464
2464
  se: (135 - b + 360) % 360,
2465
2465
  sw: (225 - b + 360) % 360
2466
- }, q = (a) => {
2467
- const Y = a > 180 ? a - 360 : a, e = Math.cos(Y * Math.PI / 180);
2468
- return 1 - o * e;
2466
+ }, q = (d) => {
2467
+ const n = d > 180 ? d - 360 : d, a = Math.cos(n * Math.PI / 180);
2468
+ return 1 - o * a;
2469
2469
  };
2470
2470
  return {
2471
- ne: Math.round(z * q(A.ne)),
2472
- nw: Math.round(z * q(A.nw)),
2473
- se: Math.round(z * q(A.se)),
2474
- sw: Math.round(z * q(A.sw))
2471
+ ne: Math.round(M * q(A.ne)),
2472
+ nw: Math.round(M * q(A.nw)),
2473
+ se: Math.round(M * q(A.se)),
2474
+ sw: Math.round(M * q(A.sw))
2475
2475
  };
2476
2476
  }
2477
2477
  /**
2478
2478
  * 为预报数据补充风圈半径
2479
2479
  * @param position 预报点数据
2480
2480
  */
2481
- static supplementWindRadii(z) {
2482
- const { wind: p, lat: b, movement: O } = z;
2481
+ static supplementWindRadii(M) {
2482
+ const { wind: p, lat: b, movement: O } = M;
2483
2483
  if (p.r7) {
2484
- for (const a of Object.keys(p))
2485
- /^r[7,10,12]/.test(a) && (isNaN(Number(p[a])) || p[a] < 0) && (p[a] = null);
2484
+ for (const d of Object.keys(p))
2485
+ /^r[7,10,12]/.test(d) && (isNaN(Number(p[d])) || p[d] < 0) && (p[d] = null);
2486
2486
  return p;
2487
2487
  }
2488
2488
  const W = p.kts;
@@ -2505,14 +2505,14 @@ class N {
2505
2505
  r12sw: null
2506
2506
  };
2507
2507
  const o = N.estimateWindRadii(W, b), A = {};
2508
- return ["r7", "r10", "r12"].forEach((a) => {
2509
- const Y = o[a];
2510
- if (Y) {
2511
- A[a] = Y;
2512
- const e = N.estimateAsymmetricRadii(Y, (O == null ? void 0 : O.kts) || 0, (O == null ? void 0 : O.deg) || 0, b > 0 ? "N" : "S");
2513
- A[`${a}ne`] = e.ne, A[`${a}nw`] = e.nw, A[`${a}se`] = e.se, A[`${a}sw`] = e.sw;
2508
+ return ["r7", "r10", "r12"].forEach((d) => {
2509
+ const n = o[d];
2510
+ if (n) {
2511
+ A[d] = n;
2512
+ const a = N.estimateAsymmetricRadii(n, (O == null ? void 0 : O.kts) || 0, (O == null ? void 0 : O.deg) || 0, b > 0 ? "N" : "S");
2513
+ A[`${d}ne`] = a.ne, A[`${d}nw`] = a.nw, A[`${d}se`] = a.se, A[`${d}sw`] = a.sw;
2514
2514
  } else
2515
- A[a] = null, A[`${a}ne`] = null, A[`${a}nw`] = null, A[`${a}se`] = null, A[`${a}sw`] = null;
2515
+ A[d] = null, A[`${d}ne`] = null, A[`${d}nw`] = null, A[`${d}se`] = null, A[`${d}sw`] = null;
2516
2516
  }), A;
2517
2517
  }
2518
2518
  /**
@@ -2522,17 +2522,17 @@ class N {
2522
2522
  * 1 热带风暴 Tropical Storm
2523
2523
  * 2 强热带风暴 Severe Tropical Storm
2524
2524
  */
2525
- static parseTropicalType(z) {
2526
- return !z || z < 32 ? { type: "Tropical Depression", en: "TD", cn: "热带低压", i18n: "tropical.td" } : z < 47 ? { type: "Tropical Storm", en: "TS", cn: "热带风暴", i18n: "tropical.ts" } : z < 63 ? { type: "Severe Tropical Storm", en: "STS", cn: "强热带风暴", i18n: "tropical.sts" } : z < 80 ? { type: "Typhoon", en: "TY", cn: "台风", i18n: "tropical.ty" } : z < 94 ? { type: "Strong Typhoon", en: "STY", cn: "强台风", i18n: "tropical.sty" } : { type: "Super Typhoon", en: "Super TY", cn: "超强台风", i18n: "tropical.superTy" };
2525
+ static parseTropicalType(M) {
2526
+ return !M || M < 32 ? { type: "Tropical Depression", en: "TD", cn: "热带低压", i18n: "tropical.td" } : M < 47 ? { type: "Tropical Storm", en: "TS", cn: "热带风暴", i18n: "tropical.ts" } : M < 63 ? { type: "Severe Tropical Storm", en: "STS", cn: "强热带风暴", i18n: "tropical.sts" } : M < 80 ? { type: "Typhoon", en: "TY", cn: "台风", i18n: "tropical.ty" } : M < 94 ? { type: "Strong Typhoon", en: "STY", cn: "强台风", i18n: "tropical.sty" } : { type: "Super Typhoon", en: "Super TY", cn: "超强台风", i18n: "tropical.superTy" };
2527
2527
  }
2528
2528
  /**
2529
2529
  * @param name
2530
2530
  */
2531
- static parseTropicalModel(z) {
2532
- return ["中央气象台", "中国"].includes(z) ? "CMA" : z === "日本" ? "JMA" : z === "美国" ? "GFS" : z === "欧洲" ? "ECMWF" : z === "中国台湾" ? "CNTW" : z === "中国香港" ? "CNHK" : z === "韩国" ? "KMA" : "OTHER";
2531
+ static parseTropicalModel(M) {
2532
+ return ["中央气象台", "中国"].includes(M) ? "CMA" : M === "日本" ? "JMA" : M === "美国" ? "GFS" : M === "欧洲" ? "ECMWF" : M === "中国台湾" ? "CNTW" : M === "中国香港" ? "CNHK" : M === "韩国" ? "KMA" : "OTHER";
2533
2533
  }
2534
- static parseWindCircle(z) {
2535
- return z = Number(z), isNaN(z) || z <= 0 || Math.abs(z) > 999 ? null : Math.round(z);
2534
+ static parseWindCircle(M) {
2535
+ return M = Number(M), isNaN(M) || M <= 0 || Math.abs(M) > 999 ? null : Math.round(M);
2536
2536
  }
2537
2537
  }
2538
2538
  export {