nkululeko 0.81.0__tar.gz → 0.81.2__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 (166) hide show
  1. {nkululeko-0.81.0 → nkululeko-0.81.2}/CHANGELOG.md +10 -0
  2. {nkululeko-0.81.0/nkululeko.egg-info → nkululeko-0.81.2}/PKG-INFO +11 -1
  3. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/constants.py +1 -1
  4. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/data/dataset.py +4 -1
  5. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/demo_predictor.py +7 -3
  6. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feinberg_praat.py +2 -2
  7. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model.py +7 -2
  8. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_mlp_regression.py +1 -1
  9. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_svm.py +10 -1
  10. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_svr.py +3 -1
  11. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_xgb.py +3 -0
  12. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/utils/util.py +4 -5
  13. {nkululeko-0.81.0 → nkululeko-0.81.2/nkululeko.egg-info}/PKG-INFO +11 -1
  14. {nkululeko-0.81.0 → nkululeko-0.81.2}/LICENSE +0 -0
  15. {nkululeko-0.81.0 → nkululeko-0.81.2}/README.md +0 -0
  16. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/aesdd/process_database.py +0 -0
  17. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/androids/process_database.py +0 -0
  18. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/androids_orig/process_database.py +0 -0
  19. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/androids_test/process_database.py +0 -0
  20. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/ased/process_database.py +0 -0
  21. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/asvp-esd/process_database.py +0 -0
  22. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/baved/process_database.py +0 -0
  23. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/cafe/process_database.py +0 -0
  24. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/clac/process_database.py +0 -0
  25. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/cmu-mosei/process_database.py +0 -0
  26. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/crema-d/process_database.py +0 -0
  27. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/demos/process_database.py +0 -0
  28. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/ekorpus/process_database.py +0 -0
  29. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/emns/process_database.py +0 -0
  30. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/emofilm/convert_to_16k.py +0 -0
  31. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/emofilm/process_database.py +0 -0
  32. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/emorynlp/process_database.py +0 -0
  33. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/emov-db/process_database.py +0 -0
  34. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/emovo/process_database.py +0 -0
  35. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/emozionalmente/create.py +0 -0
  36. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/enterface/process_database.py +0 -0
  37. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/esd/process_database.py +0 -0
  38. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/gerparas/process_database.py +0 -0
  39. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/iemocap/process_database.py +0 -0
  40. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/jl/process_database.py +0 -0
  41. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/jtes/process_database.py +0 -0
  42. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/meld/process_database.py +0 -0
  43. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/mesd/process_database.py +0 -0
  44. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/mess/process_database.py +0 -0
  45. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/mlendsnd/process_database.py +0 -0
  46. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/msp-improv/process_database2.py +0 -0
  47. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/msp-podcast/process_database.py +0 -0
  48. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/oreau2/process_database.py +0 -0
  49. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/portuguese/process_database.py +0 -0
  50. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/ravdess/process_database.py +0 -0
  51. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/ravdess/process_database_speaker.py +0 -0
  52. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/savee/process_database.py +0 -0
  53. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/shemo/process_database.py +0 -0
  54. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/subesco/process_database.py +0 -0
  55. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/tess/process_database.py +0 -0
  56. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/thorsten-emotional/process_database.py +0 -0
  57. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/urdu/process_database.py +0 -0
  58. {nkululeko-0.81.0 → nkululeko-0.81.2}/data/vivae/process_database.py +0 -0
  59. {nkululeko-0.81.0 → nkululeko-0.81.2}/docs/source/conf.py +0 -0
  60. {nkululeko-0.81.0 → nkululeko-0.81.2}/meta/demos/demo_best_model.py +0 -0
  61. {nkululeko-0.81.0 → nkululeko-0.81.2}/meta/demos/multiple_exeriments/do_experiments.py +0 -0
  62. {nkululeko-0.81.0 → nkululeko-0.81.2}/meta/demos/multiple_exeriments/parse_nkulu.py +0 -0
  63. {nkululeko-0.81.0 → nkululeko-0.81.2}/meta/demos/my_experiment.py +0 -0
  64. {nkululeko-0.81.0 → nkululeko-0.81.2}/meta/demos/my_experiment_local.py +0 -0
  65. {nkululeko-0.81.0 → nkululeko-0.81.2}/meta/demos/plot_faster_anim.py +0 -0
  66. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/__init__.py +0 -0
  67. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/aug_train.py +0 -0
  68. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/augment.py +0 -0
  69. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/augmenting/__init__.py +0 -0
  70. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/augmenting/augmenter.py +0 -0
  71. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/augmenting/randomsplicer.py +0 -0
  72. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/augmenting/randomsplicing.py +0 -0
  73. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/augmenting/resampler.py +0 -0
  74. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/__init__.py +0 -0
  75. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/ap_age.py +0 -0
  76. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/ap_arousal.py +0 -0
  77. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/ap_dominance.py +0 -0
  78. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/ap_gender.py +0 -0
  79. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/ap_mos.py +0 -0
  80. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/ap_pesq.py +0 -0
  81. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/ap_sdr.py +0 -0
  82. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/ap_snr.py +0 -0
  83. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/ap_stoi.py +0 -0
  84. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/ap_valence.py +0 -0
  85. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/autopredict/estimate_snr.py +0 -0
  86. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/cacheddataset.py +0 -0
  87. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/data/__init__.py +0 -0
  88. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/data/dataset_csv.py +0 -0
  89. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/demo.py +0 -0
  90. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/demo_feats.py +0 -0
  91. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/experiment.py +0 -0
  92. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/explore.py +0 -0
  93. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/export.py +0 -0
  94. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/__init__.py +0 -0
  95. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_agender.py +0 -0
  96. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_agender_agender.py +0 -0
  97. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_analyser.py +0 -0
  98. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_audmodel.py +0 -0
  99. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_audmodel_dim.py +0 -0
  100. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_clap.py +0 -0
  101. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_hubert.py +0 -0
  102. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_import.py +0 -0
  103. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_mld.py +0 -0
  104. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_mos.py +0 -0
  105. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_opensmile.py +0 -0
  106. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_oxbow.py +0 -0
  107. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_praat.py +0 -0
  108. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_snr.py +0 -0
  109. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_spectra.py +0 -0
  110. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_spkrec.py +0 -0
  111. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_squim.py +0 -0
  112. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_trill.py +0 -0
  113. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_wav2vec2.py +0 -0
  114. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/feats_wavlm.py +0 -0
  115. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feat_extract/featureset.py +0 -0
  116. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/feature_extractor.py +0 -0
  117. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/file_checker.py +0 -0
  118. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/filter_data.py +0 -0
  119. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/glob_conf.py +0 -0
  120. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/losses/__init__.py +0 -0
  121. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/losses/loss_ccc.py +0 -0
  122. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/losses/loss_softf1loss.py +0 -0
  123. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/modelrunner.py +0 -0
  124. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/__init__.py +0 -0
  125. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_bayes.py +0 -0
  126. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_cnn.py +0 -0
  127. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_gmm.py +0 -0
  128. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_knn.py +0 -0
  129. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_knn_reg.py +0 -0
  130. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_lin_reg.py +0 -0
  131. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_mlp.py +0 -0
  132. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_tree.py +0 -0
  133. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_tree_reg.py +0 -0
  134. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/models/model_xgr.py +0 -0
  135. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/multidb.py +0 -0
  136. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/nkululeko.py +0 -0
  137. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/plots.py +0 -0
  138. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/predict.py +0 -0
  139. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/reporter.py +0 -0
  140. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/reporting/__init__.py +0 -0
  141. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/reporting/defines.py +0 -0
  142. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/reporting/latex_writer.py +0 -0
  143. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/reporting/report.py +0 -0
  144. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/reporting/report_item.py +0 -0
  145. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/resample.py +0 -0
  146. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/result.py +0 -0
  147. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/runmanager.py +0 -0
  148. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/scaler.py +0 -0
  149. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/segment.py +0 -0
  150. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/segmenting/__init__.py +0 -0
  151. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/segmenting/seg_inaspeechsegmenter.py +0 -0
  152. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/segmenting/seg_silero.py +0 -0
  153. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/syllable_nuclei.py +0 -0
  154. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/test.py +0 -0
  155. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/test_predictor.py +0 -0
  156. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/utils/__init__.py +0 -0
  157. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/utils/files.py +0 -0
  158. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko/utils/stats.py +0 -0
  159. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko.egg-info/SOURCES.txt +0 -0
  160. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko.egg-info/dependency_links.txt +0 -0
  161. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko.egg-info/requires.txt +0 -0
  162. {nkululeko-0.81.0 → nkululeko-0.81.2}/nkululeko.egg-info/top_level.txt +0 -0
  163. {nkululeko-0.81.0 → nkululeko-0.81.2}/pyproject.toml +0 -0
  164. {nkululeko-0.81.0 → nkululeko-0.81.2}/setup.cfg +0 -0
  165. {nkululeko-0.81.0 → nkululeko-0.81.2}/setup.py +0 -0
  166. {nkululeko-0.81.0 → nkululeko-0.81.2}/venv/bin/activate_this.py +0 -0
