Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

implement skip duplicated items #19

Open
wants to merge 6 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
__pycache__/

env/
output/
49 changes: 38 additions & 11 deletions nft.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
import time
import os
import random
from progressbar import progressbar
import progressbar

import warnings
warnings.simplefilter(action='ignore', category=FutureWarning)
Expand Down Expand Up @@ -141,14 +141,32 @@ def generate_trait_set_from_config():

return trait_set, trait_paths

def is_dupliacted(rarity_dict, trait_sets, count):
if count == 0:
return False

for index in range(count):
diff_count = 0
for idx, trait in enumerate(trait_sets):
if trait is None:
if rarity_dict[CONFIG[idx]['name']][index] != 'none':
diff_count += 1
if trait is not None:
if rarity_dict[CONFIG[idx]['name']][index] != trait[: -1 * len('.png')]:
diff_count += 1

if diff_count == 0:
return True

return False

# Generate the image set. Don't change drop_dup
def generate_images(edition, count, drop_dup=True):

# Initialize an empty rarity table
rarity_table = {}
rarity_dict = {}
for layer in CONFIG:
rarity_table[layer['name']] = []
rarity_dict[layer['name']] = []

# Define output path to output/edition {edition_num}
op_path = os.path.join('output', 'edition ' + str(edition), 'images')
Expand All @@ -161,26 +179,35 @@ def generate_images(edition, count, drop_dup=True):
os.makedirs(op_path)

# Create the images
for n in progressbar(range(count)):

image_index = 0
# initialize progressbar
bar = progressbar.ProgressBar(max_value=progressbar.UnknownLength)
while image_index < count:
# Set image name
image_name = str(n).zfill(zfill_count) + '.png'
image_name = str(image_index).zfill(zfill_count) + '.png'

# Get a random set of valid traits based on rarity weights
trait_sets, trait_paths = generate_trait_set_from_config()

if is_dupliacted(rarity_dict, trait_sets, image_index):
continue

# Generate the actual image
generate_single_image(trait_paths, os.path.join(op_path, image_name))

# Populate the rarity table with metadata of newly created image
for idx, trait in enumerate(trait_sets):
if trait is not None:
rarity_table[CONFIG[idx]['name']].append(trait[: -1 * len('.png')])
rarity_dict[CONFIG[idx]['name']].append(trait[: -1 * len('.png')])
else:
rarity_table[CONFIG[idx]['name']].append('none')

rarity_dict[CONFIG[idx]['name']].append('none')

# increase generated image count
image_index += 1
bar.update(image_index)

# Create the final rarity table by removing duplicate creat
rarity_table = pd.DataFrame(rarity_table).drop_duplicates()
rarity_table = pd.DataFrame(rarity_dict).drop_duplicates()
print("Generated %i images, %i are distinct" % (count, rarity_table.shape[0]))

if drop_dup:
Expand Down Expand Up @@ -235,4 +262,4 @@ def main():


# Run the main function
main()
main()
9 changes: 9 additions & 0 deletions requirements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
numpy==1.21.5
pandas==1.3.5
Pillow==9.0.1
progressbar==2.5
progressbar2==4.0.0
python-dateutil==2.8.2
python-utils==3.1.0
pytz==2021.3
six==1.16.0