Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Logging functionallity #269

Merged
merged 9 commits into from
Aug 30, 2024
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion pyPlots/colormaps.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
#
# You should have received a copy of the CC0 legalcode along with this
# work. If not, see <http://creativecommons.org/publicdomain/zero/1.0/>.

import logging
from matplotlib import __version__ as mpl_version
from matplotlib.colors import LinearSegmentedColormap
from packaging.version import Version
Expand Down
5 changes: 3 additions & 2 deletions pyPlots/plot.py
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@
from plot_variables import plot_variables, plot_multiple_variables


import logging
import matplotlib.pyplot as plt
import matplotlib
import colormaps as cmaps
Expand All @@ -51,7 +52,7 @@
try:
from plot_isosurface import plot_isosurface, plot_neutral_sheet
except:
print("plot_isosurface not imported. To access it, use Python version >3.8 and install scikit-image.")
logging.info("plot_isosurface not imported. To access it, use Python version >3.8 and install scikit-image.")

from packaging.version import Version

Expand Down Expand Up @@ -91,7 +92,7 @@
cb_linear = False

# Output matplotlib version
print("Using matplotlib version "+matplotlib.__version__)
logging.info("Using matplotlib version "+matplotlib.__version__)

# Default output directory for plots
defaultoutputdir=os.path.expandvars('$HOME/Plots/')
Expand Down
67 changes: 34 additions & 33 deletions pyPlots/plot_colormap.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@

