Changeset 2d06beb in sasview for pr_inversion/c_extensions


Ignore:
Timestamp:
May 5, 2008 2:03:39 PM (17 years ago)
Author:
Mathieu Doucet <doucetm@…>
Branches:
master, ESS_GUI, ESS_GUI_Docs, ESS_GUI_batch_fitting, ESS_GUI_bumps_abstraction, ESS_GUI_iss1116, ESS_GUI_iss879, ESS_GUI_iss959, ESS_GUI_opencl, ESS_GUI_ordering, ESS_GUI_sync_sascalc, costrafo411, magnetic_scatt, release-4.1.1, release-4.1.2, release-4.2.2, release_4.0.1, ticket-1009, ticket-1094-headless, ticket-1242-2d-resolution, ticket-1243, ticket-1249, ticket885, unittest-saveload
Children:
b43a009
Parents:
150c04a
Message:

Use simple least-square fit

Location:
pr_inversion/c_extensions
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • pr_inversion/c_extensions/Cinvertor.c

    reca05c8 r2d06beb  
    8080        Py_ssize_t ndata; 
    8181        double *data; 
     82        int i; 
    8283   
    8384        if (!PyArg_ParseTuple(args, "O", &data_obj)) return NULL; 
    8485        OUTVECTOR(data_obj,data,ndata); 
    85         self->params.x = data; 
     86         
     87        free(self->params.x); 
     88        self->params.x = (double*) malloc(ndata*sizeof(double)); 
     89         
     90        if(self->params.x==NULL) { 
     91            PyErr_SetString(CinvertorError,  
     92                "Cinvertor.set_x: problem allocating memory."); 
     93                return NULL;             
     94        } 
     95         
     96        for (i=0; i<ndata; i++) { 
     97                self->params.x[i] = data[i]; 
     98        } 
     99         
     100        //self->params.x = data; 
    86101        self->params.npoints = ndata; 
    87102        return Py_BuildValue("i", self->params.npoints);         
     
    95110     
    96111        if (!PyArg_ParseTuple(args, "O", &data_obj)) return NULL; 
    97         INVECTOR(data_obj, data, ndata); 
     112        OUTVECTOR(data_obj, data, ndata); 
    98113         
    99114        // Check that the input array is large enough 
     
    120135        Py_ssize_t ndata; 
    121136        double *data; 
     137        int i; 
    122138   
    123139        if (!PyArg_ParseTuple(args, "O", &data_obj)) return NULL; 
    124140        OUTVECTOR(data_obj,data,ndata); 
    125         self->params.y = data; 
     141         
     142        free(self->params.y); 
     143        self->params.y = (double*) malloc(ndata*sizeof(double)); 
     144         
     145        if(self->params.y==NULL) { 
     146            PyErr_SetString(CinvertorError,  
     147                "Cinvertor.set_y: problem allocating memory."); 
     148                return NULL;             
     149        } 
     150         
     151        for (i=0; i<ndata; i++) { 
     152                self->params.y[i] = data[i]; 
     153        }        
     154         
     155        //self->params.y = data; 
    126156        self->params.ny = ndata; 
    127157        return Py_BuildValue("i", self->params.ny);      
     
    135165     
    136166        if (!PyArg_ParseTuple(args, "O", &data_obj)) return NULL; 
    137         INVECTOR(data_obj, data, ndata); 
     167        OUTVECTOR(data_obj, data, ndata); 
    138168         
    139169        // Check that the input array is large enough 
     
    160190        Py_ssize_t ndata; 
    161191        double *data; 
     192        int i; 
    162193   
    163194        if (!PyArg_ParseTuple(args, "O", &data_obj)) return NULL; 
    164195        OUTVECTOR(data_obj,data,ndata); 
    165         self->params.err = data; 
     196         
     197        free(self->params.err); 
     198        self->params.err = (double*) malloc(ndata*sizeof(double)); 
     199         
     200        if(self->params.err==NULL) { 
     201            PyErr_SetString(CinvertorError,  
     202                "Cinvertor.set_err: problem allocating memory."); 
     203                return NULL;             
     204        } 
     205         
     206        for (i=0; i<ndata; i++) { 
     207                self->params.err[i] = data[i]; 
     208        } 
     209         
     210        //self->params.err = data; 
    166211        self->params.nerr = ndata; 
    167212        return Py_BuildValue("i", self->params.nerr);    
     
    175220     
    176221        if (!PyArg_ParseTuple(args, "O", &data_obj)) return NULL; 
    177         INVECTOR(data_obj, data, ndata); 
     222        OUTVECTOR(data_obj, data, ndata); 
    178223         
    179224        // Check that the input array is large enough 
     
    414459} 
    415460 
     461static PyObject * basefunc_ft(Cinvertor *self, PyObject *args) { 
     462        double d_max, q; 
     463        int n; 
     464         
     465        if (!PyArg_ParseTuple(args, "did", &d_max, &n, &q)) return NULL; 
     466        return Py_BuildValue("f", ortho_transformed(d_max, n, q));       
     467         
     468} 
    416469 
    417470static PyMethodDef Cinvertor_methods[] = { 
     
    435488                   {"get_pr_err", (PyCFunction)get_pr_err, METH_VARARGS, ""}, 
    436489                   {"is_valid", (PyCFunction)is_valid, METH_VARARGS, ""}, 
     490                   {"basefunc_ft", (PyCFunction)basefunc_ft, METH_VARARGS, ""}, 
    437491    
    438492   {NULL} 
  • pr_inversion/c_extensions/invertor.c

    reca05c8 r2d06beb  
    88 */ 
    99void invertor_dealloc(Invertor_params *pars) { 
    10         //free(pars->x); 
    11         //free(pars->y); 
    12         //free(pars->err); 
     10        free(pars->x); 
     11        free(pars->y); 
     12        free(pars->err); 
    1313} 
    1414 
     
    133133} 
    134134 
    135  
  • pr_inversion/c_extensions/invertor.h

    reca05c8 r2d06beb  
    2929void pr_err(double *pars, double *err, double d_max, int n_c,  
    3030                double r, double *pr_value, double *pr_value_err); 
    31  
    3231#endif 
Note: See TracChangeset for help on using the changeset viewer.