-
AndiMajore authoredAndiMajore authored
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
launch-analysis.component.ts 6.85 KiB
import {Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges} from '@angular/core';
import {
Algorithm,
AlgorithmType,
AnalysisService, BETWEENNESS_CENTRALITY, CLOSENESS_CENTRALITY,
DEGREE_CENTRALITY,
KEYPATHWAYMINER, MAX_TASKS,
MULTISTEINER, NETWORK_PROXIMITY,
QuickAlgorithmType,
TRUSTRANK
} from '../../services/analysis/analysis.service';
import { IConfig } from 'src/app/config';
@Component({
selector: 'app-launch-analysis',
templateUrl: './launch-analysis.component.html',
styleUrls: ['./launch-analysis.component.scss']
})
export class LaunchAnalysisComponent implements OnInit, OnChanges {
@Input()
public show = false;
@Input()
public target: 'drug' | 'drug-target';
@Input()
public inputNetwork: {nodes: any, edges: any};
@Input()
public config: IConfig;
@Output()
public showChange = new EventEmitter<boolean>();
@Output()
public taskEvent = new EventEmitter<object>();
public algorithm: AlgorithmType | QuickAlgorithmType;
public algorithms: Array<Algorithm> = [];
// Trustrank Parameters
public trustrankIncludeIndirectDrugs = false;
public trustrankIncludeNonApprovedDrugs = false;
public trustrankIncludeViralNonSeeds = true;
public trustrankDampingFactor = 0.85;
public trustrankMaxDeg = 0;
public trustrankHubPenalty = 0.0;
public trustrankResultSize = 20;
// Closeness Parameters
public closenessIncludeIndirectDrugs = false;
public closenessIncludeNonApprovedDrugs = false;
public closenessIncludeViralNonSeeds = true;
public closenessMaxDeg = 0;
public closenessHubPenalty = 0.0;
public closenessResultSize = 20;
// Degree Parameters
public degreeIncludeNonApprovedDrugs = false;
public degreeIncludeViralNonSeeds = true;
public degreeMaxDeg = 0;
public degreeResultSize = 20;
// Network proximity
public proximityIncludeNonApprovedDrugs = false;
public proximityMaxDeg = 0;
public proximityHubPenalty = 0.0;
public proximityResultSize = 20;
// Betweenness Parameters
public betweennessIncludeViralNonSeeds = true;
public betweennessMaxDeg = 0;
public betweennessHubPenalty = 0.0;
public betweennessResultSize = 20;
// Keypathwayminer Parameters
public keypathwayminerK = 5;
// Multisteiner Parameters
public multisteinerNumTrees = 5;
public multisteinerTolerance = 10;
public multisteinerIncludeViralNonSeeds = true;
public multisteinerMaxDeg = 0;
public multisteinerHubPenalty = 0.0;
public maxTasks = MAX_TASKS;
constructor(public analysis: AnalysisService) {
}
ngOnInit(): void {
}
ngOnChanges(changes: SimpleChanges): void {
if (this.target === 'drug-target') {
this.algorithms = [MULTISTEINER, KEYPATHWAYMINER, TRUSTRANK, CLOSENESS_CENTRALITY, DEGREE_CENTRALITY, BETWEENNESS_CENTRALITY];
this.algorithm = MULTISTEINER.slug;
} else if (this.target === 'drug') {
this.algorithms = [TRUSTRANK, CLOSENESS_CENTRALITY, DEGREE_CENTRALITY, NETWORK_PROXIMITY];
this.algorithm = TRUSTRANK.slug;
}
}
public close() {
this.show = false;
this.showChange.emit(this.show);
}
public async startTask() {
// all nodes in selection have netexId, hence exist in the backend
const seeds = this.analysis.getSelection().map((item) => item.data.netexId)
const seedsFiltered = seeds.filter(function (el) {
return el != null;
});
const parameters: any = {
seeds: seedsFiltered,
config: this.config,
input_network: this.inputNetwork
};
parameters.ppi_dataset = this.config.interactionProteinProtein;
parameters.pdi_dataset = this.config.interactionDrugProtein;
parameters.target = this.target === 'drug' ? 'drug' : 'drug-target';
// pass network data to reconstruct network in analysis result to connect non-proteins to results
// drop interactions in nodes beforehand to no cause cyclic error, information is contained in edges
// this.inputNetwork.nodes.forEach(node => {
// delete node.interactions
// });
if (this.algorithm === 'trustrank') {
parameters.damping_factor = this.trustrankDampingFactor;
parameters.include_indirect_drugs = this.trustrankIncludeIndirectDrugs;
parameters.include_non_approved_drugs = this.trustrankIncludeNonApprovedDrugs;
parameters.ignore_non_seed_baits = !this.trustrankIncludeViralNonSeeds;
if (this.trustrankMaxDeg && this.trustrankMaxDeg > 0) {
parameters.max_deg = this.trustrankMaxDeg;
}
parameters.hub_penalty = this.trustrankHubPenalty;
parameters.result_size = this.trustrankResultSize;
} else if (this.algorithm === 'closeness') {
parameters.include_indirect_drugs = this.closenessIncludeIndirectDrugs;
parameters.include_non_approved_drugs = this.closenessIncludeNonApprovedDrugs;
parameters.ignore_non_seed_baits = !this.closenessIncludeViralNonSeeds;
if (this.closenessMaxDeg && this.closenessMaxDeg > 0) {
parameters.max_deg = this.closenessMaxDeg;
}
parameters.hub_penalty = this.closenessHubPenalty;
parameters.result_size = this.closenessResultSize;
} else if (this.algorithm === 'degree') {
parameters.include_non_approved_drugs = this.degreeIncludeNonApprovedDrugs;
parameters.ignore_non_seed_baits = !this.degreeIncludeViralNonSeeds;
if (this.degreeMaxDeg && this.degreeMaxDeg > 0) {
parameters.max_deg = this.degreeMaxDeg;
}
parameters.result_size = this.degreeResultSize;
} else if (this.algorithm === 'proximity') {
parameters.include_non_approved_drugs = this.proximityIncludeNonApprovedDrugs;
if (this.proximityMaxDeg && this.proximityMaxDeg > 0) {
parameters.max_deg = this.proximityMaxDeg;
}
parameters.hub_penalty = this.proximityHubPenalty;
parameters.result_size = this.proximityResultSize;
} else if (this.algorithm === 'betweenness') {
parameters.ignore_non_seed_baits = !this.betweennessIncludeViralNonSeeds;
if (this.betweennessMaxDeg && this.betweennessMaxDeg > 0) {
parameters.max_deg = this.betweennessMaxDeg;
}
parameters.hub_penalty = this.betweennessHubPenalty;
parameters.result_size = this.betweennessResultSize;
} else if (this.algorithm === 'keypathwayminer') {
parameters.k = this.keypathwayminerK;
} else if (this.algorithm === 'multisteiner') {
parameters.num_trees = this.multisteinerNumTrees;
parameters.tolerance = this.multisteinerTolerance;
parameters.ignore_non_seed_baits = !this.multisteinerIncludeViralNonSeeds;
if (this.multisteinerMaxDeg && this.multisteinerMaxDeg > 0) {
parameters.max_deg = this.multisteinerMaxDeg;
}
parameters.hub_penalty = this.multisteinerHubPenalty;
}
const token = await this.analysis.startAnalysis(this.algorithm, this.target, parameters);
const object = {taskId: token, algorithm: this.algorithm, target: this.target, params: parameters};
this.taskEvent.emit(object);
}
}