[xquery-talk] Re: Optimizations
Michael Kay
mike at saxonica.com
Fri Oct 3 16:27:01 PDT 2008
This is a case where Saxon (even Saxon-SA) has stopped optimizing when it
could have achieved a little more. The relevant part of the final expression
tree is
<return>
<sequence>
<choose>
<when>
<compareToInteger op="ge" value="4">
<literal value="3" type="xs:integer"/>
</compareToInteger>
</when>
<then>
<directElement name="debug" validation="preserve">
<variableReference name="dosmthg"/>
</directElement>
</then>
</choose>
<variableReference name="dosmthg"/>
</sequence>
</return>
and it hasn't noticed that the <when> condition is now constant.
Deciding when to stop optimizing is the trickiest part of the exercise - if
you go on too long, optimization can take longer than any run-time savings
it is delivering. In this occasion, two more passes would have paid
dividends - one to evaluate the <when> condition, the other to reduce the
<choose> to ().
Michael Kay
http://www.saxonica.com/
_____
From: talk-bounces at x-query.com [mailto:talk-bounces at x-query.com] On Behalf
Of Rémi Dewitte
Sent: 03 October 2008 14:24
To: talk at x-query.com
Subject: [xquery-talk] Re: Optimizations
Hi again,
In the same spirit, this is not at all optimized.
Maybe I need Saxon SA ?
declare variable $level as xs:integer := 3 ;
declare function local:debug($l as xs:integer,$what){
if($l >=4) then
<debug>{$what}</debug>
else ()
};
let $dosmthg := <oki>test trace</oki>
return
(local:debug($level,$dosmthg),$dosmthg)
Rémi
On Fri, Oct 3, 2008 at 3:17 PM, Rémi Dewitte <remi at gide.net> wrote:
Hi,
I have made a little experiment after reading Michael (Kay) blog posts about
optimizations and recent James Fuller article.
I have a question quite specific to saxon still interesting in general.
Why in the following example even the function call is not skipped ?
XQuery is ::
declare variable $level := 3;
declare function local:debug($what){
if($level >=4) then
<debug>{$what}</debug>
else ()
};
let $dosmthg := <oki>test trace</oki>
return
(local:debug($dosmthg),$dosmthg)
When I run saxon with -explain we get
<query>
<globalVariables>
<declareVariable name="level">
<literal value="3" type="xs:integer"/>
</declareVariable>
</globalVariables>
<declareFunction name="local:debug" tailRecursive="false">
<literal value="()"/>
</declareFunction>
<body>
<let variable="dosmthg" as="element(oki,
{http://www.w3.org/2001/XMLSchema}untyped
<http://www.w3.org/2001/XMLSchema%7Duntyped> )">
<be>
<directElement name="oki" validation="skip">
<valueOf>
<literal value="test trace" type="xs:string"/>
</valueOf>
</directElement>
</be>
<return>
<sequence>
<functionCall name="local:debug" tailCall="false">
<variableReference name="dosmthg"/>
</functionCall>
<variableReference name="dosmthg"/>
</sequence>
</return>
</let>
</body>
</query>
Cheers,
Rémi
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://x-query.com/pipermail/talk/attachments/20081003/e3510ab1/attachment-0001.htm
More information about the talk
mailing list