PE_wariant_bit_table.xsl 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  3. xmlns:xs="http://www.w3.org/2001/XMLSchema"
  4. xmlns:bp="https://procesy5.pl/biale_plamy-schema.xsd"
  5. exclude-result-prefixes="xs"
  6. version="2.0">
  7. <xsl:output indent="yes"/>
  8. <xsl:strip-space elements="*"/>
  9. <!--<xsl:function name="bp:decimalToHex">
  10. <xsl:param name="dec"/>
  11. <xsl:if test="$dec > 0">
  12. <xsl:value-of
  13. select="bp:decimalToHex(floor($dec div 16)),substring('0123456789ABCDEF', (($dec mod 16) + 1), 1)"
  14. separator=""
  15. />
  16. </xsl:if>
  17. </xsl:function>-->
  18. <xsl:function name="bp:decimalToBit">
  19. <xsl:param name="dec"/>
  20. <xsl:if test="$dec &gt; 0">
  21. <xsl:value-of
  22. select="bp:decimalToBit(floor($dec div 2)),substring('01', (($dec mod 2) + 1), 1)"
  23. separator=""
  24. />
  25. </xsl:if>
  26. </xsl:function>
  27. <xsl:function name="bp:decimalToBitFill">
  28. <xsl:param name="dec" required="yes"/>
  29. <xsl:param name="len" required="yes"/>
  30. <xsl:variable name="bin" select=" string-join(bp:decimalToBit($dec),'')"/>
  31. <xsl:variable name="strlen" select="string-length($bin)"/>
  32. <xsl:variable name="brak_str" select="$len - $strlen"/>
  33. <!--<xsl:value-of select="concat(444,$strlen)"/>-->
  34. <!--<xsl:value-of select=" string($strlen)"/>-->
  35. <xsl:variable name="result">
  36. <xsl:choose>
  37. <xsl:when test="$strlen = $len">
  38. <xsl:value-of select="$bin"/>
  39. </xsl:when>
  40. <xsl:when test="$strlen &gt; $len">
  41. <xsl:value-of select="''"/>
  42. </xsl:when>
  43. <xsl:otherwise>
  44. <xsl:for-each select="1 to $brak_str ">
  45. <xsl:value-of select="0"/>
  46. </xsl:for-each>
  47. <xsl:copy-of select="$bin"/>
  48. </xsl:otherwise>
  49. </xsl:choose>
  50. </xsl:variable>
  51. <xsl:copy-of select="$result" />
  52. </xsl:function>
  53. <xsl:function name="bp:if_bit_pos">
  54. <xsl:param name="bit"/>
  55. <xsl:param name="pos"/>
  56. <xsl:value-of select=" substring($bit,number($pos),1)"/>
  57. </xsl:function>
  58. <xsl:template name="bp:next_bit_max">
  59. <xsl:param name="variant" required="yes"/>
  60. <xsl:param name="bit_limit" required="yes"/> <!-- like 6 -->
  61. <xsl:param name="max_possible_bit" required="yes"/><!-- like 1111111 -->
  62. <xsl:param name="loop" required="no"/>
  63. <!--<xsl:message>#80 f. v:<xsl:value-of select="$variant"/>;$bit_limit=<xsl:value-of select="$bit_limit"/>;$max_possible_bit=<xsl:value-of select="$max_possible_bit"/>; $loop=<xsl:value-of select="$loop"/>;</xsl:message>-->
  64. <xsl:variable name="variant" select="number($variant) + 1"/><!-- dodajemy 1 aby sprawdzic jak wyglada -->
  65. <xsl:variable name="curr_bit" select="bp:decimalToBit($variant)"/>
  66. <xsl:variable name="digits">
  67. <xsl:for-each select="1 to string-length($curr_bit)">
  68. <xsl:if test="substring($curr_bit,.,1) = '1'">
  69. <xsl:value-of select="number(1)"/>
  70. </xsl:if>
  71. </xsl:for-each>
  72. </xsl:variable>
  73. <xsl:variable name="cur_bit_len" select=" string-length($digits)"/>
  74. <xsl:choose>
  75. <xsl:when test=" string-length($max_possible_bit)&gt; string-length($curr_bit)">
  76. <xsl:value-of select=" $variant - 1 "/>
  77. </xsl:when>
  78. <xsl:when test="number($loop) &gt; 5000012">
  79. <!--<xsl:message>#91 loop:<xsl:value-of select="$loop"/>; hit returning $variant=<xsl:value-of select="$variant"/>; $curr_bit=<xsl:value-of select="$curr_bit"/>;</xsl:message>-->
  80. <xsl:value-of select="$variant"/>
  81. </xsl:when>
  82. <xsl:when test="$curr_bit = $max_possible_bit">
  83. <!--<xsl:message>#90 brak kolejnych wariantow $variant=<xsl:value-of select="$variant"/>;$bit_limit=<xsl:value-of select="$bit_limit"/>; $curr_bit=<xsl:value-of select="$curr_bit"/></xsl:message>-->
  84. <xsl:value-of select="$variant"/>
  85. </xsl:when>
  86. <xsl:when test="number($cur_bit_len) &lt;= number($bit_limit)">
  87. <!--<xsl:variable name="next_bit" select="bp:decimalToBit($variant+1)"/>-->
  88. <!--<xsl:message>#104 next <xsl:value-of select="$variant"/></xsl:message>-->
  89. <xsl:value-of select="$variant"/>
  90. </xsl:when>
  91. <xsl:when test="number($cur_bit_len) &gt; number($bit_limit)">
  92. <!--<xsl:variable name="next_bit" select="bp:decimalToBit($variant+1)"/>-->
  93. <!--<xsl:message>#104 next <xsl:value-of select="$variant"/></xsl:message>-->
  94. <xsl:call-template name="bp:next_bit_max">
  95. <xsl:with-param name="variant" select="$variant"/>
  96. <xsl:with-param name="bit_limit" select="$bit_limit"/> <!-- like 6 -->
  97. <xsl:with-param name="max_possible_bit" select="$max_possible_bit"/><!-- like 1111111 -->
  98. <xsl:with-param name="loop" select="$loop"/>
  99. </xsl:call-template>
  100. </xsl:when>
  101. <!--<xsl:otherwise>
  102. <xsl:message terminate="yes">#107 f. else $variant=<xsl:value-of select="$variant"/>; $curr_bit=<xsl:value-of select="$curr_bit"/>; $digits=<xsl:value-of select="$digits"/>;</xsl:message>
  103. <xsl:value-of select="$variant"/></xsl:otherwise>-->
  104. </xsl:choose>
  105. </xsl:template>
  106. <xsl:function name="bp:next_bit_max">
  107. <!-- for ($i = 1; $i < 1024; $i++) {
  108.         $bin = decbin($i);
  109.         $array = str_split($bin);
  110.         $sum = array_sum($array);
  111.         if ($sum <= 3) echo str_pad($bin, 10, "0", STR_PAD_LEFT) . " = " . $i . "\n";
  112. }-->
  113. <xsl:param name="variant" required="yes"/>
  114. <xsl:param name="bit_limit" required="yes"/> <!-- like 6 -->
  115. <xsl:param name="max_possible_bit" required="yes"/><!-- like 1111111 -->
  116. <xsl:param name="loop" required="no"/>
  117. <!--<xsl:message>#80 f. v:<xsl:value-of select="$variant"/>;$bit_limit=<xsl:value-of select="$bit_limit"/>;$max_possible_bit=<xsl:value-of select="$max_possible_bit"/>; $loop=<xsl:value-of select="$loop"/>;</xsl:message>-->
  118. <xsl:variable name="variant" select="number($variant) + 1"/><!-- dodajemy 1 aby sprawdzic jak wyglada -->
  119. <xsl:variable name="curr_bit" select="bp:decimalToBit($variant)"/>
  120. <xsl:variable name="digits">
  121. <xsl:for-each select="1 to string-length($curr_bit)">
  122. <xsl:if test="substring($curr_bit,.,1) = '1'">
  123. <xsl:value-of select="number(1)"/>
  124. </xsl:if>
  125. </xsl:for-each>
  126. </xsl:variable>
  127. <xsl:variable name="cur_bit_len" select=" string-length($digits)"/>
  128. <xsl:choose>
  129. <xsl:when test=" string-length($max_possible_bit)&gt; string-length($curr_bit)">
  130. <xsl:value-of select=" $variant - 1 "/>
  131. </xsl:when>
  132. <xsl:when test="number($loop) &gt; 512">
  133. <!--<xsl:message>#91 loop:<xsl:value-of select="$loop"/>; hit returning $variant=<xsl:value-of select="$variant"/>; $curr_bit=<xsl:value-of select="$curr_bit"/>;</xsl:message>-->
  134. <xsl:value-of select="$variant"/>
  135. </xsl:when>
  136. <xsl:when test="$curr_bit = $max_possible_bit">
  137. <!--<xsl:message>#90 brak kolejnych wariantow $variant=<xsl:value-of select="$variant"/>;$bit_limit=<xsl:value-of select="$bit_limit"/>; $curr_bit=<xsl:value-of select="$curr_bit"/></xsl:message>-->
  138. <xsl:value-of select="$variant"/>
  139. </xsl:when>
  140. <xsl:when test="number($cur_bit_len) &lt;= number($bit_limit)">
  141. <!--<xsl:variable name="next_bit" select="bp:decimalToBit($variant+1)"/>-->
  142. <!--<xsl:message>#104 next <xsl:value-of select="$variant"/></xsl:message>-->
  143. <xsl:value-of select="$variant"/>
  144. </xsl:when>
  145. <xsl:when test="number($cur_bit_len) &gt; number($bit_limit)">
  146. <!--<xsl:variable name="next_bit" select="bp:decimalToBit($variant+1)"/>-->
  147. <!--<xsl:message>#104 next <xsl:value-of select="$variant"/></xsl:message>-->
  148. <xsl:value-of select="bp:next_bit_max($variant ,$bit_limit,$max_possible_bit,$loop+1)"/>
  149. </xsl:when>
  150. <!--<xsl:otherwise>
  151. <xsl:message terminate="yes">#107 f. else $variant=<xsl:value-of select="$variant"/>; $curr_bit=<xsl:value-of select="$curr_bit"/>; $digits=<xsl:value-of select="$digits"/>;</xsl:message>
  152. <xsl:value-of select="$variant"/></xsl:otherwise>-->
  153. </xsl:choose>
  154. </xsl:function>
  155. <xsl:template name="PE_wariant_bit_table">
  156. <xsl:param name="wariant_id" required="yes"/>
  157. <xsl:param name="elements_cnt" required="yes"/>
  158. <xsl:param name="bit" required="yes"/>
  159. <xsl:param name="max_possible_bit" required="yes"/>
  160. <!--<xsl:variable name="table">
  161. <variant>
  162. <xsl:for-each select="1 to $elements_cnt">
  163. <pos>
  164. <xsl:attribute name="pos" select="."/>
  165. <!-\-<xsl:attribute name="bin_pos" select=" bp:if_bit_pos($bit,.)"/>-\->
  166. <xsl:if test=" string-length($bit) &gt; 0">
  167. <xsl:attribute name="bin_pos" select="substring($bit,.,1)"/>
  168. </xsl:if>
  169. <!-\-<xsl:attribute name="bin_poss" select="$bit"/>-\->
  170. <!-\-<xsl:value-of select="substring($bit,.,1)"/>-\->
  171. </pos>
  172. </xsl:for-each>
  173. </variant>
  174. </xsl:variable>-->
  175. <!--<xsl:variable name="sum_bit" select="sum($table/variant/pos/@bin_pos)"/>-->
  176. <!--<xsl:variable name="sum_bit" select="1"/>-->
  177. <!--<xsl:choose> errory
  178. <xsl:when test="$sum_bit = $elements_cnt and $sum_bit &lt;= $bit_limit">
  179. <variant>
  180. <xsl:attribute name="no_more_variants" select="$sum_bit"/>
  181. <xsl:attribute name="elements_cnt" select="$elements_cnt"/>
  182. <xsl:attribute name="bit_count" select="$sum_bit"/>
  183. </variant>
  184. </xsl:when>
  185. <xsl:when test="$sum_bit = $elements_cnt">
  186. <variant>
  187. <xsl:attribute name="no_more_variants" select="$sum_bit"/>
  188. <xsl:attribute name="elements_cnt" select="$elements_cnt"/>
  189. <xsl:copy-of select="$table"/>
  190. </variant>
  191. </xsl:when>
  192. <xsl:when test="$sum_bit &lt;= $bit_limit">
  193. <variant>
  194. <xsl:attribute name="bit_count" select="$sum_bit"/>
  195. <xsl:copy-of select="$table"/>
  196. </variant>
  197. </xsl:when>
  198. <xsl:otherwise>
  199. <variant>
  200. <xsl:attribute name="bit_limit_hit" select="$sum_bit"/>
  201. </variant>
  202. </xsl:otherwise>
  203. </xsl:choose>-->
  204. </xsl:template>
  205. <xsl:template name="main">
  206. <xsl:call-template name="PE_wariant"/>
  207. </xsl:template>
  208. <xsl:template name="PE_wariant">
  209. <xsl:param name="elements_cnt" select="10"/>
  210. <xsl:param name="max_possible_bit" select="1111111111"/>
  211. <xsl:param name="EconomicDistanceCut2"/><!-- tabela do podstawiania danych i wyliczen -->
  212. <PE_wariant_bit_table>
  213. <!--<xsl:variable name="no_more_variants" select=" math:power(2,$elements_cnt)"/>-->
  214. <xsl:variable name="no_more_variants" select="6"/>
  215. <xsl:attribute name="no_more_variants" select="$no_more_variants"/>
  216. <xsl:for-each select="1 to ($no_more_variants+1)">
  217. <xsl:variable name="wariant_id" select="."/>
  218. <!--<test><xsl:attribute name="wariant_id" select="."/>
  219. <xsl:variable name="bit" select=" string-join(bp:decimalToBitFill(.,$elements_cnt),'')"/>
  220. <xsl:attribute name="bit" select=" string-length($bit)"/>
  221. <xsl:value-of select="$bit"/>
  222. </test>-->
  223. <xsl:variable name="bit" select=" string-join(bp:decimalToBitFill(.,$elements_cnt),'')"/>
  224. <xsl:variable name="bit2" select=" string-join(bp:decimalToBit($wariant_id),'')"/>
  225. <xsl:variable name="bp:next_bit_max" select="bp:next_bit_max($wariant_id,$max_possible_bit,$elements_cnt,0)"/>
  226. <xsl:variable name="PE_wariant_bit_table">
  227. <PE_wariant_bit_table>
  228. <xsl:attribute name="wariant_id" select="."/>
  229. <xsl:attribute name="bit" select="$bit" />
  230. <xsl:attribute name="bit2" select="$bit2" />
  231. <bp:next_bit_max><xsl:attribute name="bit_od" select=" string-join(bp:decimalToBitFill($bp:next_bit_max,$elements_cnt),'')"/>
  232. <xsl:copy-of select="$bp:next_bit_max"/></bp:next_bit_max>
  233. <xsl:call-template name="PE_wariant_bit_table">
  234. <xsl:with-param name="wariant_id" select="$wariant_id"/>
  235. <xsl:with-param name="elements_cnt" select="$elements_cnt"/>
  236. <xsl:with-param name="bit" select="bp:decimalToBitFill($wariant_id,$elements_cnt)"/>
  237. <xsl:with-param name="max_possible_bit" select="$max_possible_bit"/>
  238. </xsl:call-template>
  239. </PE_wariant_bit_table>
  240. </xsl:variable>
  241. <xsl:choose>
  242. <xsl:when test="$bp:next_bit_max = $no_more_variants">
  243. No More variants by $bp:next_bit_max hits!
  244. </xsl:when>
  245. <xsl:when test="$PE_wariant_bit_table/PE_wariant_bit_table/variant[@bit_limit_hit]">
  246. <PE_wariant_bit_table>
  247. <xsl:attribute name="wariant_id" select="$wariant_id"/>
  248. <xsl:attribute name="bit_limit_hit" select="$PE_wariant_bit_table/PE_wariant_bit_table/variant/@bit_limit_hit"/>
  249. <xsl:copy-of select="$PE_wariant_bit_table/PE_wariant_bit_table"/>
  250. </PE_wariant_bit_table>
  251. </xsl:when>
  252. <xsl:when test="$PE_wariant_bit_table/PE_wariant_bit_table/variant[@no_more_variants]">
  253. <PE_wariant_bit_table>
  254. <xsl:attribute name="wariant_id" select="$wariant_id"/>
  255. <xsl:attribute name="no_more_variants" select="$PE_wariant_bit_table/PE_wariant_bit_table/variant/@no_more_variants"/>
  256. <xsl:copy-of select="$PE_wariant_bit_table/PE_wariant_bit_table"/>
  257. </PE_wariant_bit_table>
  258. </xsl:when>
  259. <xsl:otherwise>
  260. <xsl:copy-of select="$PE_wariant_bit_table"/>
  261. </xsl:otherwise>
  262. </xsl:choose>
  263. </xsl:for-each>
  264. </PE_wariant_bit_table>
  265. </xsl:template>
  266. </xsl:stylesheet>