KERAS ImageDataGenerator indexy třída průtoku pro řídké a kategorických tříd

hlasů
0

Pro KERAS Dětské ImageDataGenerator flow_*metod vyžaduje stringified verzi indexů třída pro kategorické a rozptýlené class_mode. Mám štítky tříd, které vypadá ['0','1',...,'10','11',...]a nešťastnou důsledkem je, že KERAS indexy tyto v řetězci-abecedním pořadí:

Například:

datagen = ImageDataGenerator(
        rotation_range=0,
        width_shift_range=0,
        height_shift_range=0,
        rescale=None,
        shear_range=0,
        zoom_range=0,
        horizontal_flip=False,
        preprocessing_function=preprocessor,
        fill_mode='nearest')

test_generator = datagen.flow_from_dataframe(
    dataframe=dfTest,
    directory=None,
    x_col=filePath,
    y_col=ycat,
    target_size=SIZE,
    batch_size=BATCH_SIZE,
    class_mode='sparse',
    shuffle=False)

    print(test_generator.class_indices)

dodává:

{'0': 0,
 '1': 1,
 '10': 2,
 '11': 3,
 ...,
 '2': 12,
 '20': 13,
 '21': 14,
 '22': 15,
 '3': 16,
 '4': 17,
 '5': 18,
 '6': 19,
 '7': 20,
 '8': 21,
 '9': 22}

V ideálním případě bych si přál, aby:

{'0': 0,
 '1': 1,
 '2': 2,

 ...,
 }

Přemýšlel jsem o ruční změně test_generator.class_indices, ale nejsem si jistý, že je to bezpečné jako po inicializaci, generátor má pre-vypočtena etikety třída datovém souboru.

Je zde pěkný řešení tohoto problému, aniž by přepsáním flow_*metodu?

Položena 14/02/2020 v 00:02
zdroj uživatelem
V jiných jazycích...                            

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more