All Downloads are FREE. Search and download functionalities are using the official Maven repository.

dev.ikm.reasoner.hybrid.snomed.AbsentSubsumption Maven / Gradle / Ivy

package dev.ikm.reasoner.hybrid.snomed;

/*-
 * #%L
 * ELK Integration with SNOMED
 * %%
 * Copyright (C) 2023 - 2024 Integrated Knowledge Management
 * %%
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * #L%
 */

import java.util.HashMap;
import java.util.Set;

import dev.ikm.elk.snomed.DefiningSubsumption;
import dev.ikm.elk.snomed.SnomedIsa;
import dev.ikm.elk.snomed.SnomedOntology;
import dev.ikm.elk.snomed.model.Concept;
import dev.ikm.elk.snomed.model.Definition;
import dev.ikm.elk.snomed.model.Role;
import dev.ikm.elk.snomed.model.RoleGroup;
import dev.ikm.elk.snomed.model.RoleType;
import dev.ikm.reasoner.hybrid.snomed.StatementSnomedOntology.SwecIds;

public class AbsentSubsumption extends DefiningSubsumption {

	private SwecIds swecIds;

	public static boolean hasAbsentSnomed(Set roles) {
		return new AbsentSubsumption().hasAbsent(roles);
	}

	public boolean hasAbsent(Set roles) {
		return roles.stream().anyMatch(x -> x.getRoleType().getId() == swecIds.findingContext()
				&& x.getConcept().getId() == swecIds.knownAbsent());
	}

	public static boolean hasAbsentSnomed(RoleGroup rg) {
		return new AbsentSubsumption().hasAbsent(rg);
	}

	public boolean hasAbsent(RoleGroup rg) {
		return hasAbsent(rg.getRoles());
	}

	public static boolean hasUngroupedAbsentSnomed(Concept con) {
		return con.getDefinitions().stream()
				.anyMatch(def -> AbsentSubsumption.hasAbsentSnomed(def.getUngroupedRoles()));
	}

	public static boolean hasGroupedAbsentSnomed(Concept con) {
		return con.getDefinitions().stream().flatMap(def -> def.getRoleGroups().stream())
				.anyMatch(rg -> AbsentSubsumption.hasAbsentSnomed(rg));
	}

	private AbsentSubsumption() {
		super(null, null, null, null, null);
		this.swecIds = StatementSnomedOntology.swec_sctids;
	}

	public AbsentSubsumption(SnomedOntology ontology, SnomedIsa definingIsa, SnomedIsa isa,
			HashMap> superRoles, HashMap necessaryNormalForm,
			SwecIds swecIds) {
		super(ontology, definingIsa, isa, superRoles, necessaryNormalForm);
		this.swecIds = swecIds;
	}

	public AbsentSubsumption(SnomedOntology ontology, SnomedIsa definingIsa, SnomedIsa isa,
			HashMap> superRoles, HashMap necessaryNormalForm) {
		super(ontology, definingIsa, isa, superRoles, necessaryNormalForm);
		this.swecIds = StatementSnomedOntology.swec_sctids;
	}

	@Override
	protected boolean isSubsumedBy(RoleGroup rg1, RoleGroup rg2) {
		if (hasAbsent(rg1) && hasAbsent(rg2))
			return super.isSubsumedBy(rg2, rg1);
		return super.isSubsumedBy(rg1, rg2);
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy