#include <Misfit.h>
Definition at line 15 of file Misfit.h.
◆ Misfit() [1/2]
◆ Misfit() [2/2]
Misfit::Misfit |
( |
char * |
in_name, |
|
|
int |
in_definitionenum, |
|
|
int |
in_model_enum, |
|
|
int |
in_observation_enum, |
|
|
char * |
in_timeinterpolation, |
|
|
int |
in_local, |
|
|
int |
in_weights_enum |
|
) |
| |
Definition at line 40 of file Misfit.cpp.
44 this->
name = xNew<char>(strlen(in_name)+1);
45 xMemCpy<char>(this->
name,in_name,strlen(in_name)+1);
48 xMemCpy<char>(this->
timeinterpolation,in_timeinterpolation,strlen(in_timeinterpolation)+1);
◆ ~Misfit()
◆ copy()
Object * Misfit::copy |
( |
void |
| ) |
|
|
virtual |
◆ DeepEcho()
void Misfit::DeepEcho |
( |
void |
| ) |
|
|
virtual |
◆ Echo()
void Misfit::Echo |
( |
void |
| ) |
|
|
virtual |
◆ Id()
◆ Marshall()
void Misfit::Marshall |
( |
char ** |
pmarshalled_data, |
|
|
int * |
pmarshalled_data_size, |
|
|
int |
marshall_direction |
|
) |
| |
|
virtual |
◆ ObjectEnum()
int Misfit::ObjectEnum |
( |
void |
| ) |
|
|
virtual |
◆ DefinitionEnum()
int Misfit::DefinitionEnum |
( |
| ) |
|
|
virtual |
◆ Name()
◆ Response()
Implements Definition.
Definition at line 111 of file Misfit.cpp.
143 misfit_t=all_misfit_t;
146 if (area_t!=0) misfit_t=misfit_t/area_t;
152 if(time==finaltime)this->
lock=1;
155 if(time!=0.)
return misfit/(time-starttime);
158 else if (this->
local==2){
163 int msize,osize,wsize;
175 for (
int i=0;i<msize;i++){
176 misfit_t += pow(model[i]-observation[i],2)*weights[i];
177 if (weights[i]!=0)count++;
179 misfit=sqrt(misfit_t/count);
182 xDelete<IssmDouble>(model);
183 xDelete<IssmDouble>(observation);
184 xDelete<IssmDouble>(weights);
203 for (
int i=0;i<msize;i++){
204 misfit_t += pow(model[i]-observation[i],2)*weights[i];
205 if (weights[i]!=0)count++;
207 misfit=sqrt(misfit_t/count);
210 misfit=sqrt(misfit_t)/count;
214 if(time==finaltime)this->
lock=1;
217 xDelete<IssmDouble>(model);
218 xDelete<IssmDouble>(observation);
219 xDelete<IssmDouble>(weights);
222 return misfit/(time-starttime);
241 misfit+=dt*(model-observation);
244 if(time==finaltime)this->
lock=1;
247 return misfit/(time-starttime);
◆ definitionenum
int Misfit::definitionenum |
◆ local
◆ model_enum
◆ name
◆ observation_enum
int Misfit::observation_enum |
◆ timeinterpolation
char* Misfit::timeinterpolation |
◆ weights_enum
◆ lock
◆ misfit
The documentation for this class was generated from the following files:
int ISSM_MPI_Allreduce(void *sendbuf, void *recvbuf, int count, ISSM_MPI_Datatype datatype, ISSM_MPI_Op op, ISSM_MPI_Comm comm)