Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
measure.cpp@9:29db35656fcb, 2021-11-02 (annotated)
- Committer:
- nsheth
- Date:
- Tue Nov 02 10:14:25 2021 +0000
- Revision:
- 9:29db35656fcb
- Parent:
- 8:bd0b93e35392
- Child:
- 10:186e097fb1e3
Added platform drivers, documentation updated, short calibration completed
Who changed what in which revision?
| User | Revision | Line number | New contents of line | 
|---|---|---|---|
| nsheth | 5:746e78113d7d | 1 | /* Copyright (c) 2021 Analog Devices, Inc. All rights reserved. | 
| nsheth | 5:746e78113d7d | 2 | |
| nsheth | 5:746e78113d7d | 3 | Redistribution and use in source and binary forms, with or without modification, | 
| nsheth | 5:746e78113d7d | 4 | are permitted provided that the following conditions are met: | 
| nsheth | 5:746e78113d7d | 5 | - Redistributions of source code must retain the above copyright notice, | 
| nsheth | 5:746e78113d7d | 6 | this list of conditions and the following disclaimer. | 
| nsheth | 5:746e78113d7d | 7 | - Redistributions in binary form must reproduce the above copyright notice, | 
| nsheth | 5:746e78113d7d | 8 | this list of conditions and the following disclaimer in the documentation | 
| nsheth | 5:746e78113d7d | 9 | and/or other materials provided with the distribution. | 
| nsheth | 5:746e78113d7d | 10 | - Modified versions of the software must be conspicuously marked as such. | 
| nsheth | 5:746e78113d7d | 11 | - This software is licensed solely and exclusively for use with processors/products | 
| nsheth | 5:746e78113d7d | 12 | manufactured by or for Analog Devices, Inc. | 
| nsheth | 5:746e78113d7d | 13 | - This software may not be combined or merged with other code in any manner | 
| nsheth | 5:746e78113d7d | 14 | that would cause the software to become subject to terms and conditions which | 
| nsheth | 5:746e78113d7d | 15 | differ from those listed here. | 
| nsheth | 5:746e78113d7d | 16 | - Neither the name of Analog Devices, Inc. nor the names of its contributors | 
| nsheth | 5:746e78113d7d | 17 | may be used to endorse or promote products derived from this software without | 
| nsheth | 5:746e78113d7d | 18 | specific prior written permission. | 
| nsheth | 5:746e78113d7d | 19 | - The use of this software may or may not infringe the patent rights of one or | 
| nsheth | 5:746e78113d7d | 20 | more patent holders. This license does not release you from the requirement | 
| nsheth | 5:746e78113d7d | 21 | that you obtain separate licenses from these patent holders to use this software. | 
| nsheth | 5:746e78113d7d | 22 | |
| nsheth | 5:746e78113d7d | 23 | THIS SOFTWARE IS PROVIDED BY ANALOG DEVICES, INC. AND CONTRIBUTORS "AS IS" AND | 
| nsheth | 5:746e78113d7d | 24 | ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, NON-INFRINGEMENT, | 
| nsheth | 5:746e78113d7d | 25 | TITLE, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN | 
| nsheth | 5:746e78113d7d | 26 | NO EVENT SHALL ANALOG DEVICES, INC. OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, | 
| nsheth | 5:746e78113d7d | 27 | INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, PUNITIVE OR CONSEQUENTIAL DAMAGES | 
| nsheth | 5:746e78113d7d | 28 | (INCLUDING, BUT NOT LIMITED TO, DAMAGES ARISING OUT OF CLAIMS OF INTELLECTUAL | 
| nsheth | 5:746e78113d7d | 29 | PROPERTY RIGHTS INFRINGEMENT; PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS | 
| nsheth | 5:746e78113d7d | 30 | OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 
| nsheth | 5:746e78113d7d | 31 | THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | 
| nsheth | 5:746e78113d7d | 32 | NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, | 
| nsheth | 5:746e78113d7d | 33 | EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
| nsheth | 5:746e78113d7d | 34 | |
| nsheth | 5:746e78113d7d | 35 | 2021-01-10-7CBSD SLA | 
| nsheth | 5:746e78113d7d | 36 | */ | 
| nsheth | 5:746e78113d7d | 37 | |
| nsheth | 5:746e78113d7d | 38 | /*============= I N C L U D E S =============*/ | 
| nsheth | 5:746e78113d7d | 39 | #include "ADMX2001.h" | 
| nsheth | 5:746e78113d7d | 40 | #include "ADMX2001_commands.h" | 
| nsheth | 5:746e78113d7d | 41 | #include "message.h" | 
| nsheth | 5:746e78113d7d | 42 | #include "measure.h" | 
| nsheth | 5:746e78113d7d | 43 | #include <stdint.h> | 
| nsheth | 5:746e78113d7d | 44 | #include <stdio.h> | 
| nsheth | 5:746e78113d7d | 45 | #include <stdlib.h> | 
| nsheth | 5:746e78113d7d | 46 | |
| nsheth | 9:29db35656fcb | 47 | /*============= D A T A T Y P E S =============*/ | 
| nsheth | 9:29db35656fcb | 48 | |
| nsheth | 5:746e78113d7d | 49 | /** maximum length for buffer for string operation */ | 
| nsheth | 8:bd0b93e35392 | 50 | #define MAX_DISPLAY_LENGTH 256 | 
| nsheth | 5:746e78113d7d | 51 | /** maximum length for buffer for storing measurement values */ | 
| nsheth | 5:746e78113d7d | 52 | #define MAX_MEASUREMENT_BUFFER 512 | 
| nsheth | 9:29db35656fcb | 53 | |
| nsheth | 9:29db35656fcb | 54 | /*============= D A T A =============*/ | 
| nsheth | 9:29db35656fcb | 55 | |
| nsheth | 5:746e78113d7d | 56 | /** buffer for string operation */ | 
| nsheth | 5:746e78113d7d | 57 | char displayString[MAX_DISPLAY_LENGTH]; | 
| nsheth | 5:746e78113d7d | 58 | /** Array to store measurement values*/ | 
| nsheth | 5:746e78113d7d | 59 | double measurementBuffer[MAX_MEASUREMENT_BUFFER]; | 
| nsheth | 5:746e78113d7d | 60 | /** Array to store sweep points*/ | 
| nsheth | 5:746e78113d7d | 61 | double sweepPoints[MAX_MEASUREMENT_BUFFER]; | 
| nsheth | 5:746e78113d7d | 62 | |
| nsheth | 5:746e78113d7d | 63 | extern Admx200xDev admx200xDev; | 
| nsheth | 5:746e78113d7d | 64 | |
| nsheth | 8:bd0b93e35392 | 65 | static int32_t ReadAndDisplay(); | 
| nsheth | 5:746e78113d7d | 66 | |
| nsheth | 5:746e78113d7d | 67 | static void DisplayMeasuredValue(double displayVal1, double displayVal2, | 
| nsheth | 5:746e78113d7d | 68 | double sweepVar); | 
| nsheth | 5:746e78113d7d | 69 | |
| nsheth | 5:746e78113d7d | 70 | /** | 
| nsheth | 5:746e78113d7d | 71 | * @brief Dsiplays the output value | 
| nsheth | 5:746e78113d7d | 72 | * \ref DisplayMeasuredValue | 
| nsheth | 5:746e78113d7d | 73 | */ | 
| nsheth | 5:746e78113d7d | 74 | void DisplayMeasuredValue(double displayVal1, double displayVal2, | 
| nsheth | 5:746e78113d7d | 75 | double sweepVar) | 
| nsheth | 5:746e78113d7d | 76 | { | 
| nsheth | 5:746e78113d7d | 77 | snprintf(&displayString[0], MAX_DISPLAY_LENGTH, | 
| nsheth | 8:bd0b93e35392 | 78 | "Count = %d, Value = (%0.6e) + (%0.6e) j\n\r", | 
| nsheth | 8:bd0b93e35392 | 79 | (int32_t)sweepVar, displayVal1, displayVal2); | 
| nsheth | 5:746e78113d7d | 80 | printf("%s", &displayString[0]); | 
| nsheth | 5:746e78113d7d | 81 | } | 
| nsheth | 5:746e78113d7d | 82 | |
| nsheth | 5:746e78113d7d | 83 | /** | 
| nsheth | 5:746e78113d7d | 84 | * @brief Function to read and display measured values | 
| nsheth | 5:746e78113d7d | 85 | */ | 
| nsheth | 8:bd0b93e35392 | 86 | int32_t ReadAndDisplay() | 
| nsheth | 5:746e78113d7d | 87 | { | 
| nsheth | 5:746e78113d7d | 88 | int32_t i; | 
| nsheth | 5:746e78113d7d | 89 | int32_t status = ADMX_STATUS_SUCCESS; | 
| nsheth | 5:746e78113d7d | 90 | |
| nsheth | 5:746e78113d7d | 91 | Admx200xDev *pAdmx200x = &admx200xDev; | 
| nsheth | 5:746e78113d7d | 92 | uint8_t cmdId = 0; | 
| nsheth | 5:746e78113d7d | 93 | uint16_t addr = 0; | 
| nsheth | 5:746e78113d7d | 94 | uint32_t statReg; | 
| nsheth | 5:746e78113d7d | 95 | |
| nsheth | 5:746e78113d7d | 96 | int32_t numValues = | 
| nsheth | 5:746e78113d7d | 97 | sizeof(measurementBuffer) / sizeof(measurementBuffer[0]); | 
| nsheth | 5:746e78113d7d | 98 | |
| nsheth | 5:746e78113d7d | 99 | if (status == 0) | 
| nsheth | 5:746e78113d7d | 100 | { | 
| nsheth | 5:746e78113d7d | 101 | status = Admx200xReadFifo(pAdmx200x, &measurementBuffer[0], &numValues); | 
| nsheth | 5:746e78113d7d | 102 | } | 
| nsheth | 5:746e78113d7d | 103 | // Read sweep points | 
| nsheth | 5:746e78113d7d | 104 | if (status == 0) | 
| nsheth | 5:746e78113d7d | 105 | { | 
| nsheth | 5:746e78113d7d | 106 | cmdId = CMD_READ_SWEEP_POINTS; | 
| nsheth | 5:746e78113d7d | 107 | numValues /= 2; | 
| nsheth | 5:746e78113d7d | 108 | status = Admx200xSendCmd(pAdmx200x, &cmdId, &addr, | 
| nsheth | 5:746e78113d7d | 109 | (uint32_t *)&numValues, &statReg); | 
| nsheth | 5:746e78113d7d | 110 | } | 
| nsheth | 5:746e78113d7d | 111 | // Read sweep points | 
| nsheth | 5:746e78113d7d | 112 | if (status == 0) | 
| nsheth | 5:746e78113d7d | 113 | { | 
| nsheth | 5:746e78113d7d | 114 | status = Admx200xReadFifo(pAdmx200x, &sweepPoints[0], &numValues); | 
| nsheth | 5:746e78113d7d | 115 | } | 
| nsheth | 5:746e78113d7d | 116 | |
| nsheth | 5:746e78113d7d | 117 | if (status == 0) | 
| nsheth | 5:746e78113d7d | 118 | { | 
| nsheth | 5:746e78113d7d | 119 | for (i = 0; i < numValues; i++) | 
| nsheth | 5:746e78113d7d | 120 | { | 
| nsheth | 5:746e78113d7d | 121 | DisplayMeasuredValue(measurementBuffer[2 * i], | 
| nsheth | 5:746e78113d7d | 122 | measurementBuffer[2 * i + 1], sweepPoints[i]); | 
| nsheth | 5:746e78113d7d | 123 | } | 
| nsheth | 5:746e78113d7d | 124 | } | 
| nsheth | 5:746e78113d7d | 125 | |
| nsheth | 5:746e78113d7d | 126 | return status; | 
| nsheth | 5:746e78113d7d | 127 | } | 
| nsheth | 5:746e78113d7d | 128 | |
| nsheth | 8:bd0b93e35392 | 129 | |
| nsheth | 8:bd0b93e35392 | 130 | /** | 
| nsheth | 8:bd0b93e35392 | 131 | * Sets up, measures and displays Impedance | 
| nsheth | 8:bd0b93e35392 | 132 | */ | 
| nsheth | 8:bd0b93e35392 | 133 | int32_t MeasureAndDisplay() | 
| nsheth | 5:746e78113d7d | 134 | { | 
| nsheth | 5:746e78113d7d | 135 | int32_t status = 0; | 
| nsheth | 5:746e78113d7d | 136 | uint8_t cmdId; | 
| nsheth | 5:746e78113d7d | 137 | uint16_t addr; | 
| nsheth | 5:746e78113d7d | 138 | uint32_t data; | 
| nsheth | 5:746e78113d7d | 139 | uint32_t statReg; | 
| nsheth | 5:746e78113d7d | 140 | Admx200xDev *pAdmx200x = &admx200xDev; | 
| nsheth | 5:746e78113d7d | 141 | uint32_t measureStatus; | 
| nsheth | 5:746e78113d7d | 142 | addr = 0; | 
| nsheth | 5:746e78113d7d | 143 | data = 0; | 
| nsheth | 8:bd0b93e35392 | 144 | |
| nsheth | 8:bd0b93e35392 | 145 | cmdId = CMD_Z; | 
| nsheth | 8:bd0b93e35392 | 146 | status = | 
| nsheth | 8:bd0b93e35392 | 147 | Admx200xSendCmd(pAdmx200x, &cmdId, &addr, &data, &statReg); | 
| nsheth | 8:bd0b93e35392 | 148 | if (status == ADMX_STATUS_INVALID_CURRENT_GAIN || | 
| nsheth | 8:bd0b93e35392 | 149 | status == ADMX_STATUS_INVALID_DISPLAY_MODE || | 
| nsheth | 8:bd0b93e35392 | 150 | status == ADMX_STATUS_UNCOMMITED_CAL || | 
| nsheth | 8:bd0b93e35392 | 151 | status == ADMX_STATUS_SUCCESS) | 
| nsheth | 5:746e78113d7d | 152 | { | 
| nsheth | 8:bd0b93e35392 | 153 | status = Admx200xWaitForStatus( | 
| nsheth | 8:bd0b93e35392 | 154 | pAdmx200x, SPI_TIMEOUT, ADMX200X_STATUS_MEASURE_DONE_BITM, | 
| nsheth | 8:bd0b93e35392 | 155 | &measureStatus); | 
| nsheth | 5:746e78113d7d | 156 | } | 
| nsheth | 5:746e78113d7d | 157 | else | 
| nsheth | 5:746e78113d7d | 158 | { | 
| nsheth | 8:bd0b93e35392 | 159 | status = ADMX_STATUS_FAILED; | 
| nsheth | 8:bd0b93e35392 | 160 | } | 
| nsheth | 8:bd0b93e35392 | 161 | |
| nsheth | 8:bd0b93e35392 | 162 | if (status == ADMX_STATUS_INVALID_CURRENT_GAIN || | 
| nsheth | 8:bd0b93e35392 | 163 | status == ADMX_STATUS_INVALID_DISPLAY_MODE || | 
| nsheth | 8:bd0b93e35392 | 164 | status == ADMX_STATUS_UNCOMMITED_CAL || | 
| nsheth | 8:bd0b93e35392 | 165 | status == ADMX_STATUS_SUCCESS) | 
| nsheth | 8:bd0b93e35392 | 166 | { | 
| nsheth | 8:bd0b93e35392 | 167 | status = ReadAndDisplay(); | 
| nsheth | 8:bd0b93e35392 | 168 | } | 
| nsheth | 8:bd0b93e35392 | 169 | else | 
| nsheth | 8:bd0b93e35392 | 170 | { | 
| nsheth | 8:bd0b93e35392 | 171 | status = ADMX_STATUS_FAILED; | 
| nsheth | 8:bd0b93e35392 | 172 | } | 
| nsheth | 8:bd0b93e35392 | 173 | |
| nsheth | 8:bd0b93e35392 | 174 | if (status != ADMX_STATUS_SUCCESS) | 
| nsheth | 8:bd0b93e35392 | 175 | { | 
| nsheth | 8:bd0b93e35392 | 176 | status = ADMX_STATUS_FAILED; | 
| nsheth | 8:bd0b93e35392 | 177 | ERROR_MSG("Measurement failed"); | 
| nsheth | 5:746e78113d7d | 178 | // Clear the error | 
| nsheth | 5:746e78113d7d | 179 | Admx200xClearSPI(pAdmx200x); | 
| nsheth | 5:746e78113d7d | 180 | // Send abort command to bring state machine to IDLE if it got stuck | 
| nsheth | 5:746e78113d7d | 181 | cmdId = CMD_ABORT; | 
| nsheth | 5:746e78113d7d | 182 | Admx200xSendCmd(pAdmx200x, &cmdId, &addr, &data, &statReg); | 
| nsheth | 5:746e78113d7d | 183 | } | 
| nsheth | 5:746e78113d7d | 184 | |
| nsheth | 5:746e78113d7d | 185 | return status; | 
| nsheth | 5:746e78113d7d | 186 | } | 
| nsheth | 5:746e78113d7d | 187 | |
| nsheth | 5:746e78113d7d | 188 | |
| nsheth | 5:746e78113d7d | 189 | |
| nsheth | 8:bd0b93e35392 | 190 | 
