You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@jena.apache.org by "Stian Soiland-Reyes (JIRA)" <ji...@apache.org> on 2015/09/13 04:51:45 UTC

[jira] [Commented] (JENA-1026) listIndividuals performance issue

    [ https://issues.apache.org/jira/browse/JENA-1026?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=14742305#comment-14742305 ] 

Stian Soiland-Reyes commented on JENA-1026:
-------------------------------------------

Number of individuals does not matter, with just one individual it still takes ~ 25 seconds.

Even a very significantly shrinked ontology (not-much-food.ttl) takes 10 seconds in ListIndividuals.





> listIndividuals performance issue
> ---------------------------------
>
>                 Key: JENA-1026
>                 URL: https://issues.apache.org/jira/browse/JENA-1026
>             Project: Apache Jena
>          Issue Type: Bug
>          Components: Ontology API
>    Affects Versions: Jena 3.0.0
>         Environment: Verified on Jena 3.0.1-SNAPSHOT (2015-09-13) w/ Ubuntu 14.04/x64, 4 cores i7-3520M, 16G ram, SSD disk, Open JDK 1.8.0_45-internal
>            Reporter: Stian Soiland-Reyes
>            Priority: Minor
>         Attachments: OntologiaDeAlimentos.owl, not-much-food.ttl
>
>
> As reported by Maria Clementina Latanzi on dev@jena 2015-09-12:
> {quote}
> I'm working with Jena. I have an ontology with no more than 50 individuals,
> and I use Jena to
> get individuals from Ontology by calling *listIndividual* (
> *com.hp.hpl.jena.ontology.OntModel.listIndividuals*). When I call this
> method, it's taking a lot of time up to 20 seconds. When debugging, it
> takes more than 1 minute to return. Other methods like *listClass *return
> instantly.
> {quote}
> {code}
> package testOnto;
> import java.io.InputStream;
> import java.util.ArrayList;
> import java.util.Iterator;
> import com.hp.hpl.jena.ontology.Individual;
> import com.hp.hpl.jena.ontology.OntClass;
> import com.hp.hpl.jena.ontology.OntModel;
> import com.hp.hpl.jena.rdf.model.ModelFactory;
> import com.hp.hpl.jena.rdf.model.Resource;
> import com.hp.hpl.jena.rdf.model.Property;
> import com.hp.hpl.jena.rdf.model.StmtIterator;
> import com.hp.hpl.jena.rdf.model.impl.StatementImpl;
> import com.hp.hpl.jena.shared.JenaException;
> import com.hp.hpl.jena.util.FileManager;
> import com.hp.hpl.jena.util.iterator.ExtendedIterator;
> public class onto {
> 	static String Ontofile =
> "C:/Users/Sig/Clemen/OntologiasArchivos/OntologiaIngesta.owl";
> 	public static void main(String[] args) {
> 		//crea ontologia
> 		OntModel m = ModelFactory.createOntologyModel();
> 		try {
> 			InputStream in =
> FileManager.get().open("C:/Users/Sig/Clemen/OntologiasArchivos/OntologiaDeAlimentos.owl");
>             if (in ==null) {
>             	System.out.println("ERROR abriendo archivo" + Ontofile);
>             	return;
>             	}
>             else {  m.read(in, "RDF/XML");
>                	System.out.println("archivo" + Ontofile + "leido
> exitosamente" );
>             	}
>         } catch (JenaException je) {
>         	System.out.println("ERROR leyendo archivo" + je.getMessage());
>             je.printStackTrace();
>             System.exit(0);
>         }
> 				long startMilC = System.currentTimeMillis();
>         System.out.println("Start list classes: " + startMilC);
>         ExtendedIterator classes = m.listClasses();
>         long endMilC = System.currentTimeMillis();
>         System.out.println("Duration ListIndividuals: " + (endMilC -
> startMilC));
>             long startMil = System.currentTimeMillis();
>         System.out.println("Start ListIndividuals: " + startMil);
>         ExtendedIterator individuos = m.listIndividuals();
>                  long endMil = System.currentTimeMillis();
>         System.out.println("Duration ListIndividuals: " + (endMil -
> startMil));
> 	}
> }
> {code}
> See attached ontology and test case.
> Verified against current 3.0.1-SNAPSHOT.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)