@@ -1,6 +1,16 @@
1
1
  Changelog
2
2
  =========
3
3
 
4
+ Version 0.81.2
5
+ --------------
6
+ * added a parselmouth.Praat error if pitch out of range
7
+ * changed file path for demo_predictor
8
+
9
+ Version 0.81.1
10
+ --------------
11
+ * fixed bugs in demo module
12
+ * made kernel for SVM/SVR configurable
13
+
4
14
  Version 0.81.0
5
15
  --------------
6
16
  * added test selection to test module
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: nkululeko
3
- Version: 0.81.0
3
+ Version: 0.81.2
4
4
  Summary: Machine learning audio prediction experiments based on templates
5
5
  Home-page: https://github.com/felixbur/nkululeko
6
6
  Author: Felix Burkhardt
@@ -321,6 +321,16 @@ F. Burkhardt, Johannes Wagner, Hagen Wierstorf, Florian Eyben and Björn Schulle
321
321
  Changelog
322
322
  =========
323
323
 
324
+ Version 0.81.2
325
+ --------------
326
+ * added a parselmouth.Praat error if pitch out of range
327
+ * changed file path for demo_predictor
328
+
329
+ Version 0.81.1
330
+ --------------
331
+ * fixed bugs in demo module
332
+ * made kernel for SVM/SVR configurable
333
+
324
334
  Version 0.81.0