import matplotlib
import pytools as pt
import logging
import numpy as np
import matplotlib.pyplot as plt
import os, sys
Expand Down Expand Up @@ -119,7 +120,7 @@ def plot_colormap(filename=None,
string, tries to use that as the location, e.g. "NW","NE","SW","SW"
:kword wmarkb: As for wmark, but uses an all-black Vlasiator logo.
:kword Earth: If set, draws an earth at (0,0)
:kword highres: Creates the image in high resolution, scaled up by this value (suitable for print).
:kword highres: Creates the image in high resolution, scaled up by this value (suitable for logging.info).
kstppd marked this conversation as resolved.
Show resolved Hide resolved

:kword draw: Set to anything but None or False in order to draw image on-screen instead of saving to file (requires x-windowing)

Expand Down Expand Up @@ -259,7 +260,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
elif vlsvobj:
f=vlsvobj
else:
print("Error, needs a .vlsv file name, python object, or directory and step")
logging.info("Error, needs a .vlsv file name, python object, or directory and step")
return

# Flux function files
Expand All @@ -275,11 +276,11 @@ def exprMA_cust(exprmaps, requestvariables=False):
if not os.path.exists(fluxfile):
fluxfile = fluxdir+'bulk.'+filename[-12:-5]+'.bin'
else:
print("Requested flux lines via directory but working from vlsv object, cannot find step.")
logging.info("Requested flux lines via directory but working from vlsv object, cannot find step.")

if fluxfile:
if not os.path.exists(fluxfile):
print("Error locating flux function file!")
logging.info("Error locating flux function file!")
fluxfile=None

if operator is None:
Expand Down Expand Up @@ -341,7 +342,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
if type(operator) is int:
operator = str(operator)
if not operator in 'xyz' and operator!='magnitude' and not operator.isdigit():
print("Unknown operator "+operator)
logging.info("Unknown operator "+operator)
operator=None
if operator in 'xyz':
# For components, always use linear scale, unless symlog is set
Expand Down Expand Up @@ -377,8 +378,8 @@ def exprMA_cust(exprmaps, requestvariables=False):
# Activate diff mode?
if diff:
if (expression or external or pass_vars or pass_times or pass_full):
print("attempted to perform diff with one of the following active:")
print("expression or external or pass_vars or pass_times or pass_full. Exiting.")
logging.info("attempted to perform diff with one of the following active:")
logging.info("expression or external or pass_vars or pass_times or pass_full. Exiting.")
return -1
expression=pt.plot.plot_helpers.expr_Diff
pass_vars.append(var)
Expand Down Expand Up @@ -409,16 +410,16 @@ def exprMA_cust(exprmaps, requestvariables=False):
pass

if not os.access(outputdir, os.W_OK):
print("No write access for directory "+outputdir+"! Exiting.")
logging.info("No write access for directory "+outputdir+"! Exiting.")
return

# Check if target file already exists and overwriting is disabled
if (nooverwrite and os.path.exists(outputfile)):
if os.stat(outputfile).st_size > 0: # Also check that file is not empty
print("Found existing file "+outputfile+". Skipping.")
logging.info("Found existing file "+outputfile+". Skipping.")
return
else:
print("Found existing file "+outputfile+" of size zero. Re-rendering.")
logging.info("Found existing file "+outputfile+" of size zero. Re-rendering.")


Re = 6.371e+6 # Earth radius in m
Expand All @@ -442,7 +443,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
sizes=[xsize,ysize]
pt.plot.plot_helpers.PLANE = 'XY'
if ysize!=1 and zsize!=1 and xsize!=1:
print("Mesh is not 2-D: Use plot_colormap3Dslice instead!")
logging.info("Mesh is not 2-D: Use plot_colormap3Dslice instead!")
return

# Select window to draw
Expand Down Expand Up @@ -497,7 +498,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
cb_title_use = pt.plot.mathmode(pt.plot.bfstring(cb_title_use))
# Verify data shape
if np.ndim(datamap)==0:
print("Error, read only single value from vlsv file!",datamap.shape)
logging.info("Error, read only single value from vlsv file!",datamap.shape)
return -1
# fsgrid reader returns array in correct shape but needs to be transposed
if var.startswith('fg_'):
Expand All @@ -511,7 +512,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
elif np.ndim(datamap)==3: # tensor variable
datamap = datamap[cellids.argsort()].reshape([sizes[1],sizes[0],datamap.shape[1],datamap.shape[2]])
else:
print("Error in reshaping datamap!")
logging.info("Error in reshaping datamap!")
else:
# Expression set, use generated or provided colorbar title
cb_title_use = pt.plot.mathmode(pt.plot.bfstring(pt.plot.rmstring(expression.__name__.replace(r"_",r"\_")) +operatorstr))
Expand Down Expand Up @@ -587,7 +588,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
else:
pass_map = f.read_variable(mapval)
if np.ndim(pass_map)==0:
print("Error, read only single value from vlsv file!",pass_map.shape)
logging.info("Error, read only single value from vlsv file!",pass_map.shape)
return -1
# fsgrid reader returns array in correct shape.
# For vlasov grid reader, reorder and reshape.
Expand All @@ -599,7 +600,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
elif np.ndim(pass_map)==3: # tensor variable
pass_map = pass_map[cellids.argsort()].reshape([sizes[1],sizes[0],pass_map.shape[1],pass_map.shape[2]])
else:
print("Error in reshaping pass_map!")
logging.info("Error in reshaping pass_map!")
if np.ma.is_masked(maskgrid):
if np.ndim(pass_map)==2:
pass_map = pass_map[MaskX[0]:MaskX[-1]+1,:]
Expand All @@ -611,29 +612,29 @@ def exprMA_cust(exprmaps, requestvariables=False):
pass_map = pass_map[MaskX[0]:MaskX[-1]+1,:,:,:]
pass_map = pass_map[:,MaskY[0]:MaskY[-1]+1,:,:]
else:
print("Error in masking pass_maps!")
logging.info("Error in masking pass_maps!")
pass_maps[mapval] = pass_map # add to the dictionary
else:
# Or gather over a number of time steps
# Note: pass_maps is now a list of dictionaries
pass_maps = []
if diff:
print("Comparing files "+filename+" and "+diff)
logging.info("Comparing files "+filename+" and "+diff)
elif step is not None and filename:
currstep = step
else:
if filename: # parse from filename
currstep = int(filename[-12:-5])
else:
print("Error, cannot determine current step for time extent extraction!")
logging.info("Error, cannot determine current step for time extent extraction!")
return
# define relative time step selection
if np.ndim(pass_times)==0:
dsteps = np.arange(-abs(int(pass_times)),abs(int(pass_times))+1)
elif np.ndim(pass_times)==1 and len(pass_times)==2:
dsteps = np.arange(-abs(int(pass_times[0])),abs(int(pass_times[1]))+1)
else:
print("Invalid value given to pass_times")
logging.info("Invalid value given to pass_times")
return
# Loop over requested times
for ds in dsteps:
Expand All @@ -645,7 +646,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
else:
# Construct using known filename.
filenamestep = filename[:-12]+str(currstep+ds).rjust(7,'0')+'.vlsv'
print(filenamestep)
logging.info(filenamestep)
fstep=pt.vlsvfile.VlsvReader(filenamestep)
step_cellids = fstep.read_variable("CellID")
# Append new dictionary as new timestep
Expand All @@ -660,7 +661,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
else:
pass_map = fstep.read_variable(mapval)
if np.ndim(pass_map)==0:
print("Error, read only single value from vlsv file!",pass_map.shape)
logging.info("Error, read only single value from vlsv file!",pass_map.shape)
return -1
# fsgrid reader returns array in correct shape.
# For vlasov grid reader, reorder and reshape.
Expand All @@ -672,7 +673,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
elif np.ndim(pass_map)==3: # tensor variable
pass_map = pass_map[step_cellids.argsort()].reshape([sizes[1],sizes[0],pass_map.shape[1],pass_map.shape[2]])
else:
print("Error in reshaping pass_map!")
logging.info("Error in reshaping pass_map!")
if np.ma.is_masked(maskgrid):
if np.ndim(pass_map)==2:
pass_map = pass_map[MaskX[0]:MaskX[-1]+1,:]
Expand All @@ -684,7 +685,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
pass_map = pass_map[MaskX[0]:MaskX[-1]+1,:,:,:]
pass_map = pass_map[:,MaskY[0]:MaskY[-1]+1,:,:]
else:
print("Error in masking pass_maps!")
logging.info("Error in masking pass_maps!")
pass_maps[-1][mapval] = pass_map # add to the dictionary

# colorbar title for diffs:
Expand Down Expand Up @@ -714,7 +715,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
if operator=='y': operator = '1'
if operator=='z': operator = '2'
if not operator.isdigit():
print("Error parsing operator for custom expression!")
logging.info("Error parsing operator for custom expression!")
return
elif np.ndim(datamap)==3:
datamap = datamap[:,:,int(operator)]
Expand All @@ -723,23 +724,23 @@ def exprMA_cust(exprmaps, requestvariables=False):
if np.ndim(datamap)==3: # vector
if datamap.shape[2]!=3:
# This may also catch 3D simulation fsgrid variables
print("Error, expected array of 3-element vectors, found array of shape ",datamap.shape)
logging.info("Error, expected array of 3-element vectors, found array of shape ",datamap.shape)
return -1
# take magnitude of three-element vectors
datamap = np.linalg.norm(datamap, axis=-1)
if np.ndim(datamap)==4: # tensor
if datamap.shape[2]!=3 or datamap.shape[3]!=3:
# This may also catch 3D simulation fsgrid variables
print("Error, expected array of 3x3 tensors, found array of shape ",datamap.shape)
logging.info("Error, expected array of 3x3 tensors, found array of shape ",datamap.shape)
return -1
# take trace
datamap = datamap[:,:,0,0]+datamap[:,:,1,1]+datamap[:,:,2,2]
if np.ndim(datamap)>=5: # Too many dimensions
print("Error, too many dimensions in datamap, found array of shape ",datamap.shape)
logging.info("Error, too many dimensions in datamap, found array of shape ",datamap.shape)
return -1
if np.ndim(datamap)!=2:
# Array dimensions not as expected
print("Error reading variable "+var+"! Found array of shape ",datamap.shape,". Exiting.")
logging.info("Error reading variable "+var+"! Found array of shape ",datamap.shape,". Exiting.")
return -1

# Scale final generated datamap if requested
Expand Down Expand Up @@ -808,7 +809,7 @@ def exprMA_cust(exprmaps, requestvariables=False):

# If both values are zero, we have an empty array
if vmaxuse==vminuse==0:
print("Error, requested array is zero everywhere. Exiting.")
logging.info("Error, requested array is zero everywhere. Exiting.")
return 0

# If vminuse and vmaxuse are extracted from data, different signs, and close to each other, adjust to be symmetric
Expand Down Expand Up @@ -844,7 +845,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
if symlog is not None:
if Version(matplotlib.__version__) < Version("3.3.0"):
norm = SymLogNorm(linthresh=linthresh, linscale = 1.0, vmin=vminuse, vmax=vmaxuse, clip=True)
print("WARNING: colormap SymLogNorm uses base-e but ticks are calculated with base-10.")
logging.info("WARNING: colormap SymLogNorm uses base-e but ticks are calculated with base-10.")
#TODO: copy over matplotlib 3.3.0 implementation of SymLogNorm into pytools/analysator
else:
norm = SymLogNorm(base=10, linthresh=linthresh, linscale = 1.0, vmin=vminuse, vmax=vmaxuse, clip=True)
Expand Down Expand Up @@ -992,7 +993,7 @@ def exprMA_cust(exprmaps, requestvariables=False):
except:
ff_b = f.read_variable("vg_b_vol", cellids=cid)
if (ff_b.size!=3):
print("Error reading fg_b or vg_b_vol data for fluxfunction normalization!")
logging.info("Error reading fg_b or vg_b_vol data for fluxfunction normalization!")

if f.check_variable("moments"): # restart file
ff_v = f.read_variable("vg_restart_v", cellids=cid)
Expand Down Expand Up @@ -1321,8 +1322,8 @@ def exprMA_cust(exprmaps, requestvariables=False):
try:
plt.savefig(outputfile,dpi=300, bbox_inches=bbox_inches, pad_inches=savefig_pad)
except:
print("Error with attempting to save figure.")
print(outputfile+"\n")
logging.info("Error with attempting to save figure.")
logging.info(outputfile+"\n")
plt.close()
elif not axes:
# Draw on-screen
Expand Down
Loading
Loading