Ejemplo n.º 1
0
        /// <summary>
        /// Enlists the facts/literals which are directly (or indirectly, if inference is requested) members of the lens class
        /// </summary>
        public List <(bool, RDFOntologyResource)> Members(bool enableInference)
        {
            List <(bool, RDFOntologyResource)> result = new List <(bool, RDFOntologyResource)>();

            //First-level enlisting of members (datatype class)
            if (RDFOntologyHelper.CheckIsLiteralCompatibleClass(this.Ontology.Model.ClassModel, this.OntologyClass))
            {
                IEnumerable <RDFOntologyLiteral> ontlits = this.Ontology.Data.Literals.Values.Where(ol => ol.Value is RDFTypedLiteral);
                foreach (RDFOntologyLiteral ontlit in ontlits.Where(ol => RDFModelUtilities.GetDatatypeFromEnum(((RDFTypedLiteral)ol.Value).Datatype).Equals(this.OntologyClass.ToString())))
                {
                    if (!result.Any(ol => ol.Equals(ontlit)))
                    {
                        result.Add((false, ontlit));
                    }
                }
            }
            //First-level enlisting of members (object class)
            else
            {
                foreach (RDFOntologyTaxonomyEntry sf in this.Ontology.Data.Relations.ClassType.SelectEntriesByObject(this.OntologyClass).Where(te => !te.IsInference()))
                {
                    result.Add((false, sf.TaxonomySubject));
                }
            }

            //Inference-enabled discovery of members
            if (enableInference)
            {
                RDFOntologyData members = RDFOntologyHelper.GetMembersOf(this.Ontology, this.OntologyClass);
                foreach (RDFOntologyFact fact in members)
                {
                    if (!result.Any(f => f.Item2.Equals(fact)))
                    {
                        result.Add((true, fact));
                    }
                }
                foreach (RDFOntologyLiteral literal in members.Literals.Values)
                {
                    if (!result.Any(f => f.Item2.Equals(literal)))
                    {
                        result.Add((true, literal));
                    }
                }
            }

            return(result);
        }
        /// <summary>
        /// Enlists the classes to which the lens fact directly (or indirectly, if inference is requested) belongs
        /// </summary>
        public List <(bool, RDFOntologyClass)> ClassTypes(bool enableInference)
        {
            List <(bool, RDFOntologyClass)> result = new List <(bool, RDFOntologyClass)>();

            //First-level enlisting of class types
            foreach (RDFOntologyTaxonomyEntry sf in this.Ontology.Data.Relations.ClassType.SelectEntriesBySubject(this.OntologyFact).Where(te => !te.IsInference()))
            {
                result.Add((false, (RDFOntologyClass)sf.TaxonomyObject));
            }

            //Inference-enabled discovery of class types
            if (enableInference)
            {
                //Skip already enlisted classes and also reserved/literal-compatible classes
                var availableclasses = this.Ontology.Model.ClassModel.Where(cls => !result.Any(res => res.Item2.Equals(cls)) &&
                                                                            !RDFOntologyChecker.CheckReservedClass(cls) &&
                                                                            !RDFOntologyHelper.CheckIsLiteralCompatibleClass(this.Ontology.Model.ClassModel, cls));
                var membersCache = new Dictionary <long, RDFOntologyData>();

                //Evaluate enumerations
                foreach (var e in availableclasses.Where(cls => cls.IsEnumerateClass()))
                {
                    if (!membersCache.ContainsKey(e.PatternMemberID))
                    {
                        membersCache.Add(e.PatternMemberID, this.Ontology.GetMembersOfEnumerate((RDFOntologyEnumerateClass)e));
                    }

                    if (membersCache[e.PatternMemberID].Facts.ContainsKey(this.OntologyFact.PatternMemberID))
                    {
                        result.Add((true, e));
                    }
                }

                //Evaluate restrictions
                foreach (var r in availableclasses.Where(cls => cls.IsRestrictionClass()))
                {
                    if (!membersCache.ContainsKey(r.PatternMemberID))
                    {
                        membersCache.Add(r.PatternMemberID, this.Ontology.GetMembersOfRestriction((RDFOntologyRestriction)r));
                    }

                    if (membersCache[r.PatternMemberID].Facts.ContainsKey(this.OntologyFact.PatternMemberID))
                    {
                        result.Add((true, r));
                    }
                }

                //Evaluate simple classes
                foreach (var c in availableclasses.Where(cls => cls.IsSimpleClass()))
                {
                    if (!membersCache.ContainsKey(c.PatternMemberID))
                    {
                        membersCache.Add(c.PatternMemberID, this.Ontology.GetMembersOfClass(c));
                    }

                    if (membersCache[c.PatternMemberID].Facts.ContainsKey(this.OntologyFact.PatternMemberID))
                    {
                        result.Add((true, c));
                    }
                }

                //Evaluate composite classes
                foreach (var c in availableclasses.Where(cls => cls.IsCompositeClass()))
                {
                    if (!membersCache.ContainsKey(c.PatternMemberID))
                    {
                        membersCache.Add(c.PatternMemberID, this.Ontology.GetMembersOfComposite(c, membersCache));
                    }

                    if (membersCache[c.PatternMemberID].Facts.ContainsKey(this.OntologyFact.PatternMemberID))
                    {
                        result.Add((true, c));
                    }
                }
            }

            return(result);
        }