Быстрая попытка ответить на ваш вопрос по обработке изображений. Обратите внимание на то, что вы ищете. Максимум в стеке изображений должен быть наибольшим значением во всем стеке. Минимум - это самые маленькие значения в стеке. Таким образом, при выполнении сравнения, ищущего наименьшее или наибольшее при загрузке изображений, к концу вы должны получить изображение, которое вы ищете.
for i=1:numImages
fn = sprintf('%s%s',pathImages,indexImages(i).name);
primera=imread(fn);
primera=double(primera);
if(i==1)
Ifondo=double(primera);
else
IDX = Ifondo < primera; % Finding larger values from next loaded img
Ifondo(IDX) = primera(IDX); % pixels found larger in primera, overlap those same pixels in Ifondo
end
end
Вот как я бы сделал это, используя ваш код.
В XSLT 1.0 вы должны создать рекурсивный шаблон. Эта таблица стилей:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="text/text()" name="tokenize">
<xsl:param name="text" select="."/>
<xsl:param name="separator" select="','"/>
<xsl:choose>
<xsl:when test="not(contains($text, $separator))">
<item>
<xsl:value-of select="normalize-space($text)"/>
</item>
</xsl:when>
<xsl:otherwise>
<item>
<xsl:value-of select="normalize-space(substring-before($text, $separator))"/>
</item>
<xsl:call-template name="tokenize">
<xsl:with-param name="text" select="substring-after($text, $separator)"/>
</xsl:call-template>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
</xsl:stylesheet>
Вход:
<root>
<text>Item1, Item2, Item3</text>
</root>
Выход:
<root>
<text>
<item>Item1</item>
<item>Item2</item>
<item>Item3</item>
</text>
</root>
В XSLT 2.0 у вас есть основная функция tokenize()
. Итак, эта таблица стилей:
<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="text/text()" name="tokenize">
<xsl:param name="separator" select="','"/>
<xsl:for-each select="tokenize(.,$separator)">
<item>
<xsl:value-of select="normalize-space(.)"/>
</item>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
Результат:
<root>
<text>
<item>Item1</item>
<item>Item2</item>
<item>Item3</item>
</text>
</root>
Нет функции split
, но вы можете использовать рекурсивный шаблон с substring-before
и substring-after
, чтобы написать свой собственный.
Подробнее см. в этой статье.
XSLT 1.0
Мне нужен небольшой вариант по сравнению с другими ответами, приведенными здесь.
Ввод:
1, 2, 3
Выход:
1, 2 и 3
Вход:
1
Выход
1
Если в качестве разделителя вместо пробела используется пробел, он все равно будет работать.
Вход:
1 2 3
Выход:
1 , 2 и 3
Я только что создал слегка измененный шаблон.
<xsl:template name="tokenizeString">
<xsl:param name="list"/>
<xsl:param name="delimiter"/>
<xsl:choose>
<xsl:when test="contains($list, $delimiter)">
<xsl:variable name="listLength" select="string-length($list)" />
<xsl:variable name="listLengthWithoutDelimiters" select="string-length(translate($list, $delimiter,''))" />
<xsl:variable name="noOfDelimiters" select="($listLength - $listLengthWithoutDelimiters)" />
<xsl:value-of select="substring-before($list,$delimiter)"/>
<xsl:if test="$noOfDelimiters > 1">, </xsl:if>
<xsl:if test="$noOfDelimiters = 1"> and </xsl:if>
<xsl:call-template name="tokenizeString">
<xsl:with-param name="list" select="substring-after($list,$delimiter)"/>
<xsl:with-param name="delimiter" select="$delimiter"/>
</xsl:call-template>
</xsl:when>
<xsl:otherwise>
<xsl:choose>
<xsl:when test="$list = ''">
<xsl:text/>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="$list"/>
</xsl:otherwise>
</xsl:choose>
</xsl:otherwise>
</xsl:choose>
Шаблон можно вызвать, как показано ниже, когда разделитель запятый
<xsl:call-template name="tokenizeString">
<xsl:with-param name="list">1, 2, 3</xsl:with-param>
<xsl:with-param name="delimiter">
<xsl:value-of select="','" />
</xsl:with-param>
</xsl:call-template>
Шаблон можно вызвать, как показано ниже разделителем является пробел
<xsl:call-template name="tokenizeString">
<xsl:with-param name="list">1 2 3</xsl:with-param>
<xsl:with-param name="delimiter">
<xsl:value-of select="' '" />
</xsl:with-param>
</xsl:call-template>