mirror of
				http://172.16.0.230/r/SIF/TowerOptoSifAndSpectral.git
				synced 2025-10-25 13:59:44 +08:00 
			
		
		
		
	
		
			
	
	
		
			865 lines
		
	
	
		
			42 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			865 lines
		
	
	
		
			42 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|  | /***************************************************//**
 | |||
|  |  * @file    SeaBreezeWrapper.h | |||
|  |  * @date    July 2009 | |||
|  |  * @author  Ocean Optics, Inc. | |||
|  |  * | |||
|  |  * This is a trivial interface to SeaBreeze that allows | |||
|  |  * the user to connect to devices over USB. | |||
|  |  * This is intended as a usable and extensible API. | |||
|  |  * | |||
|  |  * This provides a C interface to help with linkage. | |||
|  |  * | |||
|  |  * LICENSE: | |||
|  |  * | |||
|  |  * SeaBreeze Copyright (C) 2014, Ocean Optics Inc | |||
|  |  * | |||
|  |  * Permission is hereby granted, free of charge, to any person obtaining | |||
|  |  * a copy of this software and associated documentation files (the | |||
|  |  * "Software"), to deal in the Software without restriction, including | |||
|  |  * without limitation the rights to use, copy, modify, merge, publish, | |||
|  |  * distribute, sublicense, and/or sell copies of the Software, and to | |||
|  |  * permit persons to whom the Software is furnished to do so, subject | |||
|  |  * to the following conditions: | |||
|  |  * | |||
|  |  * The above copyright notice and this permission notice shall be included | |||
|  |  * in all copies or substantial portions of the Software. | |||
|  |  * | |||
|  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | |||
|  |  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | |||
|  |  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. | |||
|  |  * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY | |||
|  |  * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, | |||
|  |  * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE | |||
|  |  * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | |||
|  |  *******************************************************/ | |||
|  | 
 | |||
|  | #ifndef SEABREEZE_WRAPPER_H
 | |||
|  | #define SEABREEZE_WRAPPER_H
 | |||
|  | 
 | |||
|  | #define SEABREEZE_API_VERSION "3.0.11"  //!< current version of the SeaBreezeWrapper API
 | |||
|  | #define SEABREEZE_MAX_DEVICES 32        //!< how many different spectrometer types we support
 | |||
|  | 
 | |||
|  | #include "api/DllDecl.h"
 | |||
|  | 
 | |||
|  | #ifdef __cplusplus
 | |||
|  | 
 | |||
|  | /**
 | |||
|  | * @brief Encapsulates all SeaBreeze classes | |||
|  | */ | |||
|  | namespace seabreeze { | |||
|  | 	class Device; | |||
|  | } | |||
|  | 
 | |||
|  | /**
 | |||
|  |     Original interface to SeaBreeze.  SeaBreezeAPI represents a proposed architecture for | |||
|  |     future development. | |||
|  | */ | |||
|  | class DLL_DECL SeaBreezeWrapper { | |||
|  | public: | |||
|  | 
 | |||
|  |     //! get handle to Singleton
 | |||
|  |     static SeaBreezeWrapper *getInstance(); | |||
|  | 
 | |||
|  |     //! free some static memory under Microsoft profiler
 | |||
|  |     static void shutdown(); | |||
|  | 
 | |||
|  |     // lifecycle
 | |||
|  |     int    openSpectrometer          (int index, int *errorCode); | |||
|  |     int    closeSpectrometer         (int index, int *errorCode); | |||
|  | 
 | |||
|  |     // metadata
 | |||
|  |     int    getModel                  (int index, int *errorCode, char *buf, int len); | |||
|  |     int    getSerialNumber           (int index, int *errorCode, char *buf, int len); | |||
|  | 
 | |||
|  |     // basic acquisitions
 | |||
|  |     void   setIntegrationTimeMicrosec(int index, int *errorCode, unsigned long integration_time_micros); | |||
|  |     int    getWavelengths            (int index, int *errorCode, double *wavelengths, int length); | |||
|  |     int    getFormattedSpectrum      (int index, int *errorCode, double* buffer, int buffer_length); | |||
|  |     int    getUnformattedSpectrum    (int index, int *errorCode, unsigned char *buffer, int buffer_length); | |||
|  |     int    getFormattedSpectrumLength(int index, int *errorCode); | |||
|  |     int    getUnformattedSpectrumLength(int index, int *errorCode); | |||
|  |     long   getMinIntegrationTimeMicrosec(int index, int *errorCode); | |||
|  |     long   getMaxIntegrationTimeMicrosec(int index, int *errorCode); | |||
|  |     int    getMaximumIntensity(int index, int *errorCode); | |||
|  | 
 | |||
|  |     // advanced features
 | |||
|  |     int    getElectricDarkPixelIndices(int index, int *errorCode, int *indices, int length); | |||
|  |     void   setTriggerMode            (int index, int *errorCode, int mode); | |||
|  |     void   setStrobeEnable           (int index, int *errorCode, unsigned char strobe_enable); | |||
|  |     void   setShutterOpen            (int index, int *errorCode, unsigned char opened); | |||
|  |     void   setContinuousStrobePeriodMicrosec(int index, int *errorCode, unsigned short strobe_id, unsigned long period_usec); | |||
|  |     void   setAcquisitionDelayMicrosec(int index, int *errorCode, unsigned long delay_usec); | |||
|  | 
 | |||
|  |     // Buffering features
 | |||
|  |     void   clearBuffer               (int index, int *errorCode); | |||
|  |     unsigned long getBufferElementCount(int index, int *errorCode); | |||
|  |     unsigned long getBufferCapacity  (int index, int *errorCode); | |||
|  |     unsigned long getBufferCapacityMaximum(int index, int *errorCode); | |||
|  |     unsigned long getBufferCapacityMinimum(int index, int *errorCode); | |||
|  |     void   setBufferCapacity         (int index, int *errorCode, unsigned long capacity); | |||
|  | 
 | |||
|  |     // EEPROM access
 | |||
|  |     int    readEEPROMSlot            (int index, int *errorCode, int slot_number, unsigned char *buffer, int buffer_length); | |||
|  |     int    writeEEPROMSlot           (int index, int *errorCode, int slot_number, unsigned char *buffer, int buffer_length); | |||
|  | 
 | |||
|  |     // irradiance calibration
 | |||
|  |     int    readIrradCalibration      (int index, int *errorCode, float *buffer, int buffer_length); | |||
|  |     int    writeIrradCalibration     (int index, int *errorCode, float *buffer, int buffer_length); | |||
|  |     int    hasIrradCollectionArea    (int index, int *errorCode); | |||
|  |     float  readIrradCollectionArea   (int index, int *errorCode); | |||
|  |     void   writeIrradCollectionArea  (int index, int *errorCode, float area); | |||
|  | 
 | |||
|  |     // thermal-electric cooler
 | |||
|  |     double readTECTemperature        (int index, int *errorCode); | |||
|  |     void   setTECTemperature         (int index, int *errorCode, double temperature_degrees_celsius); | |||
|  |     void   setTECEnable              (int index, int *errorCode, unsigned char tec_enable); | |||
|  |     void   setTECFanEnable           (int index, int *errorCode, unsigned char tec_fan_enable); | |||
|  | 
 | |||
|  |     // Wrapper features
 | |||
|  |     void   setVerbose                (bool flag); | |||
|  |     void   setLogfile                (char *path, int length); | |||
|  |     int    getAPIVersionString       (char *buffer, int length); | |||
|  |     int    getErrorString            (int errorCode, char *buffer, int buffer_length); | |||
|  | 
 | |||
|  |     // raw USB access
 | |||
|  |     int    writeUSB                  (int index, int *errorCode, unsigned char endpoint, unsigned char *buffer, unsigned int length); | |||
|  |     int    readUSB                   (int index, int *errorCode, unsigned char endpoint, unsigned char *buffer, unsigned int length); | |||
|  |     int    getUSBDescriptorString    (int index, int *errorCode, int id, unsigned char *buffer, int length); | |||
|  | 
 | |||
|  |     // light sources (JAZ?)
 | |||
|  |     int    getLightSourceCount       (int index, int *errorCode); | |||
|  |     void   setLightSourceEnable      (int index, int *errorCode, int lightIndex, unsigned char enable); | |||
|  |     void   setLightSourceIntensity   (int index, int *errorCode, int lightIndex, double intensity); | |||
|  | 
 | |||
|  | private: | |||
|  |     SeaBreezeWrapper(); | |||
|  |     virtual ~SeaBreezeWrapper(); | |||
|  | 
 | |||
|  |     //! Singleton
 | |||
|  |     static SeaBreezeWrapper *instance; | |||
|  | 
 | |||
|  |     //! types of supported Ocean Optics devices (not actual devices found enumerated on the USB bus)
 | |||
|  |     seabreeze::Device *devices[SEABREEZE_MAX_DEVICES]; | |||
|  | }; | |||
|  | 
 | |||
|  | extern "C" { | |||
|  | #endif /* __cplusplus */
 | |||
|  | 
 | |||
|  |     /* All of these C functions start with seabreeze_ to prevent namespace
 | |||
|  |      * collisions. | |||
|  |      */ | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function opens a device attached to the system. | |||
|  |      * @param index (Input) The index of a USB device to try to open. | |||
|  |      *        Valid values will range from 0 to N-1 for N connected devices. | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used | |||
|  |      *        for storing error codes. | |||
|  |      * @return int: The function will return an integer of 0 if it opened a | |||
|  |      *      device successfully, or 1 if no device was opened (in which | |||
|  |      *      case the error_code variable will be set). | |||
|  |      * | |||
|  |      * This can be called repeatedly with incrementing index values (until | |||
|  |      * it returns 1) to open all connected devices. | |||
|  |      * | |||
|  |      * Note that the index used to open a device with this function should also | |||
|  |      * be used to communicate with that same device in the other functions | |||
|  |      * provided here. | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_open_spectrometer(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function closes the spectrometer attached to the system. | |||
|  |      * @param index (Input) The index of a device previously opened with | |||
|  |      *        open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used | |||
|  |      *        for storing error codes. | |||
|  |      * @return int: This function will return 1 no matter what!  (MZ) | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_close_spectrometer(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function returns a description of the error denoted by | |||
|  |      *        error_code. | |||
|  |      * @param error_code (Input) The integer error code to look up.  Error | |||
|  |      *        codes not be zero, but can be any non-zero integer (positive or | |||
|  |      *        negative). | |||
|  |      * @param buffer (Output) A character buffer allocated to contain at least | |||
|  |      *        'buffer_length' bytes, which will be populated with the string | |||
|  |      *        description of the given error code. | |||
|  |      * @param buffer_length (Input) allocated size of the output buffer | |||
|  |      * @return int: Number of bytes written to buffer. | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_error_string(int error_code, char *buffer, int buffer_length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function returns a string denoting the type of the device. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *      error codes.  This may be NULL. | |||
|  |      * @param buffer (Output)  A character buffer allocated to contain at least | |||
|  |      *      'buffer_length' bytes, which will be populated with the | |||
|  |      *      spectrometer type. | |||
|  |      * @param buffer_length (Input) allocated size of the buffer | |||
|  |      * @return int: Number of bytes written to the buffer. | |||
|  |      * | |||
|  |      * The populated buffer will hold one of the following strings: | |||
|  |      * | |||
|  |      * \verbatim | |||
|  |      *      NONE:        Used if no spectrometer is found (error_code will also be set) | |||
|  |      *      HR2000:      Represents an HR2000 Spectrometer | |||
|  |      *      HR2000PLUS:  Represents an HR2000+ Spectrometer | |||
|  |      *      HR4000:      Represents an HR4000 Spectrometer | |||
|  |      *      JAZ:         Represents a Jaz Spectrometer | |||
|  |      *      MAYA2000:    Represents a Maya2000 Spectrometer | |||
|  |      *      MAYALSL:     Represents a Maya-LSL Spectrometer | |||
|  |      *      MAYA2000PRO: Represents a Maya2000 Pro Spectrometer | |||
|  |      *      NIRQUEST256: Represents an NIRQuest256 Spectrometer | |||
|  |      *      NIRQUEST512: Represents an NIRQuest512 Spectrometer | |||
|  |      *      QE65000:     Represents a QE65000 Spectrometer | |||
|  |      *      QE-PRO:      Represents a QE-Pro Spectrometer | |||
|  |      *      STS:         Represents an STS Spectrometer | |||
|  |      *      TORUS:       Represents a Torus Spectrometer | |||
|  |      *      USB2000:     Represents a USB2000 Spectrometer | |||
|  |      *      USB2000PLUS: Represents a USB2000+ Spectrometer | |||
|  |      *      USB4000:     Represents a USB4000 Spectrometer | |||
|  |      * \endverbatim | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_model(int index, int *error_code, char *buffer, int buffer_length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function sets the trigger mode for the specified device. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *      error codes. | |||
|  |      * @param mode (Input) a trigger mode (0 = normal, 1 = software, 2 = synchronization, | |||
|  |      *        3 = external hardware, etc.) | |||
|  |      * | |||
|  |      * Note that requesting an unsupported mode will result in an error. | |||
|  |      */ | |||
|  | 
 | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_trigger_mode(int index, int *error_code, int mode); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function sets the integration time for the specified device. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *      error codes. | |||
|  |      * @param integration_time_micros (Input) The new integration time in units of | |||
|  |      *      microseconds | |||
|  |      * | |||
|  |      * This function does not automatically perform a stability scan. | |||
|  |      * If your application requires a stability scan following a change | |||
|  |      * in integration time, you need to command that yourself. | |||
|  |      */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_integration_time_microsec(int index, int *error_code, | |||
|  |             unsigned long integration_time_micros); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function returns the smallest integration time setting, | |||
|  |      *        in microseconds, that is valid for the spectrometer. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @return Returns minimum legal integration time in microseconds if > 0. | |||
|  |      *        On error, returns -1 and error_code will be set accordingly. | |||
|  |      */ | |||
|  |     DLL_DECL long | |||
|  |     seabreeze_get_min_integration_time_microsec(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function sets the shutter state on the spectrometer. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param opened (Input) A logical boolean used for denoting the desired | |||
|  |      *      state (opened/closed) of the shutter.   If the value of opened is | |||
|  |      *      non-zero, then the shutter will open.  If the value of opened is | |||
|  |      *      zero, then the shutter will close. | |||
|  |      */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_shutter_open(int index, int *error_code, unsigned char opened); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function sets the strobe enable on the spectrometer.  Note that | |||
|  |      *        this refers to a particular set of one or more digital pins on the | |||
|  |      *        device: lamp enable, single strobe, and continuous strobe may all | |||
|  |      *        be affected by this setting, and these generally control lamps | |||
|  |      *        that are external to the device.  Note that this is related to, but | |||
|  |      *        different from, the light source interface which allows the intensity | |||
|  |      *        and/or enable status of individual light sources (e.g. lamp bulbs, | |||
|  |      *        LEDs, or lasers) in attached modules to be controlled.  Refer to | |||
|  |      *        the seabreeze_xxx_light_source_ functions for finer control of | |||
|  |      *        certain light source modules that are more closely integrated with | |||
|  |      *        the spectrometer. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output)  A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param strobe_enable (Input) A logical boolean used for denoting the | |||
|  |      *      desired value (high/low) of the strobe-enable pin.   If the value of | |||
|  |      *      strobe_enable is zero, then the pin should be set low.  If the value | |||
|  |      *      of strobe_enable is non-zero, then the pin should be set high. | |||
|  |      */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_strobe_enable(int index, int *error_code, unsigned char strobe_enable); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function gets the number of attached light sources that can | |||
|  |      *        be programmatically controlled. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output)  A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @return The number of light sources that can be controlled | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_light_source_count(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function sets the enable status on a connected light source. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output)  A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param light_index (Input)  The index of the light source.  This will | |||
|  |      *      usually be zero, but if the light module contains multiple LEDs, | |||
|  |      *      bulbs, lasers, etc. then this may be higher.  Use | |||
|  |      *      seabreeze_get_light_source_count() to bound the maximum value . | |||
|  |      * @param enable (Input) A logical boolean used for denoting whether to enable | |||
|  |      *      the indicated light source.   If the value of | |||
|  |      *      enable is zero, then the light source should be disabled.  If the value | |||
|  |      *      of enable is non-zero, then the light source should be enabled. | |||
|  |      */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_light_source_enable(int index, int *error_code, | |||
|  |             int light_index, unsigned char enable); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function sets the intensity of a connected light source. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output)  A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param light_index (Input)  The index of the light source.  This will | |||
|  |      *      usually be zero, but if the light module contains multiple LEDs, | |||
|  |      *      bulbs, lasers, etc. then this may be higher.  Use | |||
|  |      *      seabreeze_get_light_source_count() to bound the maximum value. | |||
|  |      * @param intensity (Input) The desired intensity of the light source.  The | |||
|  |      *      range of intensities is normalized over [0, 1], where 0 is the | |||
|  |      *      minimum controllable intensity of the light source, and 1 is the | |||
|  |      *      maximum. | |||
|  |      * | |||
|  |      * @warning SETTING THE INTENSITY TO ZERO MAY NOT CAUSE THE LIGHT SOURCE | |||
|  |      *      TO TURN OFF COMPLETELY.  The light source will go to the | |||
|  |      *      dimmest level it can reach without changing its enable status. | |||
|  |      *      To switch the light source off, try using the | |||
|  |      *      seabreeze_set_light_source_enable() function or provide the | |||
|  |      *      operator with another way to disable or block the light source. | |||
|  |      */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_light_source_intensity(int index, int *error_code, | |||
|  |             int light_index, double intensity); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function reads a string out of the spectrometer's EEPROM slot | |||
|  |      *        and returns the result. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param slot_number (Input) The number of the slot to read out.  Possible | |||
|  |      *        values are 0 through 16*. | |||
|  |      * @param buffer (Output)  A buffer (with memory already allocated) to hold the | |||
|  |      *        value read out of the EEPROM slot | |||
|  |      * @param buffer_length (Input) The length of the allocated output buffer (typically 16) | |||
|  |      * @return int: The number of bytes read from the EEPROM slot into the buffer | |||
|  |      * | |||
|  |      * (*) Actual maximum slot count varies by spectrometer model.  For the number of supported | |||
|  |      *     slots on your spectrometer, see EEPROMSlotFeature instantiation in appropriate | |||
|  |      *     device file under src/vendors/OceanOptics/devices. | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_read_eeprom_slot(int index, int *error_code, int slot_number, unsigned char *buffer, | |||
|  |             int buffer_length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function writes a string to a spectrometer's EEPROM slot | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer for storing error codes. | |||
|  |      * @param slot_number (Input) The number of the slot being written (e.g. 0-16*). | |||
|  |      * @param buffer (Input) A buffer containing the text to write to the slot. | |||
|  |      * @param buffer_length (Input) The length of the text to write (typically 15) | |||
|  |      * @return number of bytes written | |||
|  |      * | |||
|  |      * @warning CARELESS USE OF THIS FUNCTION CAN RENDER YOUR SPECTROMETER INOPERABLE, | |||
|  |      *          POSSIBLY REQUIRING R.M.A. OR REFLASHING TO RESTORE FUNCTIONALITY. | |||
|  |      *          PLEASE READ YOUR SPECTROMETER'S DATA SHEET CAREFULLY BEFORE USE. | |||
|  |      * | |||
|  |      * (*) See note in seabreeze_read_eeprom_slot() regarding per-device slot limits. | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_write_eeprom_slot(int index, int *error_code, int slot_number, unsigned char *buffer, | |||
|  |             int buffer_length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function reads out an irradiance calibration from the spectrometer's | |||
|  |      *        internal memory if that feature is supported. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param buffer (Output) array of floating point values into which calibration values are stored | |||
|  |      * @param buffer_length (Input) maximum number of values to copy from the device into buffer | |||
|  |      * @return int: the number of floats read from the device into the buffer | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_read_irrad_calibration(int index, int *error_code, float *buffer, | |||
|  |         int buffer_length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function writes an irradiance calibration to the spectrometer's | |||
|  |      *        internal memory if that feature is supported. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param buffer (Output) array of floating point values to store into the device | |||
|  |      * @param buffer_length (Input) number of calibration factors to write | |||
|  |      * @return int: the number of floats written from the buffer to the device | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_write_irrad_calibration(int index, int *error_code, float *buffer, | |||
|  |         int buffer_length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function checks for an irradiance collection area in the spectrometer's | |||
|  |      *        internal memory if that feature is supported. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @return int: 0 if no collection area available, 1 if available. | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_has_irrad_collection_area(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function reads an irradiance collection area from the spectrometer's | |||
|  |      *        internal memory if that feature is supported. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @return float: collection area (typically in units of cm^2) read from device | |||
|  |      */ | |||
|  |     DLL_DECL float | |||
|  |     seabreeze_read_irrad_collection_area(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function writes an irradiance collection area to the spectrometer's | |||
|  |      *        internal memory if that feature is supported. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param area (Input) collection area to save to the EEPROM (presumably cm^2) | |||
|  |      */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_write_irrad_collection_area(int index, int *error_code, float area); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function reads the value of the TEC and returns the value in | |||
|  |      *        degrees celsius. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @return int: The TEC temperature in degrees Celsius. | |||
|  |      */ | |||
|  |     DLL_DECL double | |||
|  |     seabreeze_read_tec_temperature(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function sets the TEC temperature. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param temperature_degrees_celsius (Input) The desired temperature, in degrees | |||
|  |      *        Celsius. | |||
|  |      */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_tec_temperature(int index, int *error_code, | |||
|  |             double temperature_degrees_celsius); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function enables the TEC feature on the spectrometer. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param tec_enable (Input) A logical boolean that denotes the desired TEC enable | |||
|  |      *        state.  If the value of tec_enable is zero, the TEC should be disabled. | |||
|  |      *        If the value of tec_enable is non-zero, the TEC should be enabled. | |||
|  |      */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_tec_enable(int index, int *error_code, unsigned char tec_enable); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This function enables the TEC Fan on the spectrometer. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param tec_fan_enable (Input) A logical boolean that denotes the desired TEC fan enable | |||
|  |      *        state.  If the value of tec_fan_enable is zero, the TEC fan should be disabled. | |||
|  |      *        If the value of tec_fan_enable is non-zero, the TEC fan should be enabled. | |||
|  |      */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_tec_fan_enable(int index, int *error_code, unsigned char tec_fan_enable); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This acquires a spectrum and returns the answer in raw, unformatted bytes. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param buffer (Output) A buffer (with memory already allocated) to hold the | |||
|  |      *        spectral data | |||
|  |      * @param buffer_length (Input) The length of the buffer in bytes (not pixels) | |||
|  |      * @return int: The number of bytes read into the buffer | |||
|  |      * @see   sample-code/c/demo-unformatted-spectrum.c | |||
|  |      * | |||
|  |      * An unformatted spectrum is the raw sequence of bytes returned by the spectrometer to  | |||
|  |      * the PC over USB.  The bytes have not been broken down into pixels, they're in the  | |||
|  |      * original endianness, absolutely nothing has been done to them.  The caller is expected  | |||
|  |      * to know how many bytes are returned by each spectrometer model, which bytes indicate  | |||
|  |      * synchronization points or whatever, etc.   | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_unformatted_spectrum(int index, int *error_code, | |||
|  |             unsigned char *buffer, int buffer_length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This acquires a spectrum and returns the answer in formatted | |||
|  |      *        floats.  In this mode, auto-nulling should be automatically | |||
|  |      *        performed for devices that support it. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param buffer (Output) A buffer (with memory already allocated) to hold the | |||
|  |      *        spectral data | |||
|  |      * @param buffer_length (Input) The length of the buffer in floats (not bytes) | |||
|  |      * @return int: The number of floats read into the buffer | |||
|  |      * | |||
|  |      * A formatted spectrum returns exactly one double-precision floating-point IEEE value  | |||
|  |      * per pixel, as opposed to a raw byte stream.  It has also had autonulling (gain control)  | |||
|  |      * applied, meaning it has been scaled up to the spectrometer's full dynamic range using  | |||
|  |      * the gain setting recorded in that spectrometer’s EEPROM. | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_formatted_spectrum(int index, int *error_code, | |||
|  |             double* buffer, int buffer_length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This returns an integer denoting the length of a raw spectrum | |||
|  |      *        (as returned by get_unformatted_spectrum(...)). | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *      error codes. | |||
|  |      * @return int: An integer denoting the length of an unformatted spectrum in bytes | |||
|  |      * | |||
|  |      * The caller is expected to know the number of bytes per pixel and the endian | |||
|  |      * ordering, but it will normally be 2 bytes per pixel, LSB-MSB order. | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_unformatted_spectrum_length(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This returns an integer denoting the number of pixels in a | |||
|  |      *        formatted spectrum (as returned by get_formatted_spectrum(...)). | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @return int: An integer denoting the length of a formatted spectrum (in pixels) | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_formatted_spectrum_length(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This computes the wavelengths for the spectrometer and fills in the | |||
|  |      *        provided array (up to the given length) with those values. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param wavelengths (Output) A pre-allocated array of doubles into which the | |||
|  |      *        wavelengths will be copied | |||
|  |      * @param length (Input) The number of values to copy into the wavelength array (this should | |||
|  |      *        be no larger than the number of doubles allocated in the wavelengths | |||
|  |      *        array) | |||
|  |      * @return int: An integer denoting the number of wavelengths written to the buffer | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_wavelengths(int index, int *error_code, double *wavelengths, int length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This reads the device's serial number and fills the | |||
|  |      *        provided array (up to the given length) with it. | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param buffer (Output) A pre-allocated array of characters into which the serial number | |||
|  |      *        will be copied | |||
|  |      * @param buffer_length (Input) The number of values to copy into the buffer (this should | |||
|  |      *        be no larger than the number of chars allocated in the buffer) (typically 16) | |||
|  |      * @return int: An integer denoting the number of bytes written into the buffer | |||
|  |      * | |||
|  |      * Note that "serial numbers" may include both digits and letters | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_serial_number(int index, int *error_code, char *buffer, int buffer_length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief This fills in the provided array (up to the given length) with the indices | |||
|  |      *        of the pixels that are electrically active but optically masked | |||
|  |      *        (a.k.a. electric dark pixels). | |||
|  |      * @param index (Input) The index of a device previously opened with open_spectrometer(). | |||
|  |      * @param error_code (Output) A pointer to an integer that can be used for storing | |||
|  |      *        error codes. | |||
|  |      * @param indices (Output) A pre-allocated array of ints into which the pixel indices | |||
|  |      *        will be copied | |||
|  |      * @param length (Input) The number of values to copy into the indices array (this should | |||
|  |      *        be no larger than the number of ints allocated in the indices array) | |||
|  |      * @return int: An integer denoting the number of indices written into the indices buffer | |||
|  |      * | |||
|  |      * Note that not all detectors have optically masked pixels; in that case, | |||
|  |      * this function will return zero. | |||
|  |      */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_electric_dark_pixel_indices(int index, int *error_code, | |||
|  |         int *indices, int length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |      * @brief Shutdown SeaBreeze completely, releasing all resources and destroying | |||
|  |      *        any cached device handles. | |||
|  |      * | |||
|  |      * This function is not normally needed (Singletons are destroyed automatically | |||
|  |      * at process end), but calling this explicitly can resolve some spurious warnings | |||
|  |      * in highly paranoid memory leak profilers. | |||
|  |      */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_shutdown(); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Write a raw array of bytes to a USB spectrometer. | |||
|  |     * @param index (Input) index of an opened spectrometer | |||
|  |     * @param errorCode (Output) pointer to an allocated integer field for receiving error codes | |||
|  |     * @param endpoint (Input) USB endpoint for write operation | |||
|  |     *        (see src/vendors/OceanOptics/features/raw_bus_access/RawUSBBusAccessFeature.cpp) | |||
|  |     * @param buffer (Input) array of bytes to send to USB spectrometer | |||
|  |     * @param length (Input) number of bytes to write from buffer to spectrometer | |||
|  |     * @return number of bytes written | |||
|  |     * | |||
|  |     * Write the bytes in the buffer according to the two command bytes at the | |||
|  |     * start of the buffer. | |||
|  |     * | |||
|  |     * \section Endpoints | |||
|  |     * | |||
|  |     * You may wonder why the caller needs to specify an explicit endpoint for | |||
|  |     * raw read and write operations; does not SeaBreeze already know the appro- | |||
|  |     * priate endpoints for any open spectrometer, for example.  Yes it does, | |||
|  |     * but currently there is no easy way to extract endpoints from a generic | |||
|  |     * spectrometer, due to the fact that OOIUSBCypressEndpointMap and | |||
|  |     * OOIUSBSTSEndpointMap do not share a common base class (see | |||
|  |     * OOIUSBEndpointMaps.h). | |||
|  |     * | |||
|  |     * We could attempt to extract them from the TransferHelpers held by | |||
|  |     * OOIUSBInterface, but without a Hint to use as a key, we would likely | |||
|  |     * obtain unmatched or inappropriate versions for control exchanges. | |||
|  |     * As ControlHint and OBPControlHint share no common ancestor or type data | |||
|  |     * to associate them while distinguishing from other hint types, we cannot | |||
|  |     * automatically infer appropriate control endpoints. | |||
|  |     * | |||
|  |     * And finally, we have no way of knowing that the user really wants to | |||
|  |     * use control endpoints anyway: they may actually desire high-speed | |||
|  |     * spectral retrieval.  So really, this needs to remain a manual external | |||
|  |     * operation until such time as we provide a much richer, generic query | |||
|  |     * interface over our internal endpoint lookup tables. | |||
|  |     * | |||
|  |     * \section Example | |||
|  |     * | |||
|  |     * For instance, for most USB spectrometers, the hex values <tt>05 00</tt> in | |||
|  |     * the buffer means 'read EEPROM slot 0'. Writing this command, and following | |||
|  |     * it with the \c seabreeze_read_usb command and the same hex <tt>05 00</tt> | |||
|  |     * in the buffer, will result in the spectrometer's serial number, in ASCII | |||
|  |     * characters, being delivered to the subsequent bytes in the buffer array. | |||
|  |     * This would appear in the output buffer as: | |||
|  |     * | |||
|  |     * \code | |||
|  |     *   05 00 55 53 42 32 2B 48 30 31 34 31 36 00 00 00 00 (hex) | |||
|  |     * \endcode | |||
|  |     * | |||
|  |     * (<tt>USB2+H01416</tt> ASCII, skipping the two command bytes) | |||
|  |     * | |||
|  |     * A C or C++ program could use the data as-is, but a C# program could | |||
|  |     * append to a string, each byte, cast as char, stopping on the first null | |||
|  |     * character: | |||
|  |     * | |||
|  |     * \code | |||
|  |     *   string serial = ""; | |||
|  |     *   for (int i = 0; i < length && buffer[i] != '\0'; i++) | |||
|  |     *     serial += (char)buffer[i]; | |||
|  |     * \endcode | |||
|  |     * | |||
|  |     * This is equivalent to: | |||
|  |     * | |||
|  |     * \code | |||
|  |     *   string serial = System.Text.ASCIIEncoding.ASCII.GetString(buffer).Trim('\0'); | |||
|  |     * \endcode | |||
|  |     * | |||
|  |     * For C# and VB.NET, the trailing zero-fill must be removed. Those null | |||
|  |     * characters would not print or display on a screen but would make a file | |||
|  |     * name invalid. | |||
|  |     */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_write_usb(int index, int *errorCode, unsigned char endpoint, unsigned char* buffer, unsigned int length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Read a raw array of bytes from a USB spectrometer. | |||
|  |     * @param index (Input) index of a previously opened spectrometer | |||
|  |     * @param errorCode (Output) pointer to an allocated integer field for receiving error codes | |||
|  |     * @param endpoint (Input) USB endpoint for read operation | |||
|  |     *        (see src/vendors/OceanOptics/features/raw_bus_access/RawUSBBusAccessFeature.cpp) | |||
|  |     * @param buffer (Input) array of allocated bytes at which to recieve USB data | |||
|  |     * @param length (Input) maximum number of bytes to read from spectrometer | |||
|  |     * @return number of received bytes written to buffer | |||
|  |     * | |||
|  |     * Read bytes from the spectrometer into the buffer. The buffer starts with | |||
|  |     * two bytes of command information that will be followed by the transferred | |||
|  |     * bytes. The read and write USB functions allow low-level control of the | |||
|  |     * spectrometer via USB commands. The higher-level SeaBreeze functions issue | |||
|  |     * USB commands internally. | |||
|  |     * | |||
|  |     * Reading USB data takes two steps. First a seabreeze_write_usb call requests | |||
|  |     * the transfer, then a seabreeze_read_usb call delivers the data. Writing a buffer | |||
|  |     * to USB takes one step. The operating system handle for the spectrometer is | |||
|  |     * managed by SeaBreeze. USB has a concept of "end points". These are implicitly | |||
|  |     * addressed by the seabreeze_read_usb and seabreeze_write_usb functions. | |||
|  |     */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_read_usb(int index, int *errorCode, unsigned char endpoint, unsigned char* buffer, unsigned int length); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Get the SeaBreeze library's internal version identifier. | |||
|  |     * @param buffer (Output) pointer to an allocated character array | |||
|  |     *                        to hold the returned version string | |||
|  |     * @param len    (Input)  size of the allocated buffer | |||
|  |     * @return number of bytes written to buffer | |||
|  |     */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_api_version_string(char *buffer, int len); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Get a USB descriptor string by number | |||
|  |     * @param index     (Input)  Which spectrometer to set | |||
|  |     * @param errorCode (Output) pointer to allocated integer to receive error code | |||
|  |     * @param id        (Input)  numeric ID of the desired USB descriptor string | |||
|  |     * @param buffer    (Output) pointer to an allocated character array to hold | |||
|  |     *                           the returned descriptor string | |||
|  |     * @param len       (Input)  size of the allocated buffer | |||
|  |     * @return number of bytes written to buffer | |||
|  |     */ | |||
|  |     DLL_DECL int | |||
|  |     seabreeze_get_usb_descriptor_string(int index, int *errorCode, int id, unsigned char *buffer, int len); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Set the continuous strobe period in microseconds | |||
|  |     * @param index (Input) Which spectrometer to set | |||
|  |     * @param errorCode (Output) pointer to allocated integer to receive error code | |||
|  |     * @param strobe_id (Input) index of the strobe generator (currently always zero) | |||
|  |     * @param period_usec (Input) total period of the strobe, in microseconds | |||
|  |     * @return zero (on success or failure; check errorCode) | |||
|  |     * | |||
|  |     * The resolution is 0.1 milliseconds (100 microseconds). | |||
|  |     */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_continuous_strobe_period_microsec(int index, int *errorCode, | |||
|  |         unsigned short strobe_id, unsigned long period_usec); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Set the acquisition delay (trigger delay) in microseconds.  This | |||
|  |     *        controls the amount of time between a particular event | |||
|  |     *        (usually a request for spectrum or an external trigger pulse) | |||
|  |     *        and the start of acquisition. | |||
|  |     */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_acquisition_delay_microsec(int index, | |||
|  |         int *errorCode, unsigned long delay_usec); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Clear the spectrum buffer (if equipped) | |||
|  |     * @param index (Input) Which spectrometer should have its buffer cleared | |||
|  |     * @param error_code (Output) Pointer to allocated integer to receive error code | |||
|  |     */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_clear_buffer(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Get the number of spectra presently in the buffer (if equipped) | |||
|  |     * @param index (Input) Which spectrometer should have its buffer queried | |||
|  |     * @param error_code (Output) Pointer to allocated integer to receive error code | |||
|  |     * @return Number of spectra in the buffer | |||
|  |     */ | |||
|  |     DLL_DECL unsigned long | |||
|  |     seabreeze_get_buffer_element_count(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Get the currently configured size of the data buffer (if equipped) | |||
|  |     * @param index (Input) Which spectrometer should have its buffer queried | |||
|  |     * @param error_code (Output) Pointer to allocated integer to receive error code | |||
|  |     * @return The present limit on the number of spectra that will be retained. | |||
|  |     */ | |||
|  |     DLL_DECL unsigned long | |||
|  |     seabreeze_get_buffer_capacity(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Get the maximum possible configurable size for the data buffer (if equipped) | |||
|  |     * @param index (Input) Which spectrometer should have its buffer queried | |||
|  |     * @param error_code (Output) Pointer to allocated integer to receive error code | |||
|  |     * @return Maximum allowed value for the buffer size | |||
|  |     */ | |||
|  |     DLL_DECL unsigned long | |||
|  |     seabreeze_get_buffer_capacity_maximum(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Get the minimum possible configurable size for the data buffer (if equipped) | |||
|  |     * @param index (Input) Which spectrometer should have its buffer queried | |||
|  |     * @param error_code (Output) Pointer to allocated integer to receive error code | |||
|  |     * @return Minimum allowed value for the buffer size | |||
|  |     */ | |||
|  |     DLL_DECL unsigned long | |||
|  |     seabreeze_get_buffer_capacity_minimum(int index, int *error_code); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Set the number of spectra that the buffer should keep | |||
|  |     * @param index (Input) Which spectrometer should have its buffer modified | |||
|  |     * @param error_code (Output) Pointer to allocated integer to receive error code | |||
|  |     * @param capacity (Input) Limit on number of spectra to store. | |||
|  |     *        Note that this must be within the range defined by the capacity minimum | |||
|  |     *        and maximum values. | |||
|  |     */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_buffer_capacity(int index, int *error_code, unsigned long capacity); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief Programmatically enable debug outputs to stderr | |||
|  |     * @param flag (Input) zero to disable (default), non-zero to enable | |||
|  |     */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_verbose(int flag); | |||
|  | 
 | |||
|  |     /**
 | |||
|  |     * @brief redirect verbose logging to named file | |||
|  |     * @param flag (Input) NULL for default behavior (stderr), non-null for valid OS path | |||
|  |     */ | |||
|  |     DLL_DECL void | |||
|  |     seabreeze_set_logfile(char* pathname, int len); | |||
|  | 
 | |||
|  | #ifdef __cplusplus
 | |||
|  | }; | |||
|  | #endif /* __cplusplus */
 | |||
|  | 
 | |||
|  | #endif /* SEABREEZE_WRAPPER_H */
 |