<p>Hi Nathan, </p>
<p>My drive-by, Friday night answer is to combine a three element boolean periodicity attribute with fields that are conditionally made available (through validators) to parameter files if periodicity is appropriate. </p>

<p>-Matt</p>
<div class="gmail_quote">On Dec 21, 2012 8:16 PM, "Nathan Goldbaum" <<a href="mailto:nathan12343@gmail.com">nathan12343@gmail.com</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
This is a discussion that began on yt-users but since I'm going to speculate about how to change the code, I'm replying over here on yt-dev.<br>
<br>
I see now that it's difficult to check for periodic boundary conditions in a code-independent way in the middle of a field definition.  There are a number of places where yt assumes periodic boundary conditions (mostly in plotting routines) but I don't see any places that programatically check the boundary conditions that the simulation was run with.  Am I missing something somewhere?<br>

<br>
I feel like this functionality should be there but I'm not sure what the best solution is.<br>
<br>
Just spitballing: perhaps there be something like pf.periodic which is True or False?  This would have to be defined in the individual code frontends by looking at runtime parameters.  It's not obvious to me that this will be easy to do for codes that don't have self-describing data formats.  Another issue is that a binary Periodic attribute won't be sufficient for simulations run with mixed boundary conditions.<br>

<br>
Does anyone else have any thoughts on this?  I don't want to cause a huge disruption but I'm strongly -1 on the way the Radius field is currently written since it quietly produces incorrect results on a large number of test problem-like datasets.  It won't be a problem in cosmological simulations so I worry that inexperienced users will tend to get bit by it.<br>

<br>
Cheers,<br>
<br>
Nathan<br>
<br>
On 12/21/12 4:26 PM, Geoffrey So wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
I've seen and used something similar in my ellipsoids, where the domain width (DW) is used to calculate the shortest distance between two points due to periodic boundary condition.  So if you do not have a periodic box then that line (involving DW) should be changed.  This is part of the reason why my ellipsoid container is limited to periodic box only.<br>

<br>
I'm hoping to put in a flag to turn it off and on later, but if a flag is put in to turn it off maybe I'll imitate it for the ellipsoids, too.<br>
<br>
From<br>
G.S.<br>
<br>
On Fri, Dec 21, 2012 at 4:18 PM, Nathan Goldbaum <<a href="mailto:nathan12343@gmail.com" target="_blank">nathan12343@gmail.com</a> <mailto:<a href="mailto:nathan12343@gmail.com" target="_blank">nathan12343@gmail.com</a>><u></u>> wrote:<br>

<br>
    Hi all,<br>
<br>
    I encountered a bit of odd code deep in the field definition code<br>
    and I need some help to understand why it is the way it is.<br>
<br>
    The field I'm curious about is the Radius field (defined on line<br>
    796 of universal_fields.py):<br>
<br>
    def _Radius(field, data):<br>
        center = data.get_field_parameter("<u></u>center")<br>
        DW = data.pf.domain_right_edge - data.pf.domain_left_edge<br>
        radius = np.zeros(data["x"].shape, dtype='float64')<br>
        for i, ax in enumerate('xyz'):<br>
            r = np.abs(data[ax] - center[i])<br>
            radius += np.minimum(r, np.abs(DW[i]-r))**2.0<br>
        np.sqrt(radius, radius)<br>
        return radius<br>
<br>
    In particular, I don't understand this line:<br>
<br>
    radius += np.minimum(r, np.abs(DW[i]-r))**2.0<br>
<br>
    Is this supposed to correct for some effect in periodic simulations?<br>
<br>
    The reason I bring this up is because it caused some very weird<br>
    behavior in a 1D FLASH simulation.  In this simulation, the domain<br>
    went from x = -.01 pc to x = +500 pc.  Since the middle of the<br>
    domain wasn't lined up with the 'center' of the simulation at x =<br>
    0, the offending line in the radius calculation led to an<br>
    incorrect calculation of the radius beyond x = 250 pc.  In that<br>
    case, I was able to fix it by changing the offending line to<br>
<br>
    radius += r**2.0<br>
<br>
    Before I issue a patch, I want to see why it's defined the way it<br>
    is currently and see if we can come up with a workaround.<br>
<br>
    Cheers,<br>
<br>
    Nathan<br>
    ______________________________<u></u>_________________<br>
    yt-users mailing list<br>
    <a href="mailto:yt-users@lists.spacepope.org" target="_blank">yt-users@lists.spacepope.org</a> <mailto:<a href="mailto:yt-users@lists.spacepope.org" target="_blank">yt-users@lists.<u></u>spacepope.org</a>><br>
    <a href="http://lists.spacepope.org/listinfo.cgi/yt-users-spacepope.org" target="_blank">http://lists.spacepope.org/<u></u>listinfo.cgi/yt-users-<u></u>spacepope.org</a><br>
<br>
<br>
<br>
<br>
______________________________<u></u>_________________<br>
yt-users mailing list<br>
<a href="mailto:yt-users@lists.spacepope.org" target="_blank">yt-users@lists.spacepope.org</a><br>
<a href="http://lists.spacepope.org/listinfo.cgi/yt-users-spacepope.org" target="_blank">http://lists.spacepope.org/<u></u>listinfo.cgi/yt-users-<u></u>spacepope.org</a><br>
</blockquote>
<br>
______________________________<u></u>_________________<br>
yt-dev mailing list<br>
<a href="mailto:yt-dev@lists.spacepope.org" target="_blank">yt-dev@lists.spacepope.org</a><br>
<a href="http://lists.spacepope.org/listinfo.cgi/yt-dev-spacepope.org" target="_blank">http://lists.spacepope.org/<u></u>listinfo.cgi/yt-dev-spacepope.<u></u>org</a><br>
</blockquote></div>