-
Notifications
You must be signed in to change notification settings - Fork 41
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
image preprocessing functions #185
base: main
Are you sure you want to change the base?
Conversation
… scale_and_fill), added unit tests for prepare_img functions, added opencv-contrib-python requirement
3a82a1e
to
6efd6d9
Compare
…hods, use preprocessing in CogVLM2, added select_preprocess_img_by_str to map from string to function
@jhc13 I'm done. |
I have to admit it is rather difficult for me to come up with real adversarial examples:
I'm so sorry children but it's for science!
from https://commons.wikimedia.org/wiki/File:EPK_komplexes_Beispiel.png |
I just noticed some models are using preprocessor_config.json |
#168
implement different functions (
prepare_img_stretch_and_squish
,prepare_img_scale_and_centercrop
,prepare_img_scale_and_fill
) to prepare square images for the model. functions are not yet integrated in UI.added unit tests for prepare_img functions. call with
python taggui/run_tests.py
which runs the functions onimages/people_landscape.webp
andimages/people_portrait.webp
. images are licensed CC, addedattributions.txt
. I chose images with an aspect ratio of 2 and people as content to make any strange preparations more obvious ("vertically flipped faces?", "oval faces?", "double face reflections?", "extended feet?")added
opencv-contrib-python
as requirement (used inscale_and_fill
). sooner or later we will need it anyway. I strongly argue for using opencv-contrib (contrib + non-headless) as there is a known issue with opencv to be incompatible with any other module previously installed in parallel and this version is the superset of all opencv modules.TODO: add examples with abstract objects (like diagram)
Landscape example
original:
stretch and squish:
data:image/s3,"s3://crabby-images/ba133/ba133e1a0767658f5d15350833fdf91ee97bf6e1" alt="people_landscape_stretch_and_squish"
center crop:
data:image/s3,"s3://crabby-images/488b8/488b85b00fab9bfba2b3d967c33dc4bc381d61e6" alt="people_landscape_scale_and_centercrop"
fill gray:
data:image/s3,"s3://crabby-images/8fdb1/8fdb1bbf3f0a01dc1ab78f8225e17b6f03771a8a" alt="people_landscape_gray"
fill noise:
data:image/s3,"s3://crabby-images/ae8e7/ae8e77ff387edeb71b648ccaefb9706ab40c2728" alt="people_landscape_noise"
fill reflect:
data:image/s3,"s3://crabby-images/b9e3a/b9e3a2adf7c9221c1c057775a811066c6806ca68" alt="people_landscape_reflect"
fill replicate:
data:image/s3,"s3://crabby-images/5ccff/5ccff7d26202c1b0e7d1faeb6fa46b0f5f9781b9" alt="people_landscape_replicate"
Portrait Example
original:
data:image/s3,"s3://crabby-images/99a05/99a05a3bac3a4c09cd863839bdb41bd2eec1e19e" alt="people_portrait"
stretch and squish:
data:image/s3,"s3://crabby-images/8bfe5/8bfe53d1a6f2bfc9ed438d9aa5ad10d71171d0a1" alt="people_portrait_stretch_and_squish"
center crop:
data:image/s3,"s3://crabby-images/519b3/519b310bf777b152bda51f5b56c10e8a78033eaf" alt="people_portrait_scale_and_centercrop"
fill gray:
data:image/s3,"s3://crabby-images/6f0b7/6f0b7b15097da84f051f2850c959fe9a2007a9ff" alt="people_portrait_gray"
fill noise:
data:image/s3,"s3://crabby-images/929a5/929a5e2b3d327bac73a27eb6f3004d20b0527b6d" alt="people_portrait_noise"
fill reflect:
data:image/s3,"s3://crabby-images/54ab8/54ab8958cac7455b3a8ab8b8e14f893471001dcf" alt="people_portrait_reflect"
fill replicate:
data:image/s3,"s3://crabby-images/a4e98/a4e9877e190d0f2614554cd72b513ffd5cda1c22" alt="people_portrait_replicate"