325
335
  --------------
326
336
  * added test selection to test module
@@ -1,2 +1,2 @@
1
- VERSION="0.81.0"
1
+ VERSION="0.81.2"
2
2
  SAMPLING_RATE = 16000
@@ -162,7 +162,10 @@ class Dataset:
162
162
  if column not in [self.target, "age", "speaker", "gender"]:
163
163
  df[column] = df_target[column]
164
164
  except audformat.core.errors.BadKeyError:
165
- pass
165
+ if not self.is_labeled:
166
+ self.util.error(
167
+ f"Giving up: no target ({self.target}) column found"
168
+ )
166
169
 
167
170
  if self.is_labeled:
168
171
  # remember the target in case they get labelencoded later
@@ -1,3 +1,4 @@
1
+ import os
1
2
  import pandas as pd
2
3
  import numpy as np
3
4
  import audiofile
@@ -52,13 +53,16 @@ class Demo_predictor:
52
53
  file_list.append(line)
53
54
  for file_name in file_list:
54
55
  test_folder = glob_conf.config["DATA"]["test_folder"]
55
- file_path = test_folder + file_name.strip()
56
+ file_path = os.path.join(test_folder, file_name.strip())
56
57
  sig, sr = audiofile.read(file_path)
57
58
  print(f"predicting file {file_path}")
58
59
  res_dict = self.predict_signal(sig, sr)
59
- df_tmp = pd.DataFrame(res_dict, index=[file_path])
60
+ df_tmp = pd.DataFrame(res_dict, index=[file_name.strip()])
60
61
  df_res = pd.concat([df_res, df_tmp], ignore_index=False)
61
62
  df_res = df_res.set_index(df_res.index.rename("file"))
63
+ # save only filename and prediction (df_tmp) by default
64
+ # drop other columns
65
+ # df_res = df_res[["predicted"]]
62
66
  if self.outfile is not None:
63
67
  df_res.to_csv(self.outfile)
64
68
  else:
@@ -94,7 +98,7 @@ class Demo_predictor:
94
98
  return result_dict
95
99
  else:
96
100
  # experiment is regression and returns one estimation
97
- dict_2["predicted"] = result_dict[0]
101
+ dict_2["predicted"] = result_dict
98
102
  print(dict_2)
99
103
  return dict_2
100
104
 
@@ -294,8 +294,8 @@ def compute_features(file_index):
294
294
  f4_median,
295
295
  ) = measureFormants(sound, 75, 300)
296
296
  # file_list.append(wave_file) # make an ID list
297
- except statistics.StatisticsError as se:
298
- print(f"error on file {wave_file}: {se}")
297
+ except (statistics.StatisticsError, parselmouth.PraatError) as errors:
298
+ print(f"error on file {wave_file}: {errors}")
299
299
 
300
300
  duration_list.append(duration) # make duration list
301
301
  mean_F0_list.append(meanF0) # make a mean F0 list
@@ -269,19 +269,24 @@ class Model:
269
269
  )
270
270
  return report
271
271
 
272
+ def get_type(self):
273
+ return "generic"
274
+
272
275
  def predict_sample(self, features):
273
276
  """Predict one sample"""
274
277
  prediction = {}
275
278
  if self.util.exp_is_classification():
276
279
  # get the class probabilities
277
- predictions = self.clf.predict_proba([features])
280
+ if not self.get_type() == "xgb":
281
+ features = [features]
282
+ predictions = self.clf.predict_proba(features)
278
283
  # pred = self.clf.predict(features)
279
284
  for i in range(len(self.clf.classes_)):
280
285
  cat = self.clf.classes_[i]
281
286
  prediction[cat] = predictions[0][i]
282
287
  else:
283
288
  predictions = self.clf.predict(features)
284
- prediction["result"] = predictions[0]
289
+ prediction = predictions[0]
285
290
  return prediction
