CouplingPhysicalModel¶
- class persalys.CouplingPhysicalModel(*args)¶
- File-exchange based coupling model. - This model allows one to wrap computer codes that read input values and write output values in text files. It is defined from a sequence steps, each step being defined from: - a list of input files to copy, or input files in which some variables are written 
- a command to launch the code 
- a list of output files and the associated output variables to read. 
 - Each step is run sequentially in a temporary working directory for each input point. The name of the temporary working directory is computed from a hash of the input point. - Parameters:
- namestr
- Model name 
- inputssequence of Input
- Input variables (optional) 
- outputssequence of Output
- Output variables (optional) 
- stepssequence of CouplingStep
- List of steps to execute (optional) 
 
 - Examples - >>> import persalys >>> import sys - input.txt is generated from the existing input_template.txt by replacing the @XN tokens: - >>> input_file = persalys.CouplingInputFile('/tmp/input_template.txt') >>> input_file.setConfiguredPath('input.txt') >>> input_file.setVariables(['X0', 'X1', 'X2'], ['@X0', '@X1', '@X2'], ['', '', '']) - external_program.py reads input.txt and writes output.txt: - >>> resource_file = persalys.CouplingResourceFile('external_program.py') - output variables Yj are read from output.txt and delimited by tokens, no token/line/column skipped: - >>> output_file = persalys.CouplingOutputFile('output.txt') >>> output_file.setVariables(['Y0', 'Y1'], ['Y0=', 'Y1='], [0, 0], [0, 0], [0, 0]) >>> step = persalys.CouplingStep(sys.executable + ' external_program.py input.txt', [input_file], [resource_file], [output_file]) >>> model = persalys.CouplingPhysicalModel('A', [step]) - Methods - addInput(input)- Add an input variable. - addOutput(output)- Add an output variable. - Remove all the input variables. - Remove all the output variables. - exportStandalonePythonScript(fileName)- Export the model into a Python script. - Cache input file accessor. - Cache output file accessor. - Accessor to the object's name. - Cleanup work directory accessor. - getCode()- Code accessor. - Copula accessor. - Distribution accessor. - Evaluation time accessor. - getFunction(*args)- Accessor to the underlying function. - getInputByName(*args)- Input variable accessor. - Number of input variables accessor. - Input variable names accessor. - Input random vector accessor. - Input variables accessor. - Mesh model accessor. - getName()- Accessor to the object's name. - getOutputByName(*args)- Output variable accessor. - Number of output variables accessor. - Output variable names accessor. - getOutputRandomVector(outputNames)- Output random vector accessor. - Output variables accessor. - getPointToFieldFunction(*args)- Accessor to the underlying function. - Number of concurrent processes. - Python script accessor. - getRestrictedFunction(*args)- Accessor to the function restricted to its stochastic inputs. - getRestrictedPointToFieldFunction(outputNames)- Accessor to the field function restricted to its stochastic inputs. - Accessor to the selected outputs names. - getSteps()- Coupling steps accessor. - Accessor to the names of the stochastic input variables. - Working directory accessor. - hasInputNamed(inputName)- Check if an input has the given name. - hasMesh()- Whether the model has a mesh. - hasName()- Test if the object is named. - hasOutputNamed(outputName)- Check if an output has the given name. - Whether it contains stochastic variables. - Whether the evaluations of the model are parallelized. - isValid()- Whether it is valid. - removeInput(inputName)- Remove an input variable. - removeOutput(outputName)- Remove an output variable. - selectOutput(outputName, selected)- Select output. - setCacheFiles(inputFile, outputFile)- Cache files accessor. - setCleanupWorkDirectory(cleanupWorkDirectory)- Cleanup work directory accessor. - setCode(code)- Code accessor. - setCopula(inputNames, copula)- Copula accessor. - setDistribution(inputName, distribution)- Input distribution accessor. - setDistributionParametersType(inputName, ...)- Input distribution parameter type accessor. - setEvalTime(evalTime)- Evaluation time accessor. - setFiniteDifferenceStep(inputName, step)- Finite difference step accessor. - setInputDescription(inputName, description)- Input description accessor. - setInputName(inputName, newName)- Input variable name accessor. - setInputStochastic(inputName, stoch)- Whether the input variable is stochastic. - setInputValue(inputName, value)- Input variable value accessor. - setInputs(inputs)- Input variables accessor. - setMeshModel(meshModel)- Mesh model accessor. - setName(name)- Accessor to the object's name. - setOutputDescription(outputName, description)- Output description accessor. - setOutputName(outputName, newName)- Output variable name accessor. - setOutputValue(outputName, value)- Output variable name accessor. - setOutputs(outputs)- Output variables accessor. - setParallel(flag)- Whether the evaluations of the model are parallelized. - setProcessNumber(processNumber)- Number of concurrent processes. - setSteps(steps)- Coupling steps accessor. - setWorkDir(workDir)- Working directory accessor. - __init__(*args)¶
 - clearInputs()¶
- Remove all the input variables. 
 - clearOutputs()¶
- Remove all the output variables. 
 - exportStandalonePythonScript(fileName)¶
- Export the model into a Python script. - In the case of metamodels the script only depends on OpenTURNS and is meant to be used out of Persalys. - Parameters:
- fileNamestr
- Path of the exported script 
 
 
 - getCacheInputFile()¶
- Cache input file accessor. - Returns:
- input_filestr
- Cache input file name. 
 
 
 - getCacheOutputFile()¶
- Cache output file accessor. - Returns:
- output_filestr
- Cache output file name. 
 
 
 - getClassName()¶
- Accessor to the object’s name. - Returns:
- class_namestr
- The object class name (object.__class__.__name__). 
 
 
 - getCleanupWorkDirectory()¶
- Cleanup work directory accessor. - Returns:
- cleanup_work_dirbool
- Whether the work directory is discarded 
 
 
 - getCode()¶
- Code accessor. - Returns:
- codestr
- Code text 
 
 
 - getCopula()¶
- Copula accessor. - Parameters:
- copulaopenturns.Distribution
- The copula 
 
- copula
 
 - getDistribution()¶
- Distribution accessor. - Parameters:
- Distributionopenturns.JointDistribution
- The composed distribution (marginals and dependence) 
 
- Distribution
 
 - getEvalTime()¶
- Evaluation time accessor. - Returns:
- evalTimefloat
- Evaluation time 
 
 
 - getFunction(*args)¶
- Accessor to the underlying function. - Parameters:
- outputNamessequence of str
- Names of the outputs to be evaluated (optional) 
 
- Returns:
- functionopenturns.Function
- Function evaluating the outputs 
 
- function
 
 - getInputByName(*args)¶
- Input variable accessor. - Parameters:
- namestr
- Variable name 
 
- Returns:
- inputInput
- Input variable 
 
- input
 
 - getInputDimension()¶
- Number of input variables accessor. - Returns:
- dimensionint
- Number of input variables 
 
 
 - getInputNames()¶
- Input variable names accessor. - Returns:
- namesopenturns.Description
- Input variable names 
 
- names
 
 - getInputRandomVector()¶
- Input random vector accessor. - Returns:
- namesopenturns.RandomVector
- Input random vector 
 
- names
 
 - getName()¶
- Accessor to the object’s name. - Returns:
- namestr
- The name of the object. 
 
 
 - getOutputByName(*args)¶
- Output variable accessor. - Parameters:
- namestr
- Variable name 
 
- Returns:
- inputOutput
- Output variable 
 
- input
 
 - getOutputDimension()¶
- Number of output variables accessor. - Returns:
- dimensionint
- Number of output variables 
 
 
 - getOutputNames()¶
- Output variable names accessor. - Returns:
- namesopenturns.Description
- Output variable names 
 
- names
 
 - getOutputRandomVector(outputNames)¶
- Output random vector accessor. - Returns:
- namesopenturns.RandomVector
- Output random vector 
 
- names
 
 - getPointToFieldFunction(*args)¶
- Accessor to the underlying function. - Parameters:
- outputNamessequence of str
- Names of the outputs to be evaluated (optional) 
 
- Returns:
- functionopenturns.PointToFieldFunction
- Function evaluating the outputs along the mesh nodes 
 
- function
 
 - getProcessNumber()¶
- Number of concurrent processes. - Returns:
- process_numberint
- Maximum number of processes 
 
 
 - getPythonScript()¶
- Python script accessor. - Returns:
- scriptstr
- Python script to replay the model 
 
 
 - getRestrictedFunction(*args)¶
- Accessor to the function restricted to its stochastic inputs. - Parameters:
- outputNamessequence of str
- Output variables (optional) 
 
- Returns:
- restrictedopenturns.Function
- Stochastic function 
 
- restricted
 
 - getRestrictedPointToFieldFunction(outputNames)¶
- Accessor to the field function restricted to its stochastic inputs. - Parameters:
- outputNamessequence of str
- Output variables (optional) 
 
- Returns:
- restrictedopenturns.PointToFieldFunction
- Stochastic field function (for model with mesh) 
 
- restricted
 
 - getSelectedOutputsNames()¶
- Accessor to the selected outputs names. - Returns:
- namesopenturns.Description
- Selected outputs names 
 
- names
 
 - getSteps()¶
- Coupling steps accessor. - Returns:
- stepssequence of CouplingStep
- List of steps to execute 
 
- stepssequence of 
 
 - getStochasticInputNames()¶
- Accessor to the names of the stochastic input variables. - Returns:
- namesopenturns.Description
- Names of the stochastic input variables 
 
- names
 
 - getWorkDir()¶
- Working directory accessor. - Returns:
- workDirstr
- Working directory path. 
 
 
 - hasInputNamed(inputName)¶
- Check if an input has the given name. - Parameters:
- namestr
- Variable name 
 
- Returns:
- hasbool
- Whether an input has the given name 
 
 
 - hasMesh()¶
- Whether the model has a mesh. - Returns:
- hasMeshbool
- Whether the model has a mesh 
 
 
 - hasName()¶
- Test if the object is named. - Returns:
- hasNamebool
- True if the name is not empty. 
 
 
 - hasOutputNamed(outputName)¶
- Check if an output has the given name. - Parameters:
- namestr
- Variable name 
 
- Returns:
- hasbool
- Whether an output has the given name 
 
 
 - hasStochasticInputs()¶
- Whether it contains stochastic variables. - Returns:
- hasbool
- Whether it contains stochastic variables 
 
 
 - isParallel()¶
- Whether the evaluations of the model are parallelized. - Returns:
- isParallelbool
- Whether the evaluations of the model are parallelized (available only for the Python model) 
 
 
 - isValid()¶
- Whether it is valid. - Returns:
- isValidbool
- Whether it is valid 
 
 
 - removeInput(inputName)¶
- Remove an input variable. - Parameters:
- namestr
- Variable name 
 
 
 - removeOutput(outputName)¶
- Remove an output variable. - Parameters:
- namestr
- Variable name 
 
 
 - selectOutput(outputName, selected)¶
- Select output. - Parameters:
- namestr
- Output name 
- isSelectedbool
- Whether it is selected 
 
 
 - setCacheFiles(inputFile, outputFile)¶
- Cache files accessor. - Parameters:
- input_filestr
- Cache input file name. 
- output_filestr
- Cache output file name. 
 
 
 - setCleanupWorkDirectory(cleanupWorkDirectory)¶
- Cleanup work directory accessor. - Parameters:
- cleanup_work_dirbool
- Whether the work directory is discarded 
 
 
 - setCode(code)¶
- Code accessor. - Parameters:
- codestr
- Code text 
 
 
 - setCopula(inputNames, copula)¶
- Copula accessor. - Parameters:
- copulaopenturns.Distribution
- The copula 
 
- copula
 
 - setDistribution(inputName, distribution)¶
- Input distribution accessor. - Parameters:
- namestr
- Variable name 
- distributionopenturns.Distribution
- Variable distribution 
 
 
 - setDistributionParametersType(inputName, distributionParametersType)¶
- Input distribution parameter type accessor. - Parameters:
- namestr
- Variable name 
- parametersTypeint
- Distribution parameter type accessor 
 
 
 - setEvalTime(evalTime)¶
- Evaluation time accessor. - Parameters:
- evalTimefloat
- Evaluation time 
 
 
 - setFiniteDifferenceStep(inputName, step)¶
- Finite difference step accessor. - Parameters:
- namestr
- Variable name 
- stepfloat
- Finite difference step used to define the gradient of the model’s function 
 
 
 - setInputDescription(inputName, description)¶
- Input description accessor. - Parameters:
- namestr
- Variable name 
- descriptionstr
- Description text 
 
 
 - setInputName(inputName, newName)¶
- Input variable name accessor. - Parameters:
- namestr
- Variable name 
- newNamestr
- New name 
 
 
 - setInputStochastic(inputName, stoch)¶
- Whether the input variable is stochastic. - Parameters:
- namestr
- Variable name 
- isStochasticbool
- Whether the input variable is stochastic 
 
 
 - setInputValue(inputName, value)¶
- Input variable value accessor. - Parameters:
- namestr
- Variable name 
- valuefloat
- New value 
 
 
 - setName(name)¶
- Accessor to the object’s name. - Parameters:
- namestr
- The name of the object. 
 
 
 - setOutputDescription(outputName, description)¶
- Output description accessor. - Parameters:
- namestr
- Variable name 
- descriptionstr
- Description text 
 
 
 - setOutputName(outputName, newName)¶
- Output variable name accessor. - Parameters:
- namestr
- Variable name 
- newNamestr
- New name 
 
 
 - setOutputValue(outputName, value)¶
- Output variable name accessor. - Parameters:
- namestr
- Variable name 
- valuefloat
- New value 
 
 
 - setOutputs(outputs)¶
- Output variables accessor. - Parameters:
- outputssequence of Output
- Output variables 
 
- outputssequence of 
 
 - setParallel(flag)¶
- Whether the evaluations of the model are parallelized. - Parameters:
- isParallelbool
- Whether the evaluations of the model are parallelized 
 
 - Notes - This is only implemented for the Python model. Also, on Windows platforms, ProcessPoolExecutor startup time being much higher, you may want to evaluate enough points in batch rather than many small blocks. Refer to the setBlockSize method of the various algorithms. 
 - setProcessNumber(processNumber)¶
- Number of concurrent processes. - Parameters:
- process_numberint
- Maximum number of processes 
 
 
 - setSteps(steps)¶
- Coupling steps accessor. - Parameters:
- stepssequence of CouplingStep
- List of steps to execute 
 
- stepssequence of 
 
 - setWorkDir(workDir)¶
- Working directory accessor. - Parameters:
- workDirstr
- Working directory path. 
 
 
 
