Spaces:
Running
Running
Ron Au
commited on
Commit
·
360c090
1
Parent(s):
5a112e6
fix(typing): Convert to Python <3.9 types 🥲
Browse files- Because package `youtokentome` only works on 3.8
- README.md +1 -1
- app.py +4 -4
- modules/dataset.py +3 -3
- modules/details.py +19 -19
README.md
CHANGED
@@ -4,7 +4,7 @@ emoji: 🧬
|
|
4 |
colorFrom: gray
|
5 |
colorTo: green
|
6 |
sdk: gradio
|
7 |
-
python_version: 3.8.
|
8 |
app_file: start.py
|
9 |
models: [minimaxir/ai-generated-pokemon-rudalle]
|
10 |
pinned: true
|
|
|
4 |
colorFrom: gray
|
5 |
colorTo: green
|
6 |
sdk: gradio
|
7 |
+
python_version: 3.8.12
|
8 |
app_file: start.py
|
9 |
models: [minimaxir/ai-generated-pokemon-rudalle]
|
10 |
pinned: true
|
app.py
CHANGED
@@ -1,4 +1,4 @@
|
|
1 |
-
from typing import Union
|
2 |
from time import gmtime, strftime
|
3 |
|
4 |
from fastapi import FastAPI
|
@@ -22,7 +22,7 @@ def index() -> FileResponse:
|
|
22 |
|
23 |
|
24 |
@app.get('/new_card')
|
25 |
-
def new_card() ->
|
26 |
card_logs.append(strftime('%Y-%m-%dT%H:%M:%SZ', gmtime()))
|
27 |
|
28 |
details: Details = rand_details()
|
@@ -34,10 +34,10 @@ def new_card() -> dict[str, Union[Details, str]]:
|
|
34 |
|
35 |
|
36 |
@app.get('/stats')
|
37 |
-
def stats() ->
|
38 |
return get_stats() | {"cards_served": len(card_logs)}
|
39 |
|
40 |
|
41 |
@app.get('/logs')
|
42 |
-
def logs() ->
|
43 |
return card_logs
|
|
|
1 |
+
from typing import Dict, List, Union
|
2 |
from time import gmtime, strftime
|
3 |
|
4 |
from fastapi import FastAPI
|
|
|
22 |
|
23 |
|
24 |
@app.get('/new_card')
|
25 |
+
def new_card() -> Dict[str, Union[Details, str]]:
|
26 |
card_logs.append(strftime('%Y-%m-%dT%H:%M:%SZ', gmtime()))
|
27 |
|
28 |
details: Details = rand_details()
|
|
|
34 |
|
35 |
|
36 |
@app.get('/stats')
|
37 |
+
def stats() -> Dict[str, Union[int, object]]:
|
38 |
return get_stats() | {"cards_served": len(card_logs)}
|
39 |
|
40 |
|
41 |
@app.get('/logs')
|
42 |
+
def logs() -> List[str]:
|
43 |
return card_logs
|
modules/dataset.py
CHANGED
@@ -1,6 +1,6 @@
|
|
1 |
import os
|
2 |
from random import choices, randint
|
3 |
-
from typing import cast, Optional, TypedDict
|
4 |
import h5py
|
5 |
|
6 |
|
@@ -12,7 +12,7 @@ h5_file: str = os.path.join(datasets_dir, datasets_file)
|
|
12 |
class Stats(TypedDict):
|
13 |
size_total: int
|
14 |
size_mb: float
|
15 |
-
size_counts:
|
16 |
|
17 |
|
18 |
def get_stats(h5_file: str = h5_file) -> Stats:
|
@@ -24,7 +24,7 @@ def get_stats(h5_file: str = h5_file) -> Stats:
|
|
24 |
}
|
25 |
|
26 |
|
27 |
-
energy_types:
|
28 |
'fire', 'grass', 'lightning', 'metal', 'psychic', 'water']
|
29 |
|
30 |
|
|
|
1 |
import os
|
2 |
from random import choices, randint
|
3 |
+
from typing import cast, Dict, List, Optional, TypedDict
|
4 |
import h5py
|
5 |
|
6 |
|
|
|
12 |
class Stats(TypedDict):
|
13 |
size_total: int
|
14 |
size_mb: float
|
15 |
+
size_counts: Dict[str, int]
|
16 |
|
17 |
|
18 |
def get_stats(h5_file: str = h5_file) -> Stats:
|
|
|
24 |
}
|
25 |
|
26 |
|
27 |
+
energy_types: List[str] = ['colorless', 'darkness', 'dragon', 'fairy', 'fighting',
|
28 |
'fire', 'grass', 'lightning', 'metal', 'psychic', 'water']
|
29 |
|
30 |
|
modules/details.py
CHANGED
@@ -1,20 +1,20 @@
|
|
1 |
import random
|
2 |
import json
|
3 |
-
from typing import cast, Optional, TypedDict, Union
|
4 |
|
5 |
|
6 |
class Attack(TypedDict):
|
7 |
name: str
|
8 |
-
cost:
|
9 |
convertedEnergyCost: int
|
10 |
damage: str
|
11 |
text: str
|
12 |
|
13 |
|
14 |
-
ListCollection =
|
15 |
|
16 |
|
17 |
-
def load_lists(list_names:
|
18 |
lists = {}
|
19 |
|
20 |
for name in list_names:
|
@@ -27,16 +27,16 @@ def load_lists(list_names: list[str], base_dir: str = "lists") -> ListCollection
|
|
27 |
def rand_hp() -> int:
|
28 |
# Weights from https://bulbapedia.bulbagarden.net/wiki/HP_(TCG)
|
29 |
|
30 |
-
hp_range:
|
31 |
|
32 |
-
weights:
|
33 |
131, 132, 132, 56, 66, 97, 74, 23, 24, 25, 7, 15, 6, 0, 12, 18, 35, 18, 3]
|
34 |
|
35 |
return random.choices(hp_range, weights)[0]
|
36 |
|
37 |
|
38 |
def rand_energy(can_be_none: bool = False) -> Union[str, None]:
|
39 |
-
types:
|
40 |
'fire', 'grass', 'lightning', 'metal', 'psychic', 'water']
|
41 |
|
42 |
if can_be_none:
|
@@ -51,19 +51,19 @@ def rand_name(energy_type: str = cast(str, rand_energy())) -> str:
|
|
51 |
return cast(str, random.choices(lists[energy_type])[0])
|
52 |
|
53 |
|
54 |
-
def rand_species(species:
|
55 |
random_species: str = random.choices(species)[0]
|
56 |
|
57 |
return f'{random_species.capitalize()}'
|
58 |
|
59 |
|
60 |
-
def rand_length() ->
|
61 |
# Weights from https://bulbapedia.bulbagarden.net/wiki/List_of_Pok%C3%A9mon_by_height
|
62 |
|
63 |
-
feet_ranges:
|
64 |
17, 18, 19, 20, 21, 22, 23, 24, 26, 28, 30, 32, 34, 35, 47, 65, 328]
|
65 |
|
66 |
-
weights:
|
67 |
4, 3, 2, 2, 2, 1, 2, 3, 1, 2, 1, 1, 1, 2, 1, 1, 2, 1, 1, 1]
|
68 |
|
69 |
return {
|
@@ -75,7 +75,7 @@ def rand_length() -> dict[str, int]:
|
|
75 |
def rand_weight() -> str:
|
76 |
# Weights from https://bulbapedia.bulbagarden.net/wiki/List_of_Pok%C3%A9mon_by_weight
|
77 |
|
78 |
-
weight_ranges:
|
79 |
{"start": 1, "end": 22},
|
80 |
{"start": 22, "end": 44},
|
81 |
{"start": 44, "end": 55},
|
@@ -94,7 +94,7 @@ def rand_weight() -> str:
|
|
94 |
{"start": 903, "end": 2204}]
|
95 |
|
96 |
# 'weights' as in statistical weightings, not physical mass
|
97 |
-
weights:
|
98 |
|
99 |
start: int
|
100 |
end: int
|
@@ -106,7 +106,7 @@ def rand_weight() -> str:
|
|
106 |
|
107 |
|
108 |
def rand_attack(
|
109 |
-
attacks:
|
110 |
name: str, energy_type: Optional[str],
|
111 |
colorless_only_allowed: bool = False) -> Attack:
|
112 |
random_attack: Attack = random.choices(attacks)[0]
|
@@ -126,7 +126,7 @@ def rand_attack(
|
|
126 |
return random_attack
|
127 |
|
128 |
|
129 |
-
def rand_attacks(attacks:
|
130 |
attack1: Attack = rand_attack(attacks, name, energy_type)
|
131 |
|
132 |
if n > 1:
|
@@ -158,9 +158,9 @@ class Details(TypedDict):
|
|
158 |
hp: int
|
159 |
energy_type: str
|
160 |
species: str
|
161 |
-
length:
|
162 |
weight: str
|
163 |
-
attacks:
|
164 |
weakness: Union[str, None]
|
165 |
resistance: Union[str, None]
|
166 |
retreat: int
|
@@ -176,10 +176,10 @@ def rand_details() -> Details:
|
|
176 |
"name": name,
|
177 |
"hp": rand_hp(),
|
178 |
"energy_type": energy_type,
|
179 |
-
"species": rand_species(cast(
|
180 |
"length": rand_length(),
|
181 |
"weight": rand_weight(),
|
182 |
-
"attacks": cast(
|
183 |
"weakness": rand_energy(can_be_none=True),
|
184 |
"resistance": rand_energy(can_be_none=True),
|
185 |
"retreat": rand_retreat(),
|
|
|
1 |
import random
|
2 |
import json
|
3 |
+
from typing import cast, Dict, List, Optional, TypedDict, Union
|
4 |
|
5 |
|
6 |
class Attack(TypedDict):
|
7 |
name: str
|
8 |
+
cost: List[str]
|
9 |
convertedEnergyCost: int
|
10 |
damage: str
|
11 |
text: str
|
12 |
|
13 |
|
14 |
+
ListCollection = Dict[str, Union[List[str], List[Attack]]]
|
15 |
|
16 |
|
17 |
+
def load_lists(list_names: List[str], base_dir: str = "lists") -> ListCollection:
|
18 |
lists = {}
|
19 |
|
20 |
for name in list_names:
|
|
|
27 |
def rand_hp() -> int:
|
28 |
# Weights from https://bulbapedia.bulbagarden.net/wiki/HP_(TCG)
|
29 |
|
30 |
+
hp_range: List[int] = list(range(30, 340 + 1, 10))
|
31 |
|
32 |
+
weights: List[int] = [156, 542, 1264, 1727, 1477, 1232, 1008, 640, 436, 515, 469, 279, 188,
|
33 |
131, 132, 132, 56, 66, 97, 74, 23, 24, 25, 7, 15, 6, 0, 12, 18, 35, 18, 3]
|
34 |
|
35 |
return random.choices(hp_range, weights)[0]
|
36 |
|
37 |
|
38 |
def rand_energy(can_be_none: bool = False) -> Union[str, None]:
|
39 |
+
types: List[str] = ['colorless', 'darkness', 'dragon', 'fairy', 'fighting',
|
40 |
'fire', 'grass', 'lightning', 'metal', 'psychic', 'water']
|
41 |
|
42 |
if can_be_none:
|
|
|
51 |
return cast(str, random.choices(lists[energy_type])[0])
|
52 |
|
53 |
|
54 |
+
def rand_species(species: List[str]) -> str:
|
55 |
random_species: str = random.choices(species)[0]
|
56 |
|
57 |
return f'{random_species.capitalize()}'
|
58 |
|
59 |
|
60 |
+
def rand_length() -> Dict[str, int]:
|
61 |
# Weights from https://bulbapedia.bulbagarden.net/wiki/List_of_Pok%C3%A9mon_by_height
|
62 |
|
63 |
+
feet_ranges: List[int] = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 16,
|
64 |
17, 18, 19, 20, 21, 22, 23, 24, 26, 28, 30, 32, 34, 35, 47, 65, 328]
|
65 |
|
66 |
+
weights: List[int] = [30, 220, 230, 176, 130, 109, 63, 27, 17, 17, 5, 5, 6,
|
67 |
4, 3, 2, 2, 2, 1, 2, 3, 1, 2, 1, 1, 1, 2, 1, 1, 2, 1, 1, 1]
|
68 |
|
69 |
return {
|
|
|
75 |
def rand_weight() -> str:
|
76 |
# Weights from https://bulbapedia.bulbagarden.net/wiki/List_of_Pok%C3%A9mon_by_weight
|
77 |
|
78 |
+
weight_ranges: List[Dict[str, int]] = [
|
79 |
{"start": 1, "end": 22},
|
80 |
{"start": 22, "end": 44},
|
81 |
{"start": 44, "end": 55},
|
|
|
94 |
{"start": 903, "end": 2204}]
|
95 |
|
96 |
# 'weights' as in statistical weightings, not physical mass
|
97 |
+
weights: List[int] = [271, 145, 53, 204, 57, 122, 1, 11, 57, 28, 7, 34, 4, 17, 5, 31]
|
98 |
|
99 |
start: int
|
100 |
end: int
|
|
|
106 |
|
107 |
|
108 |
def rand_attack(
|
109 |
+
attacks: List[Attack],
|
110 |
name: str, energy_type: Optional[str],
|
111 |
colorless_only_allowed: bool = False) -> Attack:
|
112 |
random_attack: Attack = random.choices(attacks)[0]
|
|
|
126 |
return random_attack
|
127 |
|
128 |
|
129 |
+
def rand_attacks(attacks: List[Attack], name: str, energy_type: Optional[str], n: int = 2) -> List[Attack]:
|
130 |
attack1: Attack = rand_attack(attacks, name, energy_type)
|
131 |
|
132 |
if n > 1:
|
|
|
158 |
hp: int
|
159 |
energy_type: str
|
160 |
species: str
|
161 |
+
length: Dict[str, int]
|
162 |
weight: str
|
163 |
+
attacks: List[Attack]
|
164 |
weakness: Union[str, None]
|
165 |
resistance: Union[str, None]
|
166 |
retreat: int
|
|
|
176 |
"name": name,
|
177 |
"hp": rand_hp(),
|
178 |
"energy_type": energy_type,
|
179 |
+
"species": rand_species(cast(List[str], lists["species"])),
|
180 |
"length": rand_length(),
|
181 |
"weight": rand_weight(),
|
182 |
+
"attacks": cast(List[Attack], rand_attacks(cast(List[Attack], lists["attacks"]), name, energy_type=energy_type)),
|
183 |
"weakness": rand_energy(can_be_none=True),
|
184 |
"resistance": rand_energy(can_be_none=True),
|
185 |
"retreat": rand_retreat(),
|