tardis-sn/carsus

Update GFALL data and/or parser

isaacgsmith opened this issue · 1 comments

There is new GFALL data that has been released since 2016 (see http://kurucz.harvard.edu/linelists.html under GFNEW). I tried parsing it with carsus but it did not work, so I am assuming that the parser either needs to be updated, or something needs to be done with the .dat file to make it readable by carsus. I am not sure which one of these is the case, since I am not too familiar with carsus.

I am including my error message when parsing gfnew/gfall08oct17.dat in case it is helpful:

TypeError                                 Traceback (most recent call last)
~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/ops/array_ops.py in na_arithmetic_op(left, right, op, str_rep)
    148     try:
--> 149         result = expressions.evaluate(op, str_rep, left, right)
    150     except TypeError:

~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/computation/expressions.py in evaluate(op, op_str, a, b, use_numexpr)
    207     if use_numexpr:
--> 208         return _evaluate(op, op_str, a, b)
    209     return _evaluate_standard(op, op_str, a, b)

~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/computation/expressions.py in _evaluate_numexpr(op, op_str, a, b)
    120     if result is None:
--> 121         result = _evaluate_standard(op, op_str, a, b)
    122 

~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/computation/expressions.py in _evaluate_standard(op, op_str, a, b)
     69     with np.errstate(all="ignore"):
---> 70         return op(a, b)
     71 

~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/ops/roperator.py in rpow(left, right)
     47 def rpow(left, right):
---> 48     return right ** left
     49 

TypeError: unsupported operand type(s) for ** or pow(): 'int' and 'str'

During handling of the above exception, another exception occurred:

TypeError                                 Traceback (most recent call last)
/tmp/ipykernel_3668324/4130594254.py in <module>
      4                            ionization_energies,
      5                            gfall_reader,
----> 6                            zeta_data)

~/carsus/carsus/io/output/base.py in __init__(self, atomic_weights, ionization_energies, gfall_reader, zeta_data, chianti_reader, cmfgen_reader, levels_lines_param, collisions_param)
     70 
     71         self.levels_all = self._get_all_levels_data()
---> 72         self.lines_all = self._get_all_lines_data()
     73         self.levels, self.lines = self.create_levels_lines(**levels_lines_param)
     74         self.create_macro_atom()

~/carsus/carsus/io/output/base.py in _get_all_lines_data(self)
    422 
    423         logger.info('Ingesting transition lines.')
--> 424         gf_lines = self.gfall_reader.lines
    425         gf_lines['ds_id'] = 2
    426 

~/carsus/carsus/io/kurucz/gfall.py in lines(self)
    119     def lines(self):
    120         if self._lines is None:
--> 121             self._lines = self.extract_lines()
    122         return self._lines
    123 

~/carsus/carsus/io/kurucz/gfall.py in extract_lines(self, gfall, levels, selected_columns)
    346 
    347         lines = gfall[selected_columns].copy()
--> 348         lines["gf"] = np.power(10, lines["loggf"])
    349         lines = lines.drop(["loggf"], 1)
    350 

~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/series.py in __array_ufunc__(self, ufunc, method, *inputs, **kwargs)
    634         # for binary ops, use our custom dunder methods
    635         result = ops.maybe_dispatch_ufunc_to_dunder_op(
--> 636             self, ufunc, method, *inputs, **kwargs
    637         )
    638         if result is not NotImplemented:

pandas/_libs/ops_dispatch.pyx in pandas._libs.ops_dispatch.maybe_dispatch_ufunc_to_dunder_op()

~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/ops/common.py in new_method(self, other)
     62         other = item_from_zerodim(other)
     63 
---> 64         return method(self, other)
     65 
     66     return new_method

~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/ops/__init__.py in wrapper(left, right)
    501         lvalues = extract_array(left, extract_numpy=True)
    502         rvalues = extract_array(right, extract_numpy=True)
--> 503         result = arithmetic_op(lvalues, rvalues, op, str_rep)
    504 
    505         return _construct_result(left, result, index=left.index, name=res_name)

~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/ops/array_ops.py in arithmetic_op(left, right, op, str_rep)
    195     else:
    196         with np.errstate(all="ignore"):
--> 197             res_values = na_arithmetic_op(lvalues, rvalues, op, str_rep)
    198 
    199     return res_values

~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/ops/array_ops.py in na_arithmetic_op(left, right, op, str_rep)
    149         result = expressions.evaluate(op, str_rep, left, right)
    150     except TypeError:
--> 151         result = masked_arith_op(left, right, op)
    152 
    153     return missing.dispatch_fill_zeros(op, left, right, result)

~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/ops/array_ops.py in masked_arith_op(x, y, op)
    110         if mask.any():
    111             with np.errstate(all="ignore"):
--> 112                 result[mask] = op(xrav[mask], y)
    113 
    114     result, _ = maybe_upcast_putmask(result, ~mask, np.nan)

~/mambaforge-pypy3/envs/carsus/lib/python3.7/site-packages/pandas/core/ops/roperator.py in rpow(left, right)
     46 
     47 def rpow(left, right):
---> 48     return right ** left
     49 
     50 

TypeError: unsupported operand type(s) for ** or pow(): 'int' and 'str'

Or maybe we need to write a new parser, I don't know how similar the file is