@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_01101#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_01101#construct-template-25>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-19>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-18>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-26>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-20>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-27>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-0>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-23>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-36>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-24>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-29>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-22>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-14>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-9>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-4>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-28>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-6>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-2>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-17>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-38>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-16>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-21>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-7>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-31>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-13>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-12>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-15>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-10>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-1>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-32>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-5>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-34>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-11>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-3>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-8>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-37>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-35>,
    <http://purl.uniprot.org/unirules/MF_01101#construct-template-30>, <http://purl.uniprot.org/unirules/MF_01101#construct-template-33>;
  <http://www.w3.org/ns/shacl#prefixes> <http://purl.uniprot.org/unirules/>;
  <http://spinrdf.org/sp#where> <http://purl.uniprot.org/unirules/MF_01101#construct-where-list-0>;
  <http://spinrdf.org/sp#templates> <http://purl.uniprot.org/unirules/MF_01101#construct-template-list-0>;
  <http://www.w3.org/ns/shacl#construct> """CONSTRUCT {
  _:382517 up:source unirule:MF_01101 .
  _:382518 up:source unirule:MF_01101 .
  _:382519 up:source unirule:MF_01101 .
  _:382520 up:source unirule:MF_01101 .
  _:382521 up:source unirule:MF_01101 .
  _:382522 up:source unirule:MF_01101 .
  _:382523 up:source unirule:MF_01101 .
  _:382524 up:source unirule:MF_01101 .
  _:382525 up:source unirule:MF_01101 .
  _:382526 up:source unirule:MF_01101 .
  ?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 UPF0208 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 .
  _:382527 a rdf:Statement ;
    up:attribution _:382517 ;
    rdf:subject ?this ;
    rdf:predicate up:annotation ;
    rdf:object ?annotation0 .
  _:382528 a rdf:Statement ;
    up:attribution _:382518 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1003 .
  _:382529 a rdf:Statement ;
    up:attribution _:382519 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:472 .
  _:382530 a rdf:Statement ;
    up:attribution _:382520 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:812 .
  _:382531 a rdf:Statement ;
    up:attribution _:382521 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1133 .
  _:382532 a rdf:Statement ;
    up:attribution _:382522 ;
    rdf:subject ?this ;
    rdf:predicate up:classifiedWith ;
    rdf:object GO:0005886 .
  _:382533 a rdf:Statement ;
    up:attribution _:382523 ;
    rdf:subject ?case1 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:997 .
  _:382534 a rdf:Statement ;
    up:attribution _:382524 ;
    rdf:subject ?sam5 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:472 .
  _:382535 a rdf:Statement ;
    up:attribution _:382525 ;
    rdf:subject ?sam5 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:812 .
  _:382536 a rdf:Statement ;
    up:attribution _:382526 ;
    rdf:subject ?sam5 ;
    rdf:predicate up:classifiedWith ;
    rdf:object keyword:1133 .
}
WHERE {
  #baseURI: http://purl.uniprot.org/unirule/MF_01101
  #Rule MF_01101 Created by:? on:2005-02-28 Modified by:Edouard de Castro on:2019-11-19
  ?this up:organism ?thisOrganism ;
    rdfs:seeAlso signature:MF_01101 .
  ?thisOrganism rdfs:subClassOf+ taxon:1236 .
  BIND(URI(CONCAT(STR(?this), '#MF_01101a0')) 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_01101a11')) AS ?keyword11) .
  BIND(URI(CONCAT(STR(?this), '#MF_01101a12')) AS ?keyword12) .
  BIND(URI(CONCAT(STR(?this), '#MF_01101a13')) AS ?keyword13) .
}
""" .

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