@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> .
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
@prefix rdf4j: <http://rdf4j.org/schema/rdf4j#> .
@prefix sesame: <http://www.openrdf.org/schema/sesame#> .
@prefix owl: <http://www.w3.org/2002/07/owl#> .
@prefix xsd: <http://www.w3.org/2001/XMLSchema#> .
@prefix fn: <http://www.w3.org/2005/xpath-functions#> .

<http://purl.uniprot.org/unirules/MF_01048#construct> a <http://www.w3.org/ns/shacl#SPARQLRule>,
    <http://spinrdf.org/sp#Construct>;
  <https://hamap.expasy.org/rdf/vocab#addsTriple> <http://purl.uniprot.org/unirules/MF_01048#construct-template-10>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-29>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-16>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-18>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-20>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-33>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-5>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-30>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-26>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-7>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-11>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-40>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-6>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-2>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-41>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-0>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-3>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-35>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-24>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-25>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-22>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-9>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-4>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-14>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-8>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-12>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-28>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-27>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-36>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-19>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-31>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-21>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-23>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-38>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-17>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-15>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-32>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-13>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-34>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-1>, <http://purl.uniprot.org/unirules/MF_01048#construct-template-39>,
    <http://purl.uniprot.org/unirules/MF_01048#construct-template-37>;
  <http://www.w3.org/ns/shacl#prefixes> <http://purl.uniprot.org/unirules/>;
  <http://spinrdf.org/sp#where> <http://purl.uniprot.org/unirules/MF_01048#construct-where-list-0>;
  <http://spinrdf.org/sp#templates> <http://purl.uniprot.org/unirules/MF_01048#construct-template-list-0>;
  <http://www.w3.org/ns/shacl#construct> """CONSTRUCT {
  _:368338 up:source unirule:MF_01048 .
  _:368339 up:source unirule:MF_01048 .
  _:368340 up:source unirule:MF_01048 .
  _:368341 up:source unirule:MF_01048 .
  _:368342 up:source unirule:MF_01048 .
  _:368343 up:source unirule:MF_01048 .
  _:368344 up:source unirule:MF_01048 .
  _:368345 up:source unirule:MF_01048 .
  _:368346 up:source unirule:MF_01048 .
  _:368347 up:source unirule:MF_01048 .
  _:368348 up:source unirule:MF_01048 .
  ?this up:annotation ?annotation1 ;
    up:classifiedWith GO:0005886 ,
      keyword:1003 ,
      keyword:1133 ,
      keyword:472 ,
      keyword:812 .
  ?gene0 skos:prefLabel 'psiE' .
  ?annotation1 a up:Similarity_Annotation ;
    rdfs:comment 'Belongs to the PsiE family.' .
  ?case2 up:classifiedWith keyword:997 .
  ?sam6 up:classifiedWith keyword:1133 ,
      keyword:472 ,
      keyword:812 .
  ?transmembrane7 faldo:begin ?transmembraneb8 ;
    faldo:end ?transmembranee9 .
  ?transmembraneb8 faldo:position ?transmembranebp10 .
  ?transmembranee9 faldo:position ?transmembraneep11 .
  ?keyword12 up:range ?transmembrane7 .
  ?keyword13 up:range ?transmembrane7 .
  ?keyword14 up:range ?transmembrane7 .
  _:368349 a rdf:Statement ;
    up:attribution _:368338 ;
    rdf:subject ?gene0 ;
    rdf:predicate up:encodedBy ;
    rdf:object ?gene0 .
  _:368350 a rdf:Statement ;
    up:attribution _:368339 ;
    rdf:subject ?this ;
    rdf:predicate up:annotation ;
    rdf:object ?annotation1 .
  _:368351 a rdf:Statement ;
    up:attribution _:368340 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1003 .
  _:368352 a rdf:Statement ;
    up:attribution _:368341 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:472 .
  _:368353 a rdf:Statement ;
    up:attribution _:368342 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:812 .
  _:368354 a rdf:Statement ;
    up:attribution _:368343 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1133 .
  _:368355 a rdf:Statement ;
    up:attribution _:368344 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object GO:0005886 .
  _:368356 a rdf:Statement ;
    up:attribution _:368345 ;
    rdf:subject ?case2 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:997 .
  _:368357 a rdf:Statement ;
    up:attribution _:368346 ;
    rdf:subject ?sam6 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:472 .
  _:368358 a rdf:Statement ;
    up:attribution _:368347 ;
    rdf:subject ?sam6 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:812 .
  _:368359 a rdf:Statement ;
    up:attribution _:368348 ;
    rdf:subject ?sam6 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1133 .
}
WHERE {
  #baseURI: http://purl.uniprot.org/unirule/MF_01048
  #Rule MF_01048 Created by:? on:2005-02-28 Modified by:Edouard de Castro on:2019-11-19
  ?this up:organism ?thisOrganism ;
    rdfs:seeAlso signature:MF_01048 .
  ?thisOrganism rdfs:subClassOf+ taxon:2 .
  BIND(URI(CONCAT(STR(?this), '#MF_01048a1')) AS ?annotation1) .
  OPTIONAL {
    ?this a up:Protein .
    {
      ?this up:proteome <http://purl.uniprot.org/proteomes/Membrane#2>.
    } UNION {
      ?this up:proteome ?p15 .
      ?p15 skos:narrower <http://purl.uniprot.org/proteomes/Membrane#2>.
    }
    BIND(?this AS ?case2) .
  }
  OPTIONAL {
    ?this a up:Protein .
    {
      FILTER (! (EXISTS {
        {
          ?this up:proteome <http://purl.uniprot.org/proteomes/Membrane#any>.
        } UNION {
          ?this up:proteome ?p16 .
          ?p16 skos:narrower <http://purl.uniprot.org/proteomes/Membrane#any>.
        }
      })) .
    } UNION {
      {
        ?this up:proteome <http://purl.uniprot.org/proteomes/Membrane#1>.
      } UNION {
        ?this up:proteome ?p17 .
        ?p17 skos:narrower <http://purl.uniprot.org/proteomes/Membrane#1>.
      }
    }
    BIND(?this AS ?case3) .
  }
  OPTIONAL {
    ?this a up:Protein .
    VALUES ?supertaxon18 {taxon:561 taxon:620 taxon:590}
    ?this up:organism ?thisOrganism .
    ?thisOrganism rdfs:subClassOf+ ?supertaxon18 .
    BIND(?this AS ?case4) .
  }
  OPTIONAL {
    ?this a up:Protein .
    ?this up:organism ?thisOrganism .
    FILTER (! (EXISTS {
      VALUES ?supertaxon19 {taxon:561 taxon:620 taxon:590}
      ?thisOrganism rdfs:subClassOf+ ?supertaxon19 .
    })) .
    BIND(?this AS ?case5) .
  }
  OPTIONAL {
    ?this up:annotation ?samtransmembrane20 ;
      up:sequence ?thisSequence .
    ?samtransmembrane20 up:range ?samtransmembraner21 ;
      rdf:type up:Transmembrane_Annotation .
    ?samtransmembraner21 faldo:begin ?samtransmembraneb22 ;
      faldo:end ?samtransmembranee23 .
    ?samtransmembraneb22 faldo:position ?samtransmembranebp24 ;
      faldo:reference ?thisSequence .
    ?samtransmembranee23 faldo:position ?samtransmembraneep25 ;
      faldo:reference ?thisSequence .
    BIND(?this AS ?sam6) .
  }
  BIND(URI(CONCAT(STR(?this), '#MF_01048a12')) AS ?keyword12) .
  BIND(URI(CONCAT(STR(?this), '#MF_01048a13')) AS ?keyword13) .
  BIND(URI(CONCAT(STR(?this), '#MF_01048a14')) AS ?keyword14) .
}
""" .

<http://purl.uniprot.org/unirules/MF_01048> <http://www.w3.org/ns/shacl#rule> <http://purl.uniprot.org/unirules/MF_01048#construct> .
