Source code for immuneML.api.galaxy.DataSimulationTool

import logging
import shutil
from pathlib import Path

import yaml

from immuneML.IO.dataset_export.AIRRExporter import AIRRExporter
from immuneML.api.galaxy.GalaxyTool import GalaxyTool
from immuneML.api.galaxy.Util import Util
from immuneML.app.ImmuneMLApp import ImmuneMLApp
from immuneML.util.ParameterValidator import ParameterValidator
from immuneML.workflows.instructions.dataset_generation.DatasetExportInstruction import DatasetExportInstruction


[docs] class DataSimulationTool(GalaxyTool): def __init__(self, specification_path: Path, result_path: Path, **kwargs): Util.check_parameters(specification_path, result_path, kwargs, DataSimulationTool.__name__) super().__init__(specification_path, result_path, **kwargs) self.expected_instruction = DatasetExportInstruction.__name__[:-11] self.instruction_name = None self.dataset_name = None self.export_format = None def _run(self): self.prepare_specs() # Util.run_tool(self.yaml_path, self.result_path) state = ImmuneMLApp(self.yaml_path, self.result_path).run()[0] dataset = state.datasets[0] Util.export_galaxy_dataset(dataset, self.result_path) logging.info(f"{DataSimulationTool.__name__}: immuneML has finished and the dataset was created.")
[docs] def prepare_specs(self): with self.yaml_path.open("r") as file: specs = yaml.safe_load(file) self.instruction_name = Util.check_instruction_type(specs, DataSimulationTool.__name__, self.expected_instruction) self.export_format = Util.check_export_format(specs, DataSimulationTool.__name__, self.instruction_name) ParameterValidator.assert_keys_present(specs["definitions"], ["datasets"], DataSimulationTool.__name__, "definitions/datasets") ParameterValidator.assert_type_and_value(specs['definitions']['datasets'], dict, DataSimulationTool.__name__, "definitions/datasets") self.dataset_name = "dataset" Util.update_dataset_key(specs, DataSimulationTool.__name__, self.dataset_name) Util.check_paths(specs, DataSimulationTool.__name__) Util.update_result_paths(specs, self.result_path, self.yaml_path)