Ignore:
Timestamp:
01/22/14 16:14:20 (11 years ago)
Author:
jbondzio
Message:

CHG: extrapolation of scalar field using a steadystate solver

File:
1 edited

Legend:

Unmodified
Added
Removed
  • issm/trunk-jpl/src/c/analyses/ExtrapolationAnalysis.cpp

    r17144 r17159  
    1111/*}}}*/
    1212void ExtrapolationAnalysis::UpdateParameters(Parameters* parameters,IoModel* iomodel,int solution_enum,int analysis_enum){/*{{{*/
    13         _error_("not implemented yet");
     13        //do nothing for now
    1414}
    1515/*}}}*/
     
    2929                }
    3030        }
    31         iomodel->FetchDataToInput(elements,ExtrapolationVariableEnum);//FIXME: is this the correct way?
    3231}
    3332/*}}}*/
     
    3837/*}}}*/
    3938void ExtrapolationAnalysis::CreateConstraints(Constraints* constraints,IoModel* iomodel){/*{{{*/
    40 
    41         _error_("not implemented yet");
    42 
     39        // do nothing for now
    4340}
    4441/*}}}*/
    4542void ExtrapolationAnalysis::CreateLoads(Loads* loads, IoModel* iomodel){/*{{{*/
    46        
    47         _error_("not implemented yet");
    48 
     43//      do nothing for now
    4944}/*}}}*/
    5045
     
    5247void ExtrapolationAnalysis::Core(FemModel* femmodel){/*{{{*/
    5348
     49        /* Intermediaries */
     50        bool save_results;
    5451        /*activate formulation: */
    5552        femmodel->SetCurrentConfiguration(ExtrapolationAnalysisEnum);
     
    5855        UpdateConstraints(femmodel->elements);
    5956        solutionsequence_linear(femmodel);
     57
     58        /*recover parameters: */
     59        femmodel->parameters->FindParam(&save_results,SaveResultsEnum);
     60        if(save_results){
     61                if(VerboseSolution()) _printf0_("   Warning: Adding extrapolated variable to results\n");
     62               
     63                int outputs;
     64                femmodel->parameters->FindParam(&outputs, ExtrapolationVariableEnum);
     65                femmodel->RequestedOutputsx(&femmodel->results,&outputs,1);
     66        }
    6067
    6168}/*}}}*/
     
    248255        Node* node = NULL;
    249256
    250         /* Get further parameters */
     257        /* Get parameters */
    251258        element->FindParam(&extvar_enum, ExtrapolationVariableEnum);
    252259       
    253260        Input* levelset_input=element->GetInput(MaskIceLevelsetEnum); _assert_(levelset_input);
    254261        Input* extvar_input=element->GetInput(extvar_enum); _assert_(extvar_input);
    255        
    256         GaussPenta* gauss=new GaussPenta();
     262
     263        Gauss* gauss=element->NewGauss();
    257264        for(int in=0;in<numnodes;in++){
    258265                gauss->GaussNode(element->GetElementType(),in);
    259266                node=element->GetNode(in);
    260267                levelset_input->GetInputValue(&phi,gauss);
    261                 extvar_input->GetInputValue(&value,gauss);
    262268                if(phi<=0.){
    263269                        /* if ice, set dirichlet BC */
     270                        extvar_input->GetInputValue(&value,gauss);
    264271                        node->ApplyConstraint(1,value);
    265272                }
Note: See TracChangeset for help on using the changeset viewer.