cape.cfdx.cntl
: Base module for CFD operations and processing¶
This module provides tools and templates for tools to interact with
various CFD codes and their input files. The base class is
cape.cfdx.cntl.Cntl
, and the derivative classes include
cape.pycart.cntl.Cntl
. This module creates folders for cases,
copies files, and can be used as an interface to perform most of the
tasks that Cape can accomplish except for running individual cases.
The control module is set up as a Python interface for thec master JSON file, which contains the settings to be used for a given CFD project.
The derivative classes are used to read input files, set up cases, submit and/or run cases, and be an interface for the various Cape options as they are customized for the various CFD solvers. The individualized modules are below.
- cape.cfdx.cntl.COL_HEADERS = {'case': 'Case Folder', 'cpu-abbrev': 'CPU Hours', 'cpu-hours': 'CPU Time', 'frun': 'Config/Run Directory', 'gpu-abbrev': 'GPU Hours', 'gpu-hours': 'GPU Hours', 'group': 'Group Folder', 'i': 'Case', 'job': 'Job ID', 'job-id': 'Job ID', 'phase': 'Phase', 'progress': 'Iterations', 'queue': 'Que', 'status': 'Status'}¶
- class cape.cfdx.cntl.CaseCache(prop: str)¶
Cache of one property for cases in a run matrix
- Call:
>>> cache = CaseCache(prop)
- Inputs:
- prop:
str
Name of property being cached
- prop:
- Outputs:
- Attributes:
- class cape.cfdx.cntl.CaseLoopArgs(*args, **kw)¶
Argument parser for
Cntl.caseloop_verbose()
- class cape.cfdx.cntl.Cntl(fname: str | None = None)¶
Class to handle options, setup, and execution of CFD codes
- Call:
>>> cntl = cape.Cntl(fname="cape.json")
- Inputs:
- fname:
str
Name of JSON settings file from which to read options
- fname:
- Outputs:
- cntl:
Cntl
Instance of CAPE control interface
- cntl:
- Class attributes:
_case_cls
_fjson_default
_name
_opts_cls
_report_cls
_solver
_warnmode_default
_warnmode_envvar
_zombie_files
- Attributes:
- Versions:
2015-09-20
@ddalle
: Started2016-04-01
@ddalle
: v1.0
- ApplyCase(i: int, **kw)¶
Rewrite CAPE inputs for case i
- Call:
>>> cntl.ApplyCase(i, n=1, j=None, imax=None)
- Inputs:
- cntl:
cape.pyfun.cntl.Cntl
CAPE main control instance
- i:
int
Run index
- qsub:
True
| {False
} Option to submit case after applying settings
- nPhase:
int
Phase to apply settings to
- cntl:
- ApplyCases(**kw)¶
Reapply settings to one or more cases
- Call:
>>> cntl.ApplyCases(cons=[], j=None, extend=1, **kw)
- Inputs:
- Versions:
2016-12-12
@ddalle
: v1.0
- ArchiveCase(i: int, test: bool = False)¶
Perform
--archive
archiving on one caseThere are no restrictions on the status of the case for this action.
- Call:
>>> cntl.CleanCase(i, test=False)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Instance of control interface
- i:
int
Case index
- test:
True
| {False
} Log file/folder actions but don’t actually delete/copy
- cntl:
- Versions:
2024-09-18
@ddalle
: v1.0
- ArchiveCases(**kw)¶
Archive completed cases and clean them up if specified
- Call:
>>> cntl.ArchiveCases() >>> cntl.ArchiveCases(cons=[], **kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Instance of overall control interface
- cons:
list
[str
] List of constraints
- I:
list
[int
] List of indices
- cntl:
- Versions:
2016-12-09
@ddalle
: v1.02024-09-19
@ddalle
: v2.0
- CaseFunction(i: int)¶
Run one or more functions at “prepare-case” hook
This function is executed at the beginning of
PrepareCase(i)()
.This is meant to serve as a filter if a user wants to change the settings for some subset of the cases. Using this function can change any setting, which can be dependent on the case i.
This calls the function(s) in the global
"CaseFunction"
option from the JSON file. These functions must take cntl as an input and the case number i. The function(s) are usually from a module imported via the"Modules"
option. See the following example:"Modules": ["testmod"], "CaseFunction": ["testmod.testfunc"]
This leads CAPE to call
testmod.testfunc(cntl, i)
at the beginning ofPrepareCase()
for each case i in the run matrix. The function is also called at the beginning ofApplyCase()
ifpyfun --apply
or similar is issued.- Call:
>>> cntl.CaseFunction(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall control interface
- i:
int
Case number
- cntl:
- Versions:
2017-04-05
@ddalle
: v1.0
- See also:
- CaseGetCurrentPhase() int ¶
Get the current phase number from the appropriate module
This function utilizes the
cape.cfdx.case
module, and so it must be copied to the definition for each solver’s control class.- Call:
>>> j = cntl.CaseGetCurrentPhase()
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- cntl:
- Outputs:
- j:
int
|None
Phase number
- j:
- Versions:
2017-06-29
@ddalle
: v1.02023-07-06
@ddalle
: v1.1; useCaseRunner
- CheckBatch() int ¶
Check to see if we are running inside a batch job
This looks for environment variables to see if this is running inside a batch job. Currently supports slurm and PBS.
- Call:
>>> q = cntl.CheckBatch()
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- cntl:
- Outputs:
- jobid:
int
0
if no batch environment was detected
- jobid:
- Versions:
2023-12-13
@dvicker
: v1.02023-12-18
@ddalle
: v1.1; debug
- CheckCase(i: int, force: bool = False, v: bool = False) int | None ¶
Check current status of case i
Because the file structure is different for each solver, some of this method may need customization. This customization, however, can be kept to the functions
cape.cfdx.casecntl.GetCurrentIter()
andcape.cfdx.cntl.Cntl.CheckNone()
.- Call:
>>> n = cntl.CheckCase(i, v=False)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Index of the case to check (0-based)
- v:
True
| {False
} Verbose flag; prints messages if n is
None
- cntl:
- Outputs:
- n:
int
|None
Number of completed iterations or
None
if not set up
- n:
- Versions:
2014-09-27
@ddalle
: v1.02015-09-27
@ddalle
: v2.0; generic2015-10-14
@ddalle
: v2.1; nocase
req2017-02-22
@ddalle
: v2.2; add verbose flag2023-11-06
@ddalle
: v2.3; callsetx_i(i)
- CheckError(i: int) bool ¶
Check if a case has a failure
- Call:
>>> q = cntl.CheckError(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Run index
- cntl:
- Outputs:
- q:
bool
If
True
, case hasFAIL
file in it
- q:
- Versions:
2015-01-02
@ddalle
: v1.0
- CheckFM(**kw)¶
Display missing force & moment components
- CheckLL(**kw)¶
Display missing line load components
- CheckNone(v: bool = False) bool ¶
Check if the current directory has the needed files to run
This function needs to be customized for each CFD solver so that it checks for the appropriate files.
- Call:
>>> q = cntl.CheckNone(v=False)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Cape control interface
- v:
True
| {False
} Verbose flag; prints message if q is
True
- cntl:
- Outputs:
- q:
`True
| False` Whether or not case is missing files
- q:
- Versions:
2015-09-27
@ddalle
: v1.02017-02-22
@ddalle
: v1.1, verbosity option
- CheckPhase(i: int, v: bool = False) int | None ¶
Check current phase number of run i
- Call:
>>> n = cntl.CheckPhase(i, v=False)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Index of the case to check (0-based)
- v:
True
| {False
} Verbose flag; prints messages if n is
None
- cntl:
- Outputs:
- j:
int
|None
Phase number
- j:
- Versions:
2017-06-29
@ddalle
: v1.0
- CheckRunning(i)¶
Check if a case is currently running
- Call:
>>> q = cntl.CheckRunning(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Run index
- cntl:
- Outputs:
- q:
bool
If
True
, case hasRUNNING
file in it
- q:
- Versions:
2014-10-03
@ddalle
: v1.0
- CheckTriqFM(**kw)¶
Display missing TriqFM components
- CheckTriqPoint(**kw)¶
Display missing TriqPoint components
- CheckUsedPhase(i: int, v: bool = False)¶
Check maximum phase number run at least once
- Call:
>>> j, n = cntl.CheckUsedPhase(i, v=False)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Index of the case to check (0-based)
- v:
True
| {False
} Verbose flag; prints messages if n is
None
- cntl:
- Outputs:
- Versions:
2017-06-29
@ddalle
: v1.02017-07-11
@ddalle
: v1.1; verbosity option2025-03-02
@ddalle
: v2.0; use CaseRunner
- CheckZombie(i)¶
Check a case for
ZOMBIE
statusA running case is declared a zombie if none of the listed files (by default
*.out
) have been modified in the last 30 minutes. However, a case cannot be a zombie unless it contains aRUNNING
file and returnsTrue
fromCheckRunning()
.- Call:
>>> q = cntl.CheckZombie(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Run index
- cntl:
- Outputs:
- q:
bool
True
if no listed files have been modified recently
- q:
- Versions:
2017-04-04
@ddalle
: v1.02021-01-25
@ddalle
: v1.1; use cls._zombie_files
- CleanCase(i: int, test: bool = False)¶
Perform
--clean
archiving on one caseThere are no restrictions on the status of the case for this action.
- Call:
>>> cntl.CleanCase(i, test=False)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Instance of control interface
- i:
int
Case index
- test:
True
| {False
} Log file/folder actions but don’t actually delete/copy
- cntl:
- CleanCases(**kw)¶
Clean a list of cases using Progress archive options only
- Call:
>>> cntl.CleanCases(**kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Instance of control interface
- cntl:
- Versions:
2017-03-13
@ddalle
: v1.02024-09-18
@ddalle
: v2.0
- CountQueuedCases(I: list | None = None, u: str | None = None, **kw) int ¶
Count cases that have currently active PBS/Slurm jobs
- Call:
>>> n = cntl.CountQueuedCases(I=None, u=None, **kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- I: {
None
} |list
[int
] List of indices
- u:
str
User name (defaults to process username)
- kw:
dict
Other kwargs used to subset the run matrix
- cntl:
- Outputs:
- n:
int
Number of running or queued jobs (not counting the job from which function is called, if applicable)
- n:
- Versions:
2024-01-12
@ddalle
: v1.02024-01-17
@ddalle
: v1.1; check for this_job2025-05-01
@ddalle
: v1.2; remove jobs kwarg
- CountRunningCases(I: list, jobs: dict | None = None, u: str | None = None) int ¶
Count number of running cases via the batch system
Also print a status of the running jobs.
- Call:
>>> n = cntl.CountRunningCases(I, jobs=None, u=None)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- I:
list
[int
] List of indices
- jobs:
dict
Information on each job by ID number
- u:
str
User name (defaults to process username)
- cntl:
- Outputs:
- n:
int
Number of running or queued jobs
- n:
- Versions:
2023-12-08
@dvicker
: v1.0
- DataBook¶
cape.cfdx.databook.DataBook
Interface to post-processed data
- DeleteCase(i: int, **kw)¶
Delete a case
This function deletes a case’s PBS job and removes the entire directory. By default, the method prompts for user’s confirmation before deleting; set prompt to
False
to delete without prompt.- Call:
>>> n = cntl.DeleteCase(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Cape control interface
- i:
int
Index of the case to check (0-based)
- prompt: {
True
} |False
Whether or not to prompt user before deleting case
- cntl:
- Outputs:
- n:
0
|1
Number of folders deleted
- n:
- Versions:
2018-11-20
@ddalle
: v1.0
- Dezombie(**kw)¶
Clean up any ZOMBIE cases
- Call:
>>> cntl.Dezombie(**kw)
- Inputs:
- Versions:
2021-10-14
@ddalle
: v1.0
- DisplayStatus(**kw)¶
Display current status for all cases
This prints case names, current iteration numbers, and so on. This is the function that is called when the user issues a system command like
cape -c
.- Call:
>>> cntl.DisplayStatus(j=False)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- j:
bool
Whether or not to display job ID numbers
- cons:
list
[str
] List of constraints like
'Mach<=0.5'
- cntl:
- Versions:
2014-10-04
@ddalle
: v1.02014-12-09
@ddalle
: v2.0;--cons
2025-06-20
@ddalle
: v3.0; use caseloop_verbose()
- ExecScript(**kw) int ¶
Execute a script in a given case folder
This function is the interface to command-line calls using the
-e
flag, such aspycart -e 'ls -lh'
.- Call:
>>> ierr = cntl.ExecScript(i, cmd)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Case index (0-based)
- cntl:
- Outputs:
- ierr:
None
|int
Exit status from the command
- ierr:
- Versions:
2016-08-26
@ddalle
: v1.02024-12-09
@jfdiaz3
:v1.1
- ExtendCase(i: int, n: int = 1, j: int | None = None, imax: int | None = None)¶
Add iterations to case i by repeating the last phase
- Call:
>>> cntl.ExtendCase(i, n=1, j=None, imax=None)
- Inputs:
- cntl:
cape.pyfun.cntl.Cntl
CAPE main control instance
- i:
int
Case index
- n: {
1
} | positiveint
Add n times steps to the total iteration count
- j: {
None
} |int
Optional phase to extend
- imax: {
None
} | nonnegativeint
Use imax as the maximum iteration count
- cntl:
- ExtendCases(**kw)¶
Extend one or more case by a number of iterations
By default, this applies to the final phase, but the phase number j can also be specified as input. The number of additional iterations is generally the nominal number of iterations that phase j would normally run.
- Call:
>>> cntl.ExtendCases(cons=[], extend=1, **kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Instance of overall control interface
- extend: {
True
} | positiveint
Extend phase j by extend nominal runs
- imax: {
None
} |int
Do not increase iteration number beyond imax
- j, phase: {
None
} |int
Optional index of phase to extend
- cons:
list
[str
] List of constraints
- I:
list
[int
] List of indices
- cntl:
- Versions:
2016-12-12
@ddalle
: v1.0
- FilterUser(i: int, **kw) bool ¶
Determine if case i is assigned to current user
- Call:
>>> q = cntl.FilterUser(i, **kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Index of the case to check (0-based)
- u, user:
str
User name (default: executing process’s username) for comparing to run matrix
- cntl:
- Outputs:
- q:
bool
Whether user is owner of case i
- q:
- Versions:
2017-07-10
@ddalle
: v1.0
- GetCPUTime(i: int)¶
Read a CAPE-style core-hour file from a case
This function needs to be customized for each solver because it needs to know the name of the file in which timing data is saved. It defaults to
cape_time.dat
. Modifying this command is a one-line fix with a call tocape.cfdx.cntl.Cntl.GetCPUTimeFromFile()
with the correct file name.- Call:
>>> CPUt = cntl.GetCPUTime(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
CAPE control interface
- i:
int
Case index
- cntl:
- Outputs:
- CPUt:
float
|None
Total core hours used in this job
- CPUt:
- Versions:
2015-12-22
@ddalle
: v1.02016-08-30
@ddalle
: v1.1; check forRUNNING
2016-08-31
@ddalle
: v1.2; useGetCPUTimeBoth
2023-07-09
@ddalle
: v2.0; useCaseRunner
- GetCaseIndex(frun: str) int | None ¶
Get index of a case in the current run matrix
- Call:
>>> i = cntl.GetCaseIndex(frun)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Cape control interface
- frun:
str
Name of case, must match exactly
- cntl:
- Outputs:
- i:
int
|None
Index of case with name frun in run matrix, if present
- i:
- Versions:
2024-08-15
@ddalle
: v1.02024-10-16
@ddalle
: v1.1; move toRunMatrix
- GetCurrentIter(i: int, force: bool = False) int ¶
Get the current iteration number (using
case
)This function utilizes the
cape.cfdx.case
module, and so it must be copied to the definition for each solver’s control class.- Call:
>>> n = cntl.GetCurrentIter(i, force=False)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Index of the case to check (0-based)
- force:
True
| {False
} Option to ignore cache
- cntl:
- Outputs:
- n:
int
Number of completed iterations
- n:
- Versions:
2015-10-14
@ddalle
: v1.02023-07-07
@ddalle
: v2.0; useCaseRunner
2025-03-01
@ddalle
: v3.0; add caching
- GetLastIter(i: int) int ¶
Get minimum required iteration for a given case
- Call:
>>> nIter = cntl.GetLastIter(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Cape control interface
- i:
int
Run index
- cntl:
- Outputs:
- nIter:
int
Number of iterations required for case i
- nIter:
- Versions:
2014-10-03
@ddalle
: v1.0
- GetPBSJobID(i: int) str | None ¶
Get PBS job number if one exists
- Call:
>>> jobID = cntl.GetPBSJobID(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Run index
- cntl:
- Outputs:
- jobID:
None
|str
Most recent PBS/Slurm job name, if able
- jobID:
- Versions:
2014-10-06
@ddalle
: v1.02024-01-12
@ddalle
: v1.1; remove CheckCase() for speed
- GetPBSName(i: int) str ¶
Get PBS name for a given case
- Call:
>>> lbl = cntl.GetPBSName(i, pre=None)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Run index
- pre: {
None
} |str
Prefix for PBS job name
- cntl:
- Outputs:
- lbl:
str
Short name for the PBS job, visile via
qstat
- lbl:
- Versions:
2014-09-30
@ddalle
: v1.02016-12-20
@ddalle
: v1.1, moved to x
- GetPhaseBreaks() list ¶
Get expected iteration numbers at phase breaks
This fills in
0
entries in RunControl PhaseIters and returns the filled-out list.- Call:
>>> PI = cntl.GetPhaseBreaks()
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Cape control interface
- cntl:
- Outputs:
- Versions:
2017-04-12
@ddalle
: v1.0
- GetProjectRootName(j: int = 0) str ¶
Get the project root name
The JSON file overrides the value from the namelist file if appropriate
- Call:
>>> name = cntl.GetProjectName(j=0)
- Inputs:
- Outputs:
- name:
str
Project root name
- name:
- Versions:
2015-10-18
@ddalle
: v1.0 (pyfun)2023-06-15
@ddalle
: v1.1; cleaner logic2024-10-22
@ddalle
: v2.0; moved tocfdx
2025-07-15
@ddalle
: v2.1; move intoCntlBase
- GetSurfCT_ExitArea(key: str, i: int, comp: str | None = None) float ¶
Get exit area for a CT trajectory key
This can use either the area ratio (if available) or calculate from the exit Mach number. The input area is determined from the component ID. If using the exit Mach number M2, the input Mach number M1 is also needed. The relationship between area ratio and exit Mach is given below.
\[\begin{split}\\frac{A_2}{A_1} = \\frac{M_1}{M_2}\\left( \\frac{1+\\frac{\\gamma-1}{2}M_2^2}{ 1+\\frac{\\gamma-1}{2}M_1^2} \\right) ^ {\\frac{1}{2}\\frac{\\gamma+1}{\\gamma-1}}\end{split}\]- Call:
>>> A2 = cntl.GetSurfCT_ExitArea(key, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- key:
str
Name of trajectory key to check
- i:
int
Case number
- comp: {
None
} |str
Name of component for which to get BCs
- cntl:
- Outputs:
- Versions:
2016-04-13
@ddalle
: v1.0
- GetSurfCT_ExitMach(key: str, i: int, comp: str | None = None) float ¶
Get exit Mach number for a CT trajectory key
This can use either the
"ExitMach"
parameter (if available) or calculate from the area ratio. If using the area ratio, the input Mach number is also needed. The relationship between area ratio and exit Mach is given below.\[\frac{A_2}{A_1} = \frac{M_1}{M_2}\left( \frac{1+\frac{\gamma-1}{2}M_2^2}{ 1+\frac{\gamma-1}{2}M_1^2} \right) ^ {\frac{1}{2}\frac{\gamma+1}{\gamma-1}}\]- Call:
>>> M2 = cntl.GetSurfCT_ExitMach(key, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- key:
str
Name of trajectory key to check
- i:
int
Case number
- comp: {
None
} |str
Name of component for which to get BCs
- cntl:
- Outputs:
- M2:
float
Exit Mach number
- M2:
- Versions:
2016-04-13
@ddalle
: v1.0
- GetSurfCT_RefArea(key: str, i: int) float ¶
Get reference area for surface CT trajectory key
This references the
"RefArea"
parameter of the definition for the run matrix variable key. The user should set this parameter to1.0
if thrust inputs are given as dimensional values.If this is
None
, it returns the global reference area; if it is a string the reference area comes from the reference area for that component usingcntl.opts.get_RefArea(comp)
.- Call:
>>> Aref = cntl.GetSurfCT_RefArea(key, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- key:
str
Name of trajectory key to check
- i:
int
Case number
- cntl:
- Outputs:
- Aref:
float
Reference area for normalizing thrust coefficients
- Aref:
- Versions:
2016-04-13
@ddalle
: v1.0
- ImportModules()¶
Import user-defined modules if specified in the options
All modules from the
"Modules"
global option of the JSON file (cntl.opts["Modules"]
) will be imported and saved as attributes of cntl. For example, if the user wants to use a module calleddac3
, it will be imported as cntl.dac3. A noncomprehensive list of disallowed module names is below.DataBook, RootDir, jobs, opts, tri, x
The name of any method of this class is also disallowed. However, if the user wishes to import a module whose name is disallowed, he/she can use a dictionary to specify a different name to import the module as. For example, the user may import a module called
tri
asmytri
using the following JSON syntax."Modules": [{"tri": "mytri"}]
- Call:
>>> cntl.ImportModules()
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Instance of Cape control interface
- cntl:
- Versions:
2014-10-08
@ddalle
: v1.0 (pycart
)2015-09-20
@ddalle
: v1.02022-04-12
@ddalle
: v2.0; use self.modules
- InitFunction()¶
Run one or more functions a “initialization” hook
This calls the function(s) in the global
"InitFunction"
option from the JSON file. These functions must take cntl as an input, and they are usually from a module imported via the"Modules"
option. See the following example:"Modules": ["testmod"], "InitFunction": ["testmod.testfunc"]
This leads CAPE to call
testmod.testfunc(cntl)
.- Call:
>>> cntl.InitFunction()
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall control interface
- cntl:
- Versions:
2017-04-04
@ddalle
: v1.02022-04-12
@ddalle
: v2.0; use _exec_funclist()
- MarkERROR(**kw)¶
Mark one or more cases as ERROR and rewrite matrix
- Call:
>>> cntl.MarkERROR(**kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- I:
list
[int
] List of indices
- cons:
list
[str
] List of constraints like
'Mach<=0.5'
- flag: {
"E"
} |"e"
|"ERROR"
|"$E"
Marker to use to denote status
- cntl:
- Versions:
2019-06-14
@ddalle
: v1.0
- MarkPASS(**kw)¶
Mark one or more cases as PASS and rewrite matrix
- Call:
>>> cntl.MarkPASS(**kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- I:
list
[int
] List of indices
- cons:
list
[str
] List of constraints like
'Mach<=0.5'
- flag: {
"p"
} |"P"
|"PASS"
|"$p"
Marker to use to denote status
- cntl:
- Versions:
2019-06-14
@ddalle
: v1.0
- PrepareCase(i: int)¶
Prepare case for running if necessary
This function creates the folder, copies mesh files, and saves settings and input files. All of these tasks are completed only if they have not already been completed, and it needs to be customized for each CFD solver.
- Call:
>>> cntl.PrepareCase(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Index of case to analyze
- cntl:
- Versions:
2014-09-30
@ddalle
: v1.02015-09-27
@ddalle
: v2.0, convert to template
- PrepareConfig(i: int)¶
Apply rotations, translations, etc. to
Config.xml
- Call:
>>> cntl.PrepareConfig(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Case index
- cntl:
- Versions:
2016-08-23
@ddalle
: v1.0
- PrepareConfigFunction(key: str, i: int)¶
Apply special configuration modification function for a case
- Call:
>>> cntl.PrepareConfigFunction(key, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- key:
str
Name of key
- i:
int
Index of the case to check (0-based)
- cntl:
- Versions:
2016-08-23
@ddalle
: v1.02022-04-13
@ddalle
: v2.0; exec_modfunction()
- PrepareConfigRotation(key: str, i: int)¶
Apply a rotation to a component or components
- Call:
>>> cntl.PrepareConfigRotation(key, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- key:
str
Name of the trajectory key
- i:
int
Index of the case to check (0-based)
- cntl:
- Versions:
2016-08-23
@ddalle
: v1.0
- PrepareConfigTranslation(key: str, i: int)¶
Apply a translation to a component or components
- Call:
>>> cntl.PrepareConfigTranslation(key, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- key:
str
Name of variable from which to get value
- i:
int
Index of the case to check (0-based)
- cntl:
- Versions:
2016-08-23
@ddalle
: v1.0
- PrepareMesh(i: int)¶
Prepare the mesh for case i if necessary
- Call:
>>> cntl.PrepareMesh(i)
- Inputs:
- cntl:
cape.pyfun.cntl.Cntl
Instance of control class
- i:
int
Case index
- cntl:
- Versions:
2015-10-19
@ddalle
: v1.0 (pyfun)2024-11-04
@ddalle
: v1.3 (pyfun)2024-11-07
@ddalle
: v1.0
- PrepareMeshUnstructured(i: int)¶
Prepare the mesh for case i if necessary
- Call:
>>> cntl.PrepareMeshUnstructured(i)
- Inputs:
- cntl:
cape.pyfun.cntl.Cntl
Instance of control class
- i:
int
Case index
- cntl:
- Versions:
2015-10-19
@ddalle
: v1.0 (pyfun)2024-11-04
@ddalle
: v1.3 (pyfun)2024-11-07
@ddalle
: v1.02025-07-15
@ddalle
: v1.1; name change
- PreparePoints(i: int)¶
Calculate the value of each named
"Point"
for case i- Call:
>>> x = cntl.PreparePoints(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Case index
- cntl:
- Versions:
2022-03-07
@ddalle
: v1.0
- PreparePointsRotation(key: str, i: int)¶
Apply a rotation to named config points for one col
- Call:
>>> cntl.PreparePointsRotation(key, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- key:
str
Name of the trajectory key
- i:
int
Index of the case to check (0-based)
- cntl:
- Versions:
2022-03-07
@ddalle
: v1.0
- PreparePointsTranslation(key: str, i: int)¶
Apply a translation to named config points for one col
- Call:
>>> cntl.PreparePointsTranslation(key, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- key:
str
Name of the trajectory key
- i:
int
Case index
- cntl:
- Versions:
2022-03-07
@ddalle
: v1.0
- PrepareTri(i: int)¶
Rotate/translate/etc. triangulation for given case
- Call:
>>> cntl.PrepareTri(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Index of the case to check (0-based)
- cntl:
- Versions:
2014-12-01
@ddalle
: v1.02016-04-05
@ddalle
: v1.1, pycart -> cape
- PrepareTriFunction(key: str, i: int)¶
Apply special surf modification function for a case
- Call:
>>> cntl.PrepareTriFunction(key, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- key:
str
Name of key
- i:
int
Index of the case to check (0-based)
- cntl:
- Versions:
2015-09-11
@ddalle
: v1.02016-04-05
@ddalle
: v1.1, pycart -> cape2022-04-13
@ddalle
: v2.0; exec_modfunction()
- PrepareTriRotation(key: str, i: int)¶
Apply a rotation to a component or components
- Call:
>>> cntl.PrepareTriRotation(key, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- key:
str
Run matrix for rotation defn’
- i:
int
Index of the case to check (0-based)
- cntl:
- Versions:
2015-09-11
@ddalle
: v1.02016-04-05
@ddalle
: v1.1, pycart -> cape
- PrepareTriTranslation(key: str, i: int)¶
Apply a translation to a component or components
- Call:
>>> cntl.PrepareTriTranslation(key, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- key:
str
Run matrix key for translation def’n
- i:
int
Index of the case to check (0-based)
- cntl:
- Versions:
2015-09-11
@ddalle
: v1.02016-04-05
@ddalle
: v1.1, pycart -> cape
- ReadCaseRunner(i: int) CaseRunner ¶
Read CaseRunner into slot
- Call:
>>> runner = cntl.ReadCaseRunner(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Index of the case to check (0-based)
- cntl:
- Outputs:
- runner:
CaseRunner
Controller to run one case of solver
- runner:
- ReadConfig(f: bool = False) ConfigXML | ConfigJSON ¶
Read
Config.xml
or other surf configuration format- Call:
>>> cntl.ReadConfig(f=False)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- f:
True
| {False
} Option to reread existing cntl.config
- cntl:
- Versions:
2016-06-10
@ddalle
: v1.02016-10-21
@ddalle
: v2.0, addedConfig.json
2020-09-01
@ddalle
: v2.1, add f kwarg
- ReadFolderCaseRunner(fdir: str) CaseRunner ¶
Read a
CaseRunner
from a folder by name- Call:
>>> runner = cntl.ReadFolderCaseRunner(fdir)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- fdir:
str
Folder of case to read from
- cntl:
- Outputs:
- runner:
CaseRunner
Controller to run one case of solver
- runner:
- ReadReport(rep: str) Report ¶
Read a report interface
- Call:
>>> rep = cntl.ReadReport(rep)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
CAPE main control instance
- rep:
str
Name of report
- cntl:
- Outputs:
- rep:
cape.cfdx.report.Report
Report interface
- rep:
- Versions:
2018-10-19
@ddalle
: Version 1.0
- ReadTri()¶
Read initial triangulation file(s)
- Call:
>>> cntl.ReadTri()
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- cntl:
- Versions:
2014-08-30
@ddalle
: v1.0
- RevertOptions()¶
Revert to cntl.opts0 as working options
- Call:
>>> cntl.ResetOptions()
- Inputs:
- cntl:
Cntl
CAPE solver control interface
- cntl:
- Versions:
2021-07-31
@ddalle
: v1.0
- SaveOptions()¶
Copy cntl.opts and store it as cntl.opts0
- Call:
>>> cntl.SaveOptions()
- Inputs:
- cntl:
Cntl
CAPE solver control interface
- cntl:
- Versions:
2021-07-31
@ddalle
: v1.0
- SkeletonCase(i: int, test: bool = False)¶
Perform
--skeleton
archiving on one caseThere are no restrictions on the status of the case for this action.
- Call:
>>> cntl.SkeletonCase(i, test=False)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Instance of control interface
- i:
int
Case index
- test:
True
| {False
} Log file/folder actions but don’t actually delete/copy
- cntl:
- Versions:
2024-09-18
@ddalle
: v1.0
- SkeletonCases(**kw)¶
Archive completed cases and delete all but a few files
- Call:
>>> cntl.SkeletonCases() >>> cntl.SkeletonCases(cons=[], **kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Instance of overall control interface
- cons:
list
[str
] List of constraints
- I:
list
[int
] List of indices
- cntl:
- Versions:
2016-12-14
@ddalle
: v1.02024-09-19
@ddalle
: v2.0
- StartCase(i: int)¶
Start a case by either submitting it or running it
This function checks whether or not a case is submittable. If so, the case is submitted via
cape.cfdx.queue.pqsub()
, and otherwise the case is started using a system call.Before starting case, this function checks the folder using
cape.cfdx.cntl.CheckCase()
; if this function returnsNone
, the case is not started. Actual starting of the case is done usingCaseStartCase()
, which has a specific version for each CFD solver.- Call:
>>> pbs = cntl.StartCase(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Index of the case to check (0-based)
- cntl:
- Outputs:
- pbs:
int
|None
PBS job ID if submitted successfully
- pbs:
- StopCase(i: int)¶
Stop a case if running
This function deletes a case’s PBS job and removes the
RUNNING
file if it exists.- Call:
>>> cntl.StopCase(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Cape control interface
- i:
int
Index of the case to check (0-based)
- cntl:
- UnarchiveCases(**kw)¶
Unarchive a list of cases
- Call:
>>> cntl.UnarchiveCases(**kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Instance of control interface
- cntl:
- Versions:
2017-03-13
@ddalle
: v1.02023-10-20
@ddalle
: v1.1; arbitrary-depth frun2024-09-20
@ddalle
: v2.0; use CaseArchivist
- UnmarkCase(**kw)¶
Remove PASS or ERROR marking from one or more cases
- Call:
>>> cntl.UnmarkCase(**kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- I:
list
[int
] List of indices
- cons:
list
[str
] List of constraints like
'Mach<=0.5'
- cntl:
- Versions:
2019-06-14
@ddalle
: v1.0
- UpdateCaseProp(**kw)¶
Update generic-property databook for one or more comp
- UpdateFM(**kw)¶
Collect force and moment data
- Call:
>>> cntl.UpdateFM(cons=[], **kw)
- Inputs:
- Versions:
2014-12-12
@ddalle
: v1.0- 2014-12-22
@ddalle
: v2.0 Complete rewrite of DataBook class
Eliminate “Aero” class
- 2014-12-22
2017-04-25
@ddalle
: v2.1, add wildcards2018-10-19
@ddalle
: v3.0, rename from Aero()
- UpdateLL(**kw)¶
Update one or more line load data books
- Call:
>>> cntl.UpdateLL(ll=None, **kw)
- Inputs:
- Versions:
2016-06-07
@ddalle
: v1.02016-12-21
@ddalle
: v1.1; add pbs flag2017-04-25
@ddalle
: v1.2; rm pbs, add delete2025-08-13
@ddalle
; v2.0; use dex
- UpdatePyFuncDataBook(**kw)¶
Update Python function databook for one or more comp
- UpdateReport(**kw)¶
Update a report
- Call:
>>> cntl.UpdateReport(**kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
CAPE main control instance
- report: {
True
} |str
Name of report (or first report)
- I: {
None
} |np.ndarray
[int
] Indices to report
- cntl:
- Versions:
2025-08-25
@ddalle
: v1.0
- UpdateSurfCp(**kw)¶
Collect surface pressure data
- Call:
>>> cntl.UpdateSurfCp(cons=[], **kw)
- Inputs:
- Versions:
2014-12-12
@ddalle
: v1.0- 2014-12-22
@ddalle
: v2.0 Complete rewrite of DataBook class
Eliminate “Aero” class
- 2014-12-22
2017-04-25
@ddalle
: v2.1, add wildcards2018-10-19
@ddalle
: v3.0, rename from Aero()
- UpdateTS(**kw)¶
Update one or more time series data books
- Call:
>>> cntl.UpdateTS(ts=None, **kw)
- Inputs:
- Versions:
2016-06-07
@ddalle
: v1.02016-12-21
@ddalle
: v1.1, Add pbs flag- 2017-04-25
@ddalle
: v1.2 Removed pbs
Added
--delete
- 2017-04-25
- UpdateTriqFM(**kw)¶
Update one or more TriqFM data books
- UpdateTriqPoint(**kw)¶
Update one or more TriqPoint point sensor data books
- WriteCaseJSON(i: int, rc: dict | None = None)¶
Write JSON file with run control settings for case i
- Call:
>>> cntl.WriteCaseJSON(i, rc=None)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Generic control class
- i:
int
Run index
- rc: {
None
} |dict
If specified, write specified “RunControl” options
- cntl:
- Versions:
2015-10-19
@ddalle
: v1.02023-03-31
@ddalle
: v2.0; manual options input2023-08-29
@ddalle
: v2.1; call sample_dict()2024-08-24
@ddalle
: v2.2; use CaseRunner2025-01-23
@ddalle
: v2.3; eliminate Arvhive settings
- WriteConditionsJSON(i: int)¶
Write JSON file with run matrix settings for case i
- Call:
>>> cntl.WriteConditionsJSON(i, rc=None)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Generic control class
- i:
int
Run index
- rc: {
None
} |dict
If specified, write specified “RunControl” options
- cntl:
- Versions:
2021-09-08
@ddalle
: v1.0
- WritePBS(i: int)¶
Write the PBS script(s) for a given case
- Call:
>>> cntl.WritePBS(i)
- Inputs:
- cntl:
cape.pyfun.cntl.Cntl
CAPE main control instance
- i:
int
Run index
- cntl:
- Versions:
2014-10-19
@ddalle
: v1.02023-10-20
@ddalle
: v1.1; arbitrary frun depth2024-08-01
@ddalle
: v2.0; solver-agnostic
- WritePBSHeader(fp: IOBase, i: int | None = None, j: int = 0, typ: str | None = None, wd: str | None = None)¶
Write common part of PBS or Slurm script
- Call:
>>> cntl.WritePBSHeader(fp, i=None, j=0, typ=None, wd=None)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- fp:
IOBase
Open file handle
- i: {
None
} |int
Case index (ignore if
None
); used for PBS job name- j:
int
Phase number
- typ: {
None
} |"batch"
|"post"
Group of PBS options to use
- wd: {
None
} |str
Folder to enter when starting the job
- cntl:
- Versions:
2015-09-30
@ddalle
: v1.0, fork WritePBS()2016-09-25
@ddalle
: v1.1, “BatchPBS”- 2016-12-20
@ddalle
: v1.2 Consolidated to opts
Added prefix
- 2016-12-20
- 2024-08-15
@ddalle
: v1.3 Use cntl.opts.name as prefix
User-controlled job name length, longer default
- 2024-08-15
- caseloop(casefunc: Callable, **kw)¶
Loop through cases and execute function for each case
- Call:
>>> cntl.caseloop(casefun, **kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
CAPE run matrix control instance
- indent: {
0
} |int
Number of spaces to indent each case name
- cntl:
- Versions:
2025-02-12
@ddalle
: v1.0
- caseloop_verbose(casefunc: Callable | None = None, **kw) int ¶
Loop through cases and produce verbose table
- Call:
>>> n = cntl.caseloop_verbose(casefunc, **kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- casefunc: {
None
} |Callable
Optional function to run in each case folder
- I: {
None
} |np.ndarray
[int
] Case indices
- cntl:
- Outputs:
- n:
int
Number of cases started/submitted
- n:
- Versions:
2025-06-19
@ddalle
: v1.0
- caserunner¶
CaseRunner
Slot for the current case runner
- check_case_job(i: int, active: bool = True) str ¶
Get queue status of the PBS/Slurm job from case i
- Call:
>>> s = cntl.check_case_job(i, active=True)
- Inputs:
- Outputs:
- s:
str
Job queue status
-
: not in queueQ
: job queued (not running)R
: job runningH
: job heldE
: job error status
- s:
- Versions:
2025-05-04
@ddalle
: v1.0
- check_case_status(i: int, active: bool = True) str ¶
Get queue status of the PBS/Slurm job from case i
- Call:
>>> sts = cntl.check_case_job(i, active=True)
- Inputs:
- Outputs:
- sts:
str
Case status
---
: folder does not existINCOMP
: case incomplete but [partially] set upQUEUE
: case waiting in PBS/Slurm queueRUNNING
: case currently runningDONE
: all phases and iterations completePASS
: DONE and marked by user as passedZOMBIE
: seems running; but no recent file updatesPASS*
: case marked by user but not DONEERROR
: case marked as errorFAIL
: case failed but not marked by user
- sts:
- Versions:
2025-05-04
@ddalle
: v1.0
- copy_files(i: int)¶
Copy files from Mesh section
This applies to both CopyFiles and CopyAsFiles in the Mesh section. The former will copy a given file into the run folder for case i using the base name of the original (source) file. Using
"Mesh": { "CopyAsFiles": { "inputs/mesh-config02.ugrid": "mesh.ugrid" } }
will copy the file
inputs/mesh-config02.ugrid
into the run folder but name itmesh.ugrid
there.- Call:
>>> cntl.copy_files(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Case index
- cntl:
- Versions:
2025-09-19
@ddalle
: v1.0
- exec_cntl_function_dict(funcspec: dict)¶
Execute a Cntl function, accessing user-specified modules
- Call:
>>> v = cntl.exec_cntl_function_dict(funcspec)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall control interface
- funcspec:
dict
Function opts parsed by
UserFuncOpts
- cntl:
- Outputs:
- v: any
Output from execution of function
- Versions:
2025-03-28
@ddalle
: v1.0
- exec_cntlfunction(funcspec: str | dict) Any ¶
Execute a Cntl function, accessing user-specified modules
- Call:
>>> v = cntl.exec_cntlfunction(funcname) >>> v = cntl.exec_cntlfunction(funcspec)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall control interface
- funcname:
str
Name of function to execute, e.g.
"mymod.myfunc"
- funcspec:
dict
Function opts parsed by
UserFuncOpts
- cntl:
- Outputs:
- v: any
Output from execution of function
- Versions:
2025-03-28
@ddalle
: v1.0
- exec_cntlfunction_str(funcname: str) Any ¶
Execute a function from cntl.modules
- Call:
>>> v = cntl.exec_modfunction(funcname, a, kw, name=None)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall control interface
- funcname:
str
Name of function to execute, e.g.
"mymod.myfunc"
- cntl:
- Outputs:
- v: any
Output from execution of function
- Versions:
2025-03-28
@ddalle
: v1.0
- exec_modfunction(funcname: str, a: tuple | list | None = None, kw: dict | None = None, name: str | None = None) Any ¶
Execute a function from cntl.modules
- Call:
>>> v = cntl.exec_modfunction(funcname, a, kw, name=None)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall control interface
- funcname:
str
Name of function to execute, e.g.
"mymod.myfunc"
- a: {
None
} |tuple
Positional arguments to called function
- kw: {
None
} |dict
Keyworkd arguments to called function
- name: {
None
} |str
Hook name to use in status update
- cntl:
- Outputs:
- v: any
Output from execution of function
- Versions:
2022-04-12
@ddalle
: v1.02025-03-28
@ddalle
: v1.1; improve error messages
- get_databook_comp_nmin(comp: str) int ¶
Calculate the min iterations required for a DataBook comp
- Call:
>>> n = cntl.get_databook_comp_nmin(comp)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
CAPE run matrix control instance
- comp:
str
Name of DataBook component
- cntl:
- Outputs:
- n:
int
Iteration number
- n:
- Versions:
2025-07-29
@ddalle
: v1.0
- get_logger() CntlLogger ¶
Get current logger and/or initialize one
- Call:
>>> logger = cntl.get_logger()
- Inputs:
- cntl:
Cntl
CAPE run matrix control instance
- cntl:
- Outputs:
- logger:
CntlLogger
Run matrix logger instance
- logger:
- Versions:
2025-04-30
@ddalle
: v1.0
- get_pbs_jobs(force: bool = False, u: str | None = None, server: str | None = None, qstat: bool = True) dict ¶
Get dictionary of current jobs active by one user
- Call:
>>> jobs = cntl.get_pbs_jobs(force=False, **kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- force:
True
| {False
} Query current queue even if cntl.jobs exists
- u: {
None
} |str
User name (defaults to process username)
- server: {
None
} |str
Name of non-default PBS/Slurm server
- cntl:
- Outputs:
- jobs:
dict
Information on each job by ID number
- jobs:
- Versions:
2024-01-12
@ddalle
: v1.02024-08-22
@ddalle
: v1.1; add qstat option2025-05-01
@ddalle
: v1.2; simplify flow
- get_phase_niter(i: int, j: int) int ¶
Get number of steps for one call of phase j in case i
- Call:
>>> niter = cntl.get_Phase_inter(i, j)
- Inputs:
- cntl:
cape.pyfun.cntl.Cntl
CAPE main control instance
- i:
int
Case index
- j:
int
Phase number
- cntl:
- Outputs:
- niter:
int
Number of iterations for phase j; may be specific to case i
- niter:
- Versions:
2025-08-11
@ddalle
: v1.0
- get_transformation_matrix(topts: dict, i: int) ndarray | None ¶
Calculate rotation matrix for a databook transformation
- Call:
>>> mat = cntl.get_transformation_matrix(topts, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- topts:
dict
Definitions for transformation
- i:
int
Case number
- cntl:
- Outputs:
- mat:
None
|np.ndarray
[float
] Rotation matrix if topts is a rotation
- mat:
- Versions:
2025-01-30
@ddalle
: v1.0
- getval(opt: str, i: int) Any ¶
Get run matrix or case status value for one case
- Call:
>>> v = cntl.getval(opt, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- opt:
str
Name of option or run matrix key
- i:
int
Case index
- cntl:
- Outputs:
- v:
Any
Value of option opt for case i
- v:
- Versions:
2025-06-16
@ddalle
: v1.0
- getvalstr(opt: str, i: int) str ¶
Get value of run matrix variable as string
- Call:
>>> txt = cntl.getvalstr(opt, i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- opt:
str
Name of option or run matrix key
- i:
int
Case index
- cntl:
- Outputs:
- txt:
str
Text of value of option opt for case i
- txt:
- Versions:
2025-06-16
@ddalle
: v1.0
- import_module(modname: str)¶
Import a module by name, if possible
- Call:
>>> mod = cntl.import_module(modname)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall control interface
- modname:
str
Name of module to import
- cntl:
- Outputs:
- mod: module
Python module
- Versions:
2025-03-28
@ddalle
: v1.0
- init_post()¶
Do
py{x}
specific initialization actions- Call:
>>> cntl.init_post()
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
CAPE run matrix control instance
- cntl:
- Versions:
2023-05-31
@ddalle
: v1.0
- link_files(i: int)¶
Link files from Mesh section
This applies to both LinkFiles and LinkAsFiles in the Mesh section. The former will copy a given file into the run folder for case i using the base name of the original (source) file. Using
"Mesh": { "LinkAsFiles": { "inputs/mesh-config02.ugrid": "mesh.ugrid" } }
will create a link (using the absolute path) from
inputs/mesh-config02.ugrid
tomesh.ugrid
in the case run folder.- Call:
>>> cntl.link_files(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Case index
- cntl:
- Versions:
2025-09-19
@ddalle
: v1.0
- log_main(msg: str, title: str | None = None, parent: int = 0)¶
Write a message to primary log
- Call:
>>> runner.log_main(msg, title, parent=0)
- Inputs:
- Versions:
2025-04-30
@ddalle
: v1.0
- logger¶
CntlLogger
Run matrix logger instacnce
- make_case_folder(i: int)¶
Create folder(s) if needed for case i
- Call:
>>> cntl.make_case_folder(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- i:
int
Index of case to analyze
- cntl:
- Versions:
2023-08-25
@ddalle
: v1.0 (CreateFolder)2023-10-20
@ddalle
: v2.0; support arbitrary depth
- opts¶
cape.cfdx.options.Options
Options interface for this run matrix
- preprocess_kwargs(kw: dict)¶
Preprocess command-line arguments and flags/keywords
This will effect the following CLI options:
- --cons CONS
Comma-separated constraints split into a list
- -x FPY
Each
-x
argument is executed (can be repeated)- -I INDS
Convert INDS like
3-6,8
to[3, 4, 5, 8]
- Call:
>>> opts = cntl.cli_preprocess(*a, **kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Overall CAPE control instance
- kw:
dict
[True
|False
|str
] CLI keyword arguments and flags, modified in-place
- cntl:
- Versions:
2024-12-19
@ddalle
: v1.0
- process_mesh_filename(fname: str, fproj: str | None = None) str ¶
Return a mesh file name using the project root name
- Call:
>>> fout = cntl.process_mesh_filename(fname, fproj=None)
- Inputs:
- Outputs:
- fout:
str
Name of file name using project name as prefix
- fout:
- Versions:
2016-04-05
@ddalle
: v1.0 (pyfun)2023-03-15
@ddalle
: v1.1; add fproj2024-10-22
@ddalle
: v2.0; move tocfdx
- qdel_cases(**kw)¶
Kill/stop PBS job of cases
This function deletes a case’s PBS/Slurm jobbut not delete the foder for a case.
- Call:
>>> cntl.qdel_cases(**kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Cape control interface
- I: {
None
} |list
[int
] List of cases to delete
- kw:
dict
Other subset parameters, e.g. re, cons
- cntl:
- Versions:
2025-06-22
@ddalle
: v1.0
- read_case_json(i: int) RunControlOpts ¶
Read
case.json
file from case i if possible- Call:
>>> rc = cntl.read_case_json(i)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Instance of control class
- i:
int
Case index
- cntl:
- Outputs:
- rc:
None
|dict
Run control interface read from
case.json
file
- rc:
- Versions:
2016-12-12
@ddalle
: v1.02017-04-12
@ddalle
: v1.1; add tocape.cfdx
2023-06-29
@ddalle
: v2.0; use _case_mod2023-07-07
@ddalle
: v2.1; use CaseRunner
- read_dex(comp: str, force: bool = False) DataExchanger ¶
Read a DataBook component using
DataExchanger
- Call:
>>> db = cntl.read_dex(comp, force=False)
- Inputs:
- Outputs:
- db:
cape.cfdx.dex.DataExchanger
Data extracted from run matrix for comp comp
- db:
- Versions:
2025-07-25
@ddalle
: v1.0
- read_options(fjson: str)¶
Read options using appropriate class
This allows users to set warning mode via an environment variable.
- Call:
>>> cntl.read_options(fjson)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
CAPE run matrix control instance
- fjson:
str
Name of JSON file to read
- cntl:
- Versions:
2023-05-26
@ddalle
: v1.0; forked from __init__()2023-12-13
@ddalle
: v1.1; add RootDir and JSONFile
- rm_cases(prompt: bool = True, **kw) int ¶
Delete one or more cases
This function deletes a case’s PBS job and removes the entire directory. By default, the method prompts for confirmation before deleting; set prompt to
False
to delete without prompt, but only cases with 0 iterations can be deleted this way.- Call:
>>> n = cntl.rm_cases(prompt=True, **kw)
- Inputs:
- cntl:
cape.cfdx.cntl.Cntl
Cape control interface
- prompt: {
True
} |False
Whether or not to prompt user before deleting case
- I: {
None
} |list
[int
] List of cases to delete
- kw:
dict
Other subset parameters, e.g. re, cons
- cntl:
- Outputs:
- n:
int
Number of folders deleted
- n:
- Versions:
2025-06-20
@ddalle
: v1.0
- update_dex_comp(comp: str, **kw)¶
Update a DataBook component
- Call:
>>> n = cntl.update_dex_comp(comp, **kw)
- Inputs:
- cntl:
Cntl
CAPE run matrix controller instance
- comp:
str
Name of component to read
- I: {
None
} |np.ndarray
[int
] Indices of cases to process
- cntl:
- Versions:
2025-07-29
@ddalle
: v1.0
- x¶
cape.cfdx.runmatrix.RunMatrix
Run matrix instance
- cape.cfdx.cntl.JOB_STATUSES = ('PASS', 'PASS*', '---', 'INCOMP', 'RUN', 'DONE', 'QUEUE', 'ERROR', 'ERROR*', 'FAIL', 'ZOMBIE', 'THIS_JOB')¶
- cape.cfdx.cntl.run_rootdir(func)¶
Decorator to run a function within a specified folder
- Call:
>>> func = run_rootdir(func)
- Wrapper Signature:
>>> v = cntl.func(*a, **kw)
- Inputs:
- Versions:
2018-11-20
@ddalle
: v1.02020-02-25
@ddalle
: v1.1: better exceptions2023-06-16
@ddalle
: v1.2; usefinally