PE_wariant_bit_table.xsl 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  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. xmlns:math="http://exslt.org/math"
  6. exclude-result-prefixes="xs"
  7. version="2.0">
  8. <xsl:output indent="yes"/>
  9. <xsl:strip-space elements="*"/>
  10. <!--<xsl:function name="bp:decimalToHex">
  11. <xsl:param name="dec"/>
  12. <xsl:if test="$dec > 0">
  13. <xsl:value-of
  14. select="bp:decimalToHex(floor($dec div 16)),substring('0123456789ABCDEF', (($dec mod 16) + 1), 1)"
  15. separator=""
  16. />
  17. </xsl:if>
  18. </xsl:function>-->
  19. <xsl:function name="bp:decimalToBit">
  20. <xsl:param name="dec"/>
  21. <xsl:if test="$dec &gt; 0">
  22. <xsl:value-of
  23. select="bp:decimalToBit(floor($dec div 2)),substring('01', (($dec mod 2) + 1), 1)"
  24. separator=""
  25. />
  26. </xsl:if>
  27. </xsl:function>
  28. <xsl:function name="bp:decimalToBitFill">
  29. <xsl:param name="dec" required="yes"/>
  30. <xsl:param name="len" required="yes"/>
  31. <xsl:variable name="bin" select=" string-join(bp:decimalToBit($dec),'')"/>
  32. <xsl:variable name="strlen" select="string-length($bin)"/>
  33. <xsl:variable name="brak_str" select="$len - $strlen"/>
  34. <!--<xsl:value-of select="concat(444,$strlen)"/>-->
  35. <!--<xsl:value-of select=" string($strlen)"/>-->
  36. <xsl:variable name="result">
  37. <xsl:choose>
  38. <xsl:when test="$strlen = $len">
  39. <xsl:value-of select="$bin"/>
  40. </xsl:when>
  41. <xsl:when test="$strlen &gt; $len">
  42. <xsl:value-of select="''"/>
  43. </xsl:when>
  44. <xsl:otherwise>
  45. <xsl:for-each select="1 to $brak_str ">
  46. <xsl:value-of select="0"/>
  47. </xsl:for-each>
  48. <xsl:copy-of select="$bin"/>
  49. </xsl:otherwise>
  50. </xsl:choose>
  51. </xsl:variable>
  52. <xsl:copy-of select="$result" />
  53. </xsl:function>
  54. <xsl:function name="bp:if_bit_pos">
  55. <xsl:param name="bit"/>
  56. <xsl:param name="pos"/>
  57. <xsl:value-of select=" substring($bit,number($pos),1)"/>
  58. </xsl:function>
  59. <xsl:template name="PE_wariant_bit_table">
  60. <xsl:param name="wariant_id" required="yes"/>
  61. <xsl:param name="elements_cnt" required="yes"/>
  62. <xsl:param name="bit" required="yes"/>
  63. <xsl:param name="bit_limit" required="yes"/>
  64. <xsl:variable name="table">
  65. <variant>
  66. <xsl:for-each select="1 to $elements_cnt">
  67. <pos>
  68. <xsl:attribute name="pos" select="."/>
  69. <!--<xsl:attribute name="bin_pos" select=" bp:if_bit_pos($bit,.)"/>-->
  70. <xsl:if test=" string-length($bit) &gt; 0">
  71. <xsl:attribute name="bin_pos" select="substring($bit,.,1)"/>
  72. </xsl:if>
  73. <!--<xsl:attribute name="bin_poss" select="$bit"/>-->
  74. <!--<xsl:value-of select="substring($bit,.,1)"/>-->
  75. </pos>
  76. </xsl:for-each>
  77. </variant>
  78. </xsl:variable>
  79. <xsl:variable name="sum_bit" select="sum($table/variant/pos/@bin_pos)"/>
  80. <!--<xsl:variable name="sum_bit" select="1"/>-->
  81. <xsl:choose>
  82. <xsl:when test="$sum_bit = $elements_cnt and $sum_bit &lt;= $bit_limit">
  83. <variant>
  84. <xsl:attribute name="no_more_variants" select="$sum_bit"/>
  85. <xsl:attribute name="elements_cnt" select="$elements_cnt"/>
  86. <xsl:attribute name="bit_count" select="$sum_bit"/>
  87. </variant>
  88. </xsl:when>
  89. <xsl:when test="$sum_bit = $elements_cnt">
  90. <variant>
  91. <xsl:attribute name="no_more_variants" select="$sum_bit"/>
  92. <xsl:attribute name="elements_cnt" select="$elements_cnt"/>
  93. <xsl:copy-of select="$table"/>
  94. </variant>
  95. </xsl:when>
  96. <xsl:when test="$sum_bit &lt;= $bit_limit">
  97. <variant>
  98. <xsl:attribute name="bit_count" select="$sum_bit"/>
  99. <xsl:copy-of select="$table"/>
  100. </variant>
  101. </xsl:when>
  102. <xsl:otherwise>
  103. <variant>
  104. <xsl:attribute name="bit_limit_hit" select="$sum_bit"/>
  105. </variant>
  106. </xsl:otherwise>
  107. </xsl:choose>
  108. </xsl:template>
  109. <xsl:template name="main">
  110. <xsl:call-template name="PE_wariant"/>
  111. </xsl:template>
  112. <xsl:template name="PE_wariant">
  113. <xsl:param name="elements_cnt" select="20"/>
  114. <xsl:param name="bit_max" select="63"/>
  115. <xsl:param name="EconomicDistanceCut2"/><!-- tabela do podstawiania danych i wyliczen -->
  116. <PE_wariant_bit_table>
  117. <xsl:variable name="no_more_variants" select=" math:power(2,$elements_cnt)"/>
  118. <xsl:attribute name="no_more_variants" select="$no_more_variants"/>
  119. <xsl:for-each select="1 to ($no_more_variants+1)">
  120. <xsl:variable name="wariant_id" select="."/>
  121. <!--<test><xsl:attribute name="wariant_id" select="."/>
  122. <xsl:variable name="bit" select=" string-join(bp:decimalToBitFill(.,$elements_cnt),'')"/>
  123. <xsl:attribute name="bit" select=" string-length($bit)"/>
  124. <xsl:value-of select="$bit"/>
  125. </test>-->
  126. <xsl:variable name="bit" select=" string-join(bp:decimalToBitFill(.,$elements_cnt),'')"/>
  127. <xsl:variable name="bit2" select=" string-join(bp:decimalToBit($wariant_id),'')"/>
  128. <xsl:variable name="PE_wariant_bit_table">
  129. <PE_wariant_bit_table>
  130. <xsl:attribute name="wariant_id" select="."/>
  131. <xsl:attribute name="bit" select="$bit" />
  132. <xsl:attribute name="bit2" select="$bit2" />
  133. <xsl:call-template name="PE_wariant_bit_table">
  134. <xsl:with-param name="wariant_id" select="$wariant_id"/>
  135. <xsl:with-param name="elements_cnt" select="$elements_cnt"/>
  136. <xsl:with-param name="bit" select="bp:decimalToBitFill($wariant_id,$elements_cnt)"/>
  137. <xsl:with-param name="bit_limit" select="$bit_max"/>
  138. </xsl:call-template>
  139. </PE_wariant_bit_table>
  140. </xsl:variable>
  141. <xsl:choose>
  142. <xsl:when test="$PE_wariant_bit_table/PE_wariant_bit_table/variant[@bit_limit_hit]">
  143. <PE_wariant_bit_table>
  144. <xsl:attribute name="wariant_id" select="$wariant_id"/>
  145. <xsl:attribute name="bit_limit_hit" select="$PE_wariant_bit_table/PE_wariant_bit_table/variant/@bit_limit_hit"/>
  146. <xsl:copy-of select="$PE_wariant_bit_table/PE_wariant_bit_table"/>
  147. </PE_wariant_bit_table>
  148. </xsl:when>
  149. <xsl:when test="$PE_wariant_bit_table/PE_wariant_bit_table/variant[@no_more_variants]">
  150. <PE_wariant_bit_table>
  151. <xsl:attribute name="wariant_id" select="$wariant_id"/>
  152. <xsl:attribute name="no_more_variants" select="$PE_wariant_bit_table/PE_wariant_bit_table/variant/@no_more_variants"/>
  153. <xsl:copy-of select="$PE_wariant_bit_table/PE_wariant_bit_table"/>
  154. </PE_wariant_bit_table>
  155. </xsl:when>
  156. <xsl:otherwise>
  157. <xsl:copy-of select="$PE_wariant_bit_table"/>
  158. </xsl:otherwise>
  159. </xsl:choose>
  160. </xsl:for-each>
  161. </PE_wariant_bit_table>
  162. </xsl:template>
  163. </xsl:stylesheet>