286
291
 
287
292
  def store(self):
@@ -247,4 +247,4 @@ class MLP_Reg_model(Model):
247
247
  features = np.reshape(features, (-1, 1)).T
248
248
  logits = self.model(features.to(self.device)).reshape(-1)
249
249
  a = logits.numpy()
250
- return a
250
+ return a[0]
@@ -12,8 +12,17 @@ class SVM_model(Model):
12
12
  def __init__(self, df_train, df_test, feats_train, feats_test):
13
13
  super().__init__(df_train, df_test, feats_train, feats_test)
14
14
  c = float(self.util.config_val("MODEL", "C_val", "0.001"))
15
+ if eval(self.util.config_val("MODEL", "class_weight", "False")):
16
+ class_weight = "balanced"
17
+ else:
18
+ class_weight = None
19
+ kernel = self.util.config_val("MODEL", "kernel", "rbf")
15
20
  self.clf = svm.SVC(
16
- kernel="linear", C=c, gamma="scale", probability=True
21
+ kernel=kernel,
22
+ C=c,
23
+ gamma="scale",
24
+ probability=True,
25
+ class_weight=class_weight,
17
26
  ) # set up the classifier
18
27
 
19
28
  def set_C(self, c):
@@ -12,7 +12,9 @@ class SVR_model(Model):
12
12
  def __init__(self, df_train, df_test, feats_train, feats_test):
13
13
  super().__init__(df_train, df_test, feats_train, feats_test)
14
14
  c = float(self.util.config_val("MODEL", "C_val", "0.001"))
15
- self.clf = svm.SVR(kernel="rbf", C=c, probability=True) # set up the classifier
15
+ # kernel{‘linear’, ‘poly’, rbf’, ‘sigmoid’, ‘precomputed’} or callable, default=’rbf’
16
+ kernel = self.util.config_val("MODEL", "kernel", "rbf")
17
+ self.clf = svm.SVR(kernel=kernel, C=c) # set up the classifier
16
18
 
17
19
  def set_C(self, c):
18
20
  """Set the C parameter"""
@@ -10,3 +10,6 @@ class XGB_model(Model):
10
10
  is_classifier = True
11
11
 
12
12
  clf = XGBClassifier() # set up the classifier
13
+
14
+ def get_type(self):
15
+ return "xgb"
@@ -175,10 +175,6 @@ class Util:
175
175
  mt = f'{self.config["MODEL"]["type"]}'
176
176
  ft = "_".join(ast.literal_eval(self.config["FEATS"]["type"]))
177
177
  ft += "_"
178
- set = self.config_val("FEATS", "set", False)
179
- set_string = ""
180
- if set:
181
- set_string += set
182
178
  layer_string = ""
183
179
  layer_s = self.config_val("MODEL", "layers", False)
184
180
  if layer_s:
@@ -186,16 +182,19 @@ class Util:
186
182
  sorted_layers = sorted(layers.items(), key=lambda x: x[1])
187
183
  for l in sorted_layers:
188
184
  layer_string += f"{str(l[1])}-"
189
- return_string = f"{mt}_{ft}{set_string}{layer_string[:-1]}"
185
+ return_string = f"{mt}_{ft}{layer_string[:-1]}"
190
186
  options = [
191
187
  ["MODEL", "C_val"],
188
+ ["MODEL", "kernel"],
192
189
  ["MODEL", "drop"],
190
+ ["MODEL", "class_weight"],
193
191
  ["MODEL", "loss"],
194
192
  ["MODEL", "logo"],
195
193
  ["MODEL", "learning_rate"],
196
194
  ["MODEL", "k_fold_cross"],
197
195
  ["FEATS", "balancing"],
198
196
  ["FEATS", "scale"],
197
+ ["FEATS", "set"],
199
198
  ["FEATS", "wav2vec2.layer"],
200
199
  ]
201
200
  for option in options:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: nkululeko
3
- Version: 0.81.0
3
+ Version: 0.81.2
4
4
  Summary: Machine learning audio prediction experiments based on templates
5
5
  Home-page: https://github.com/felixbur/nkululeko
6
6
  Author: Felix Burkhardt
@@ -321,6 +321,16 @@ F. Burkhardt, Johannes Wagner, Hagen Wierstorf, Florian Eyben and Björn Schulle
321
321
  Changelog
322
322
  =========
323
323
 
324
+ Version 0.81.2
325
+ --------------
326
+ * added a parselmouth.Praat error if pitch out of range
327
+ * changed file path for demo_predictor
328
+
329
+ Version 0.81.1
330
+ --------------
331
+ * fixed bugs in demo module
332
+ * made kernel for SVM/SVR configurable
333
+
324
334
  Version 0.81.0
325
335
  --------------
326
336
  * added test selection to test module
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes