當前位置: 首頁>>代碼示例>>Python>>正文


Python StimulusModel.testDoc方法代碼示例

本文整理匯總了Python中sparkle.stim.stimulus_model.StimulusModel.testDoc方法的典型用法代碼示例。如果您正苦於以下問題:Python StimulusModel.testDoc方法的具體用法?Python StimulusModel.testDoc怎麽用?Python StimulusModel.testDoc使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在sparkle.stim.stimulus_model.StimulusModel的用法示例。


在下文中一共展示了StimulusModel.testDoc方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: SearchRunner

# 需要導入模塊: from sparkle.stim.stimulus_model import StimulusModel [as 別名]
# 或者: from sparkle.stim.stimulus_model.StimulusModel import testDoc [as 別名]

#.........這裏部分代碼省略.........
    #     stim_names = []
    #     for stim in self._explore_stimuli:
    #         stim_names.append(stim.name)
    #     return stim_names

    def run(self, interval):
        """See :meth:`AbstractAcquisitionRunner<sparkle.run.abstract_acquisition.AbstractAcquisitionRunner.run>`"""
        self._halt = False
        
        # TODO: some error checking to make sure valid paramenters are set
        if self.save_data:
            # initize data set
            self.current_dataset_name = self.set_name
            self.datafile.init_data(self.current_dataset_name, self.aitimes.shape, mode='open')
            self.set_name = increment_title(self.set_name)

        # save the start time and set last tick to expired, so first
        # acquisition loop iteration executes immediately
        self.start_time = time.time()
        self.last_tick = self.start_time - (interval/1000)
        self.interval = interval
        self.acq_thread = threading.Thread(target=self._worker)

        # arm the first read
        self.player.set_aochan(self.aochan)
        self.player.set_aichan(self.aichan)

        # make sure a signal is loaded
        self.reset_stim()
        
        # and go!
        self.acq_thread.start()

        return self.acq_thread

    def _worker(self):
        try:
            spike_counts = []
            spike_latencies = []
            spike_rates = []
            self.irep = 0
            times = self.aitimes
            # report inital stim
            trace_doc = self._stimulus.componentDoc()
            trace_doc['overloaded_attenuation'] = np.nan
            self.putnotify('current_trace', (0,0,trace_doc))

            # self.player.start_timer(self.reprate)
            stim = self.player.start()
            while not self._halt:
                self.interval_wait()

                response = self.player.run()
                stamp = time.time()

                self.putnotify('response_collected', (times, response, -1, -1, self.irep, {}))
                if stim is not None:
                    self.putnotify('stim_generated', (stim, self.player.get_samplerate()))
                    trace_doc = self._stimulus.componentDoc()
                    trace_doc['overloaded_attenuation'] = np.nan
                    self.putnotify('current_trace', (0,0,trace_doc))

                #lock it so we don't get a times mismatch
                self.player_lock.acquire()
                stim = self.player.reset()
                times = self.aitimes
                self.player_lock.release()

                if self.save_data:
                    # save response data
                    self.save_to_file(response, stamp)

                self.irep +=1
                if self.irep == self.nreps:
                    self.irep = 0

            self.player.stop()
            # self.player.stop_timer()
            if self.save_data:
                self.datafile.trim(self.current_dataset_name)

        except:
            logger = logging.getLogger('main')
            logger.exception("Uncaught Exception from Explore Thread:")

    def save_to_file(self, data, stamp):
        """Saves data to current dataset.

        :param data: data to save to file
        :type data: numpy.ndarray
        :param stamp: time stamp of when the data was acquired
        :type stamp: str
        """
        self.datafile.append(self.current_dataset_name, data)
        # save stimulu info
        info = dict(self._stimulus.componentDoc().items() + self._stimulus.testDoc().items())
        print 'saving doc', info
        info['time_stamps'] = [stamp]
        info['samplerate_ad'] = self.player.aifs
        self.datafile.append_trace_info(self.current_dataset_name, info)
開發者ID:boylea,項目名稱:sparkle,代碼行數:104,代碼來源:search_runner.py


注:本文中的sparkle.stim.stimulus_model.StimulusModel.testDoc方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。