6
0

FitModel.py 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. from flask import make_response, request, abort
  2. from flask.views import View
  3. from pycs.database.Database import Database
  4. from pycs.database.Project import Project
  5. from pycs.interfaces.MediaStorage import MediaStorage
  6. from pycs.jobs.JobGroupBusyException import JobGroupBusyException
  7. from pycs.jobs.JobRunner import JobRunner
  8. from pycs.util.PipelineCache import PipelineCache
  9. class FitModel(View):
  10. """
  11. use annotated data to fit a model
  12. """
  13. # pylint: disable=arguments-differ
  14. methods = ['POST']
  15. def __init__(self, jobs: JobRunner, pipelines: PipelineCache):
  16. # pylint: disable=invalid-name
  17. self.jobs = jobs
  18. self.pipelines = pipelines
  19. def dispatch_request(self, project_id):
  20. # extract request data
  21. data = request.get_json(force=True)
  22. if not data.get('fit', False):
  23. return abort(400)
  24. # find project
  25. project = Project.query.get(project_id)
  26. if project is None:
  27. return abort(404)
  28. # create job
  29. try:
  30. self.jobs.run(project,
  31. 'Model Interaction',
  32. f'{project.name} (fit model with new data)',
  33. f'{project.name}/model-interaction',
  34. self.load_and_fit, self.pipelines, project.id)
  35. except JobGroupBusyException:
  36. return abort(400)
  37. return make_response()
  38. @staticmethod
  39. def load_and_fit(pipelines: PipelineCache, project_id: int):
  40. pipeline = None
  41. project = Project.query.get(project_id)
  42. model = project.model()
  43. storage = MediaStorage(project_id)
  44. # load pipeline
  45. try:
  46. pipeline = pipelines.load_from_root_folder(project, model.root_folder)
  47. yield from pipeline.fit(storage)
  48. except TypeError:
  49. pass
  50. finally:
  51. if pipeline is not None:
  52. pipelines.free_instance(model.root_folder)