Source code for omfit_classes.omfit_jsolver
try:
    # framework is running
    from .startup_choice import *
except ImportError as _excp:
    # class is imported by itself
    if (
        'attempted relative import with no known parent package' in str(_excp)
        or 'No module named \'omfit_classes\'' in str(_excp)
        or "No module named '__main__.startup_choice'" in str(_excp)
    ):
        from startup_choice import *
    else:
        raise
from omfit_classes.omfit_nc import OMFITnc
from omfit_classes.omfit_eqdsk import OMFITgeqdsk
__all__ = ['OMFITjsolver']
[docs]class OMFITjsolver(OMFITnc):
    """
    Class used to parse the ouput of the jsolver equilibirum code
    """
[docs]    def to_geqdsk(self, B0, R0, ip, resolution, shot=0, time=0, RBFkw={}):
        """
        maps jsolver solution to a gEQDSK file
        :param B0: scalar vacuum B toroidal at R0
        :param R0: scalar R where B0 is defined
        :param ip: toroidal current
        :param resolution: g-file grid resolution
        :param shot: used to set g-file string
        :param time: used to set g-file string
        :param RBFkw: keywords passed to internal Rbf interpolator
        :return: OMFITgeqdsk object
        """
        return OMFITgeqdsk('g%06d.%05d' % (shot, time)).from_rz(
            self['x']['data'],
            self['z']['data'],
            self['psival']['data'],
            self['p']['data'],
            self['f']['data'],
            self['q']['data'],
            B0,
            R0,
            ip,
            resolution,
            RBFkw=RBFkw,
        )  
############################################
if __name__ == '__main__':
    test_classes_main_header()
    j = OMFITjsolver(OMFITsrc + '/../samples/jsolver_eqdsk_11MA_A3_R4.5.cdf')
    g = j.to_geqdsk(8.0, 4.5, 11e6, 65)