BETTER-NMA 1.0.5__tar.gz → 1.0.6__tar.gz

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.
Files changed (45) hide show
  1. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/adversarial_dataset.py +7 -4
  2. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/photos_uitls.py +18 -0
  3. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA.egg-info/PKG-INFO +1 -1
  4. {better_nma-1.0.5 → better_nma-1.0.6}/PKG-INFO +1 -1
  5. {better_nma-1.0.5 → better_nma-1.0.6}/setup.py +1 -1
  6. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/__init__.py +0 -0
  7. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/adversarial_score.py +0 -0
  8. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/change_cluster_name.py +0 -0
  9. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/detect_attack.py +0 -0
  10. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/explaination_score.py +0 -0
  11. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/find_lca.py +0 -0
  12. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/main.py +0 -0
  13. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/nma_creator.py +0 -0
  14. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/plot.py +0 -0
  15. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/query_image.py +0 -0
  16. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/train_adversarial_detector.py +0 -0
  17. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/__init__.py +0 -0
  18. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/__init__.py +0 -0
  19. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/adversarial_detector.py +0 -0
  20. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/dendrogram.py +0 -0
  21. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/edges_dataframe.py +0 -0
  22. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/preprocessing/__init__.py +0 -0
  23. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/preprocessing/batch_predictor.py +0 -0
  24. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/preprocessing/graph_builder.py +0 -0
  25. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/preprocessing/heap_processor.py +0 -0
  26. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/preprocessing/hierarchical_clustering_builder.py +0 -0
  27. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/preprocessing/tree_node.py +0 -0
  28. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/preprocessing/z_builder.py +0 -0
  29. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/score_calculator.py +0 -0
  30. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/classes/whitebox_testing.py +0 -0
  31. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/enums/__init__.py +0 -0
  32. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/enums/explanation_method.py +0 -0
  33. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/enums/heap_types.py +0 -0
  34. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/models_utils.py +0 -0
  35. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/photos_utils.py +0 -0
  36. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/verbal_explanation.py +0 -0
  37. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/utilss/wordnet_utils.py +0 -0
  38. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA/white_box_testing.py +0 -0
  39. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA.egg-info/SOURCES.txt +0 -0
  40. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA.egg-info/dependency_links.txt +0 -0
  41. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA.egg-info/requires.txt +0 -0
  42. {better_nma-1.0.5 → better_nma-1.0.6}/BETTER_NMA.egg-info/top_level.txt +0 -0
  43. {better_nma-1.0.5 → better_nma-1.0.6}/README.md +0 -0
  44. {better_nma-1.0.5 → better_nma-1.0.6}/setup.cfg +0 -0
  45. {better_nma-1.0.5 → better_nma-1.0.6}/tests/test_main.py +0 -0
@@ -1,6 +1,7 @@
1
1
  from sklearn.model_selection import train_test_split
2
2
  import numpy as np
3
3
  from .score_calculator import ScoreCalculator
4
+ from ..photos_uitls import preprocess_numpy_image
4
5
 
5
6
  class AdversarialDataset:
6
7
  def __init__(self, model, clear_images, adversarial_images, Z_full, labels):
@@ -16,8 +17,9 @@ class AdversarialDataset:
16
17
  try:
17
18
  for image in self.clear_images[:50]:
18
19
  # Add batch dimension for model prediction
19
- image_batch = np.expand_dims(image, axis=0)
20
- score = self.score_calculator.calculate_adversarial_score(self.model.predict(image_batch, verbose=0))
20
+ # image_batch = np.expand_dims(image, axis=0)
21
+ preprocessed_img = preprocess_numpy_image(self.model, image)
22
+ score = self.score_calculator.calculate_adversarial_score(self.model.predict(preprocessed_img, verbose=0))
21
23
  scores.append(score)
22
24
  labels.append(0)
23
25
  except Exception as e:
@@ -27,8 +29,9 @@ class AdversarialDataset:
27
29
  try:
28
30
  for adv_image in self.adversarial_images[:50]:
29
31
  # Add batch dimension for model prediction
30
- adv_image_batch = np.expand_dims(adv_image, axis=0)
31
- score = self.score_calculator.calculate_adversarial_score(self.model.predict(adv_image_batch, verbose=0))
32
+ # adv_image_batch = np.expand_dims(adv_image, axis=0)
33
+ preprocessed_adv_img = preprocess_numpy_image(self.model, adv_image)
34
+ score = self.score_calculator.calculate_adversarial_score(self.model.predict(preprocessed_adv_img, verbose=0))
32
35
  scores.append(score)
33
36
  labels.append(1)
34
37
  except Exception as e:
@@ -69,4 +69,22 @@ def preprocess_image(model, image):
69
69
  preprocess_input = get_cached_preprocess_function(model)
70
70
  image_array = preprocess_input(np.array(image))
71
71
  image_preprocessed = np.expand_dims(image_array, axis=0)
72
+ return image_preprocessed
73
+
74
+ def preprocess_numpy_image(model, image):
75
+ """
76
+ Preprocess a NumPy array image for the given model.
77
+ """
78
+ # if isinstance(image, list):
79
+ # image = np.array(image)
80
+ if image.ndim == 3:
81
+ # If the image is 3D, add a batch dimension
82
+ image = np.expand_dims(image, axis=0)
83
+
84
+ # Get the appropriate preprocessing function for the model
85
+ preprocess_input = get_cached_preprocess_function(model)
86
+
87
+ # Apply the preprocessing function
88
+ image_preprocessed = preprocess_input(image)
89
+
72
90
  return image_preprocessed
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: BETTER_NMA
3
- Version: 1.0.5
3
+ Version: 1.0.6
4
4
  Summary: NMA: Dendrogram-based model analysis, white-box testing, and adversarial detection
5
5
  Author: BETTER_XAI
6
6
  Author-email: BETTERXAI2025@gmail.com
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: BETTER_NMA
3
- Version: 1.0.5
3
+ Version: 1.0.6
4
4
  Summary: NMA: Dendrogram-based model analysis, white-box testing, and adversarial detection
5
5
  Author: BETTER_XAI
6
6
  Author-email: BETTERXAI2025@gmail.com
@@ -8,7 +8,7 @@ except FileNotFoundError:
8
8
 
9
9
  setup(
10
10
  name="BETTER_NMA",
11
- version="1.0.5",
11
+ version="1.0.6",
12
12
  author="BETTER_XAI",
13
13
  author_email="BETTERXAI2025@gmail.com",
14
14
  description="NMA: Dendrogram-based model analysis, white-box testing, and adversarial detection",
File without changes
File without changes