@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_01067#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_01067#construct-template-3>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-4>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-6>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-5>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-1>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-18>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-17>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-16>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-15>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-2>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-0>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-19>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-10>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-34>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-33>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-32>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-31>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-14>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-38>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-13>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-37>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-12>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-36>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-11>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-35>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-9>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-30>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-29>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-28>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-27>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-22>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-21>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-7>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-20>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-8>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-26>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-25>,
    <http://purl.uniprot.org/unirules/MF_01067#construct-template-24>, <http://purl.uniprot.org/unirules/MF_01067#construct-template-23>;
  <http://www.w3.org/ns/shacl#prefixes> <http://purl.uniprot.org/unirules/>;
  <http://spinrdf.org/sp#where> <http://purl.uniprot.org/unirules/MF_01067#construct-where-list-0>;
  <http://spinrdf.org/sp#templates> <http://purl.uniprot.org/unirules/MF_01067#construct-template-list-0>;
  <http://www.w3.org/ns/shacl#construct> """CONSTRUCT {
  _:373171 up:source unirule:MF_01067 .
  _:373172 up:source unirule:MF_01067 .
  _:373173 up:source unirule:MF_01067 .
  _:373174 up:source unirule:MF_01067 .
  _:373175 up:source unirule:MF_01067 .
  _:373176 up:source unirule:MF_01067 .
  _:373177 up:source unirule:MF_01067 .
  _:373178 up:source unirule:MF_01067 .
  _:373179 up:source unirule:MF_01067 .
  _:373180 up:source unirule:MF_01067 .
  ?this up:annotation ?annotation0 ;
    up:classifiedWith GO:0005886 ,
      keyword:1003 ,
      keyword:1133 ,
      keyword:472 ,
      keyword:812 .
  ?annotation0 a up:Similarity_Annotation ;
    rdfs:comment 'Belongs to the UPF0259 family.' .
  ?case1 up:classifiedWith keyword:997 .
  ?sam5 up:classifiedWith keyword:1133 ,
      keyword:472 ,
      keyword:812 .
  ?transmembrane6 faldo:begin ?transmembraneb7 ;
    faldo:end ?transmembranee8 .
  ?transmembraneb7 faldo:position ?transmembranebp9 .
  ?transmembranee8 faldo:position ?transmembraneep10 .
  ?keyword11 up:range ?transmembrane6 .
  ?keyword12 up:range ?transmembrane6 .
  ?keyword13 up:range ?transmembrane6 .
  _:373181 a rdf:Statement ;
    up:attribution _:373171 ;
    rdf:subject ?this ;
    rdf:predicate up:annotation ;
    rdf:object ?annotation0 .
  _:373182 a rdf:Statement ;
    up:attribution _:373172 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1003 .
  _:373183 a rdf:Statement ;
    up:attribution _:373173 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:472 .
  _:373184 a rdf:Statement ;
    up:attribution _:373174 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:812 .
  _:373185 a rdf:Statement ;
    up:attribution _:373175 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1133 .
  _:373186 a rdf:Statement ;
    up:attribution _:373176 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object GO:0005886 .
  _:373187 a rdf:Statement ;
    up:attribution _:373177 ;
    rdf:subject ?case1 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:997 .
  _:373188 a rdf:Statement ;
    up:attribution _:373178 ;
    rdf:subject ?sam5 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:472 .
  _:373189 a rdf:Statement ;
    up:attribution _:373179 ;
    rdf:subject ?sam5 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:812 .
  _:373190 a rdf:Statement ;
    up:attribution _:373180 ;
    rdf:subject ?sam5 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1133 .
}
WHERE {
  #baseURI: http://purl.uniprot.org/unirule/MF_01067
  #Rule MF_01067 Created by:? on:2005-02-28 Modified by:Edouard de Castro on:2019-11-19
  ?this up:organism ?thisOrganism ;
    rdfs:seeAlso signature:MF_01067 .
  ?thisOrganism rdfs:subClassOf+ taxon:91347 .
  BIND(URI(CONCAT(STR(?this), '#MF_01067a0')) AS ?annotation0) .
  OPTIONAL {
    ?this a up:Protein .
    {
      ?this up:proteome <http://purl.uniprot.org/proteomes/Membrane#2>.
    } UNION {
      ?this up:proteome ?p14 .
      ?p14 skos:narrower <http://purl.uniprot.org/proteomes/Membrane#2>.
    }
    BIND(?this AS ?case1) .
  }
  OPTIONAL {
    ?this a up:Protein .
    {
      FILTER (! (EXISTS {
        {
          ?this up:proteome <http://purl.uniprot.org/proteomes/Membrane#any>.
        } UNION {
          ?this up:proteome ?p15 .
          ?p15 skos:narrower <http://purl.uniprot.org/proteomes/Membrane#any>.
        }
      })) .
    } UNION {
      {
        ?this up:proteome <http://purl.uniprot.org/proteomes/Membrane#1>.
      } UNION {
        ?this up:proteome ?p16 .
        ?p16 skos:narrower <http://purl.uniprot.org/proteomes/Membrane#1>.
      }
    }
    BIND(?this AS ?case2) .
  }
  OPTIONAL {
    ?this a up:Protein .
    VALUES ?supertaxon17 {taxon:561 taxon:620 taxon:590}
    ?this up:organism ?thisOrganism .
    ?thisOrganism rdfs:subClassOf+ ?supertaxon17 .
    BIND(?this AS ?case3) .
  }
  OPTIONAL {
    ?this a up:Protein .
    ?this up:organism ?thisOrganism .
    FILTER (! (EXISTS {
      VALUES ?supertaxon18 {taxon:561 taxon:620 taxon:590}
      ?thisOrganism rdfs:subClassOf+ ?supertaxon18 .
    })) .
    BIND(?this AS ?case4) .
  }
  OPTIONAL {
    ?this up:annotation ?samtransmembrane19 ;
      up:sequence ?thisSequence .
    ?samtransmembrane19 up:range ?samtransmembraner20 ;
      rdf:type up:Transmembrane_Annotation .
    ?samtransmembraner20 faldo:begin ?samtransmembraneb21 ;
      faldo:end ?samtransmembranee22 .
    ?samtransmembraneb21 faldo:position ?samtransmembranebp23 ;
      faldo:reference ?thisSequence .
    ?samtransmembranee22 faldo:position ?samtransmembraneep24 ;
      faldo:reference ?thisSequence .
    BIND(?this AS ?sam5) .
  }
  BIND(URI(CONCAT(STR(?this), '#MF_01067a11')) AS ?keyword11) .
  BIND(URI(CONCAT(STR(?this), '#MF_01067a12')) AS ?keyword12) .
  BIND(URI(CONCAT(STR(?this), '#MF_01067a13')) AS ?keyword13) .
}
""" .

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