@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_01071#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_01071#construct-template-21>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-6>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-2>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-17>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-3>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-13>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-24>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-25>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-19>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-14>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-26>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-4>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-5>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-12>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-8>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-11>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-18>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-1>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-0>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-20>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-22>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-23>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-7>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-31>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-30>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-33>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-32>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-16>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-35>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-10>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-34>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-38>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-37>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-9>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-36>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-15>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-28>,
    <http://purl.uniprot.org/unirules/MF_01071#construct-template-27>, <http://purl.uniprot.org/unirules/MF_01071#construct-template-29>;
  <http://www.w3.org/ns/shacl#prefixes> <http://purl.uniprot.org/unirules/>;
  <http://spinrdf.org/sp#where> <http://purl.uniprot.org/unirules/MF_01071#construct-where-list-0>;
  <http://spinrdf.org/sp#templates> <http://purl.uniprot.org/unirules/MF_01071#construct-template-list-0>;
  <http://www.w3.org/ns/shacl#construct> """CONSTRUCT {
  _:374197 up:source unirule:MF_01071 .
  _:374198 up:source unirule:MF_01071 .
  _:374199 up:source unirule:MF_01071 .
  _:374200 up:source unirule:MF_01071 .
  _:374201 up:source unirule:MF_01071 .
  _:374202 up:source unirule:MF_01071 .
  _:374203 up:source unirule:MF_01071 .
  _:374204 up:source unirule:MF_01071 .
  _:374205 up:source unirule:MF_01071 .
  _:374206 up:source unirule:MF_01071 .
  ?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 UPF0266 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 .
  _:374207 a rdf:Statement ;
    up:attribution _:374197 ;
    rdf:subject ?this ;
    rdf:predicate up:annotation ;
    rdf:object ?annotation0 .
  _:374208 a rdf:Statement ;
    up:attribution _:374198 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1003 .
  _:374209 a rdf:Statement ;
    up:attribution _:374199 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:472 .
  _:374210 a rdf:Statement ;
    up:attribution _:374200 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:812 .
  _:374211 a rdf:Statement ;
    up:attribution _:374201 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1133 .
  _:374212 a rdf:Statement ;
    up:attribution _:374202 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object GO:0005886 .
  _:374213 a rdf:Statement ;
    up:attribution _:374203 ;
    rdf:subject ?case1 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:997 .
  _:374214 a rdf:Statement ;
    up:attribution _:374204 ;
    rdf:subject ?sam5 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:472 .
  _:374215 a rdf:Statement ;
    up:attribution _:374205 ;
    rdf:subject ?sam5 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:812 .
  _:374216 a rdf:Statement ;
    up:attribution _:374206 ;
    rdf:subject ?sam5 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1133 .
}
WHERE {
  #baseURI: http://purl.uniprot.org/unirule/MF_01071
  #Rule MF_01071 Created by:? on:2005-02-28 Modified by:Edouard de Castro on:2019-11-19
  VALUES ?supertaxon14 {taxon:186820 taxon:1236}
  ?this up:organism ?thisOrganism ;
    rdfs:seeAlso signature:MF_01071 .
  ?thisOrganism rdfs:subClassOf+ ?supertaxon14 .
  BIND(URI(CONCAT(STR(?this), '#MF_01071a0')) AS ?annotation0) .
  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 ?case1) .
  }
  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 ?case2) .
  }
  OPTIONAL {
    ?this a up:Protein .
    VALUES ?supertaxon18 {taxon:561 taxon:620 taxon:590}
    ?this up:organism ?thisOrganism .
    ?thisOrganism rdfs:subClassOf+ ?supertaxon18 .
    BIND(?this AS ?case3) .
  }
  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 ?case4) .
  }
  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 ?sam5) .
  }
  BIND(URI(CONCAT(STR(?this), '#MF_01071a11')) AS ?keyword11) .
  BIND(URI(CONCAT(STR(?this), '#MF_01071a12')) AS ?keyword12) .
  BIND(URI(CONCAT(STR(?this), '#MF_01071a13')) AS ?keyword13) .
}
""" .

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