You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

test_hetero_spec.py 1.5 kB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. import json
  2. import os
  3. import tempfile
  4. import unittest
  5. import numpy as np
  6. from learnware.market.heterogeneous.organizer import HeteroMap
  7. from learnware.specification import HeteroMapTableSpecification, RKMETableSpecification, generate_stat_spec
  8. class TestTableRKME(unittest.TestCase):
  9. def setUp(self):
  10. self.hetero_map = HeteroMap()
  11. def _test_hetero_spec(self, X):
  12. rkme: RKMETableSpecification = generate_stat_spec(type="table", X=X)
  13. hetero_spec = self.hetero_map.hetero_mapping(rkme_spec=rkme, features=dict())
  14. with tempfile.TemporaryDirectory(prefix="learnware_") as tempdir:
  15. rkme_path = os.path.join(tempdir, "rkme.json")
  16. hetero_spec.save(rkme_path)
  17. with open(rkme_path, "r") as f:
  18. data = json.load(f)
  19. assert data["type"] == "HeteroMapTableSpecification"
  20. rkme2 = HeteroMapTableSpecification()
  21. rkme2.load(rkme_path)
  22. assert rkme2.type == "HeteroMapTableSpecification"
  23. def test_hetero_rkme(self):
  24. self._test_hetero_spec(np.random.uniform(-10000, 10000, size=(5000, 200)))
  25. self._test_hetero_spec(np.random.uniform(-10000, 10000, size=(10000, 100)))
  26. self._test_hetero_spec(np.random.uniform(-10000, 10000, size=(5, 20)))
  27. self._test_hetero_spec(np.random.uniform(-10000, 10000, size=(1, 50)))
  28. self._test_hetero_spec(np.random.uniform(-10000, 10000, size=(100, 150)))
  29. if __name__ == "__main__":
  30. unittest.main()