Ignore:
Timestamp:
Mar 12, 2010 1:08:42 PM (14 years ago)
Author:
Jae Cho <jhjcho@…>
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:
e575db9
Parents:
7e99f5c
Message:

changed classtemplate for 2d evaluation from matrix form to 1d array form

File:
1 edited

Legend:

Unmodified
Added
Removed
  • sansmodels/src/sans/models/c_models/CBinaryHSModel.cpp

    r4cbaf35 r3080527  
    184184 { 
    185185    PyArrayObject *result; 
    186     int i,j, x_len, y_len, dims[2]; 
     186    int i,j, x_len, y_len, dims[1]; 
    187187    //check validity of input vectors 
    188     if (x->nd != 2 || x->descr->type_num != PyArray_DOUBLE 
    189         || y->nd != 2 || y->descr->type_num != PyArray_DOUBLE 
    190         || y->dimensions[1] != x->dimensions[0]){ 
     188    if (x->nd != 1 || x->descr->type_num != PyArray_DOUBLE 
     189        || y->nd != 1 || y->descr->type_num != PyArray_DOUBLE 
     190        || y->dimensions[0] != x->dimensions[0]){ 
    191191        const char * message= "evaluateTwoDimXY  expect 2 numpy arrays"; 
    192192        PyErr_SetString(PyExc_ValueError , message);  
     
    196196        if (PyArray_Check(x) && PyArray_Check(y)) { 
    197197                 
    198             x_len = dims[1]= x->dimensions[1]; 
     198            x_len = dims[0]= x->dimensions[0]; 
    199199        y_len = dims[0]= y->dimensions[0]; 
    200200             
    201201            // Make a new double matrix of same dims 
    202         result=(PyArrayObject *) PyArray_FromDims(2,dims,NPY_DOUBLE); 
     202        result=(PyArrayObject *) PyArray_FromDims(1,dims,NPY_DOUBLE); 
    203203        if (result == NULL){ 
    204204            const char * message= "Could not create result "; 
     
    208208        
    209209        /* Do the calculation. */ 
    210         for ( j=0; j< y_len; j++) { 
    211             for ( i=0; i< x_len; i++) { 
    212                 double x_value = *(double *)(x->data + i*x->strides[1]); 
    213                     double y_value = *(double *)(y->data + j*y->strides[0]); 
    214                         double *result_value = (double *)(result->data + 
    215                               j*result->strides[0] + i*result->strides[1]); 
    216                         *result_value = (*model)(x_value, y_value); 
    217             }            
    218         } 
     210        for ( i=0; i< x_len; i++) { 
     211            double x_value = *(double *)(x->data + i*x->strides[0]); 
     212                    double y_value = *(double *)(y->data + i*y->strides[0]); 
     213                        double *result_value = (double *)(result->data + 
     214                              i*result->strides[0]); 
     215                        *result_value = (*model)(x_value, y_value); 
     216        }            
    219217        return PyArray_Return(result);  
    220218         
Note: See TracChangeset for help on using the changeset viewer.