#define MICHLIB_NOSOURCE #include "actionuv.h" void UVMethods::StPoints::WriteBinBile(const MString& name, const michlib_internal::ParameterListEx& pars) const { BFileW stp; stp.Create(name, 3); stp.SetColumnName(1, lonlat ? "Longitude" : "x"); stp.SetColumnName(2, lonlat ? "Latitude" : "x"); stp.SetColumnName(3, "Stability (0 - saddle, 1 - st. anticicl. focus, 2 - st. knot, 3 - unst. anticicl. focus, 4 - unst. knot, 5 - st. cicl. focus, 6 - unst. cicl. focus)"); stp.SetParameters(pars); for(size_t i = 0; i < N(); i++) { stp.Write(x[i]); stp.Write(y[i]); stp.Write(michlib::int_cast(t[i])); } stp.Finalize(); stp.Close(); } MString UVMethods::StPoints::CreateNcFile(const MString& name, const michlib_internal::ParameterListEx& pars, const MString& history, int comp, const TimeData& tdata, bool timedep) { tdep = timedep; const MString xname = lonlat ? "longitude" : "x"; const MString yname = lonlat ? "latitude" : "y"; nc.Open(name); if(!nc) return "Can't create netcdf file " + name + ": " + nc.ErrMessage(); if(history.Exist()) nc.AddAtt("history", history); nc.AddAtts(pars); nc.AddDim("i", N()); nc.AddDim("time", tdata.steps.size()); nc.AddVar("time", decltype(nc)::Type2NCType, "time"); nc.SetComp("time", comp); nc.AddAtt("time", "standard_name", "time"); nc.AddAtt("time", "long_name", "time"); nc.AddAtt("time", "units", tdata.UnitName()); if(tdep) { nc.AddVar(xname, NC_FLOAT, "time", "i"); nc.AddVar(yname, NC_FLOAT, "time", "i"); } else { nc.AddVar(xname, NC_FLOAT, "i"); nc.AddVar(yname, NC_FLOAT, "i"); } nc.SetComp(xname, comp); nc.SetComp(yname, comp); if(lonlat) { nc.AddAtt(xname, "standard_name", "longitude"); nc.AddAtt(xname, "long_name", "Longitude"); nc.AddAtt(yname, "standard_name", "latitude"); nc.AddAtt(yname, "long_name", "Latitude"); } else { nc.AddAtt(xname, "long_name", "x-coordinate"); nc.AddAtt(yname, "long_name", "y-coordinate"); } if(tdep) nc.AddVar("type", NC_UBYTE, "time", "i"); else nc.AddVar("type", NC_UBYTE, "i"); nc.SetComp("type", comp); nc.AddAtt("type", "long_name", "Stationary point type, 0 - saddle, 1 - st. anticicl. focus, 2 - st. knot, 3 - unst. anticicl. focus, 4 - unst. knot, 5 - st. cicl. focus, 6 - unst. cicl. focus"); nc.WriteVar("time", tdata.steps.data()); if(!nc) return "Can't set grid in the netcdf file " + name + ": " + nc.ErrMessage(); return ""; } MString UVMethods::StPoints::WriteNcFile(size_t it) { const MString xname = lonlat ? "longitude" : "x"; const MString yname = lonlat ? "latitude" : "y"; if(tdep) { nc.WriteVar(xname, it, x.data()); nc.WriteVar(yname, it, y.data()); nc.WriteVar("type", it, t.data()); } else { nc.WriteVar(xname, x.data()); nc.WriteVar(yname, y.data()); nc.WriteVar("type", t.data()); } if(!nc) return MString("Can't write data to the netcdf file: ") + nc.ErrMessage(); return ""; }