This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
resources:eval:user-guides:eval-adicup360:reference_designs:demo_cn0396 [25 Aug 2016 15:51] – created Veronica Lupei | resources:eval:user-guides:eval-adicup360:reference_designs:demo_cn0396 [14 Mar 2021 10:02] (current) – [Obtaining the Source Code] adding in .Bin file Zuedmar Arceo | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | ======4 – Wire Electrochemical Dual Toxic Gas Sensing System | + | ====== 4 – Wire Electrochemical Dual Toxic Gas Demo ====== |
- | The **ADuCM360_demo_cn0396** is a dual toxic gas detector demo project, for the EVAL-ADICUP360 base board with additional EVAL-CN0396-ARDZ shield, created using the GNU ARM Eclipse Plug-ins in Eclipse environment. | + | The **ADuCM360_demo_cn0396** is a dual toxic gas detector demo project, for the EVAL-ADICUP360 base board with additional EVAL-CN0396-ARDZ shield, created using the CrossCore Embedded Studios Interactive Development Environment.(IDE) |
- | \\ | ||
===== General description ===== | ===== General description ===== | ||
+ | |||
+ | The **ADuCM360_demo_cn0396** project uses the [[adi> | ||
+ | |||
+ | The **EVAL-CN0396-ARDZ** board provides a potentiostatic circuit for biasing the electrochemical sensor, along with dual programmable TIA's and 16-bit Sigma-Delta ADC. The TIA's convert the small currents passing in the sensor to a voltage that can be read by the [[adi> | ||
+ | |||
+ | {{: | ||
+ | The **ADuCM360_demo_cn0396** application reads temperature value from ADT7310 and ADC values for each gas channel (CO and H2S), processes the values and make all necessary conversions in order to provide the gas concentrations. A **UART** interface (**115200** baud rate and **8-bits** data length) is used to send the results to terminal window. The output data will be displayed continuously considering a data refresh parameter (see // | ||
+ | |||
+ | |||
+ | |||
+ | Based on the **maximum sensor sensitivity** for each gas the system should be configured before using it. The application will calculate the gas concentration using sensor **gas sensitivity** and then compensate these values using measured temperature value. | ||
+ | |||
+ | < | ||
+ | **Maximum sensitivity** and **gas sensitivity** are dependent on sensor type. These value will need to be updated in case of using another sensor that the one presented here. | ||
+ | </ | ||
+ | |||
+ | {{ : | ||
+ | |||
+ | ===== Demo Requirements ===== | ||
+ | |||
+ | The following is a list of items needed in order to replicate this demo. | ||
+ | * Hardware | ||
+ | * EVAL-ADICUP360 | ||
+ | * EVAL-CN0396-ARDZ | ||
+ | * Electrochemical Gas Sensor (included with CN0396) | ||
+ | * Mirco USB to USB cable | ||
+ | * PC or Laptop with a USB port | ||
+ | * Software | ||
+ | * ADuCM360_demo_cn0396 software | ||
+ | * CrossCore Embedded Studio (2.7.0 or higher) | ||
+ | * ADuCM36x DFP (1.0.2 or higher) | ||
+ | * CMSIS ARM Pack (4.3.0 or higher) | ||
+ | * Serial Terminal Program | ||
+ | * Such as Putty or Tera Term | ||
+ | |||
+ | ===== Setting up the hardware ===== | ||
+ | |||
+ | - To program the base board, set the jumpers/ | ||
+ | - Connect the **EVAL-CN0396-ARDZ** to the Arduino connectors **P2, P5, P6, P7, P8** of the **EVAL-ADICUP360** board. | ||
+ | - Set the jumpers on EVAL-CN0396-ARDZ board, as shown in the picture below.{{ : | ||
+ | - Plug in the USB cable from the PC to the EVAL-ADICUP360 base board via the Debug USB.(P14) | ||
+ | |||
+ | ===== Obtaining the Source Code ===== | ||
+ | |||
+ | There are two basic ways to program the ADICUP360 with the software for the CN0396. | ||
+ | - Dragging and Dropping the .Bin to the MBED drive | ||
+ | - Building, Compiling, and Debugging using CCES | ||
+ | |||
+ | Using the drag and drop method, the software is going to be a version that Analog Devices creates for testing and evaluation purposes. This is the EASIEST way to get started with the reference design. | ||
+ | |||
+ | Importing the project into CrossCore is going to allow you to change parameters and customize the software to fit your needs, but will be a bit more advanced and will require you to download the CrossCore toolchain. | ||
+ | |||
+ | The software for the **ADuCM360_demo_cn0396** demo can be found here: | ||
+ | |||
+ | <WRAP round 80% download> | ||
+ | Prebuilt CN0396 Bin File | ||
+ | * [[https:// | ||
+ | Complete CN0396 Source Files | ||
+ | * [[https:// | ||
+ | |||
+ | </ | ||
+ | |||
+ | <WRAP center round info 80%> | ||
+ | For more information on importing, debugging, or other tools related questions, please see the [[/ | ||
+ | </ | ||
+ | |||
+ | ===== Configuring the Software Parameters ===== | ||
+ | |||
+ | * **Sensor Range** - <fc # | ||
+ | < | ||
+ | #define CO_RANGE | ||
+ | #define H2S_RANGE | ||
+ | </ | ||
+ | |||
+ | * **Sensor Gas Sensitivity** - <fc # | ||
+ | < | ||
+ | #define CO_SENS | ||
+ | #define H2S_SENS | ||
+ | </ | ||
+ | |||
+ | * **Maximum Sensor Gas Sensitivity** - <fc # | ||
+ | < | ||
+ | #define MAX_CO_SENS | ||
+ | #define MAX_H2S_SENS (1000 * pow(10, -9)) | ||
+ | </ | ||
+ | |||
+ | * **Terminal refresh** - // | ||
+ | < | ||
+ | #define DISPLAY_REFRESH | ||
+ | </ | ||
+ | |||
+ | ===== Outputting Data ===== | ||
+ | |||
+ | ==== Serial Terminal Output ==== | ||
+ | |||
+ | - In order to view the data, you must flash the program to the EVAL-ADICUP360. | ||
+ | - Once complete you will need to switch the USB cable from the DEBUG USB (P14) to the USER USB (P13). | ||
+ | - Then follow the UART settings below with the serial terminal program. | ||
+ | \\ | ||
+ | |||
+ | Following is the UART configuration. | ||
+ | Select COM Port | ||
+ | Baud rate: 115200 | ||
+ | Data: 8 bit | ||
+ | Parity: none | ||
+ | Stop: 1 bit | ||
+ | Flow Control: none | ||
+ | \\ | ||
+ | |||
+ | * The data output refreshes in the console window at the rate of the " | ||
+ | |||
+ | {{ : | ||
+ | |||
+ | ===== How to use the Tools ===== | ||
+ | |||
+ | The official tool we promote for use with the EVAL-ADICUP360 is CrossCore Embedded Studio. | ||
+ | |||
+ | ==== Importing ==== | ||
+ | |||
+ | For more detailed instructions on importing this application/ | ||
+ | |||
+ | ==== Debugging ==== | ||
+ | |||
+ | For more detailed instructions on importing this application/ | ||
+ | |||
+ | ===== Project structure ===== | ||
+ | |||
+ | The **ADuCM360_demo_cn0396** is a C project which uses ADuCM36x C/C++ Project structure. | ||
+ | |||
+ | This project contains: system initialization part - disabling watchdog, setting system clock, enabling clock for peripherals; | ||
+ | |||
+ | In the **src** and **include** folders you will find the source and header files related to CN0396 software | ||
+ | \\ | ||
+ | |||
+ | {{: | ||
+ | \\ | ||
+ | |||
+ | The **RTE** folder contains device and system related files: | ||
+ | * **Device Folder** – contains low levels drivers for ADuCM360 microcontroller.(try not to edit these files) | ||
+ | * **system.rteconfig** - Allows the user to select the peripherial components they need, along with the startup and ARM cmsis files needed for the project. | ||
+ | \\ | ||
\\ | \\ | ||
- | This project is a good example for how to use [[resources: | + | // End of Document // |