Changeset 65883cf in sasview


Ignore:
Timestamp:
Sep 21, 2009 6:32:18 PM (15 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:
a0bc608
Parents:
a65ffcb
Message:

dataloader: fixed get_bin_range method for smearer objects

Location:
DataLoader
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • DataLoader/extensions/smearer.cpp

    r5859862 r65883cf  
    230230 * 
    231231 */ 
    232 void BaseSmearer :: get_bin_range(int i, double* q, double* q_min, double* q_max) { 
     232int BaseSmearer :: get_bin_range(int i, double* q, double* q_min, double* q_max) { 
    233233        if (even_binning) { 
    234234                double step = (qmax-qmin)/((double)nbins-1.0); 
     
    236236                *q_min = *q - 0.5*step; 
    237237                *q_max = *q + 0.5*step; 
    238         } else { 
     238                return 1; 
     239        } else if (i>=0 && i<nbins) { 
    239240                *q = q_values[i]; 
    240241                if (i==0) { 
     
    250251                        *q_max = *q + (q_values[i+1]-q_values[i])/2.0; 
    251252                } 
    252         } 
     253                return 1; 
     254        } 
     255        return -1; 
    253256} 
    254257 
  • DataLoader/extensions/smearer.hh

    r5859862 r65883cf  
    5050        int get_nbins() { return nbins; } 
    5151        // Get the q range of a particular bin 
    52         virtual void get_bin_range(int, double*, double*, double*); 
     52        virtual int get_bin_range(int, double*, double*, double*); 
    5353}; 
    5454 
  • DataLoader/extensions/smearer_module.cpp

    r5859862 r65883cf  
    161161        BaseSmearer* s = static_cast<BaseSmearer *>(temp); 
    162162 
     163        if(s->get_nbins()<=0 || s->get_nbins()<=bin) { 
     164                return NULL; 
     165        } 
     166 
    163167        double q, q_min, q_max; 
    164         s->get_bin_range(bin, &q, &q_min, &q_max); 
    165  
     168        if (s->get_bin_range(bin, &q, &q_min, &q_max)<0) { 
     169                return NULL; 
     170        } 
    166171        return Py_BuildValue("d", q); 
    167172} 
  • DataLoader/qsmearing.py

    r5859862 r65883cf  
    106106            @param q_max: maximum q-value to smear  
    107107        """ 
     108        # If this is the first time we call for smearing, 
     109        # initialize the C++ smearer object first 
     110        if not self._init_complete: 
     111            self._initialize_smearer() 
     112             
    108113        if q_min == None: 
    109114            q_min = self.min 
     
    118123 
    119124        step = (self.max-self.min)/(self.nbins-1.0) 
    120         for i in range(self.nbins): 
    121             q_i = smearer.get_q(self._smearer, i) 
    122             if (q_i >= _qmin_unsmeared) and (q_i <= _qmax_unsmeared): 
    123                 # Identify first and last bin 
    124                 if _first_bin is None: 
    125                     _first_bin = i 
    126                 else: 
    127                     _last_bin  = i 
     125        try: 
     126            for i in range(self.nbins): 
     127                q_i = smearer.get_q(self._smearer, i) 
     128                if (q_i >= _qmin_unsmeared) and (q_i <= _qmax_unsmeared): 
     129                    # Identify first and last bin 
     130                    if _first_bin is None: 
     131                        _first_bin = i 
     132                    else: 
     133                        _last_bin  = i 
     134        except: 
     135            raise RuntimeError, "_BaseSmearer.get_bin_range: error getting range\n  %s" % sys.exc_value 
    128136                
    129137        return _first_bin, _last_bin 
     
    151159        # Storage for smeared I(q)    
    152160        iq_out = numpy.zeros(self.nbins) 
    153         smearer.smear(self._smearer, iq_in, iq_out, first_bin, last_bin) 
     161        smear_output = smearer.smear(self._smearer, iq_in, iq_out, first_bin, last_bin) 
     162        if smear_output < 0: 
     163            raise RuntimeError, "_BaseSmearer: could not smear, code = %g" % smear_output 
    154164        return iq_out 
    155165     
     
    184194        ## Smearing matrix 
    185195        self._weights = None 
     196        self.qvalues  = None 
    186197         
    187198    def _initialize_smearer(self): 
     
    275286        ## Smearing matrix 
    276287        self._weights = None 
     288        self.qvalues  = None 
    277289         
    278290    def _initialize_smearer(self): 
Note: See TracChangeset for help on using the changeset viewer.