El proyecto presentado consiste en la programación de un potenciostato a partir de la EVB Nucleo-F401R de STMicroelectroncs. La finalidad de este es la caracterización de la concentración de varias disoluciones de ferricianuro de potasio en un tampón de cloruro de potasio por medio del potenciostato. Para ello, se han programado dos medidas: una cronoamperometría (CA) y una voltametría cíclica (CV).
Primeramente, se introducen los parámetros deseados así como el tipo de medida (CA/CV) en el software viSense, programado especialmente para el proyecto. El sensor combinado con la EVB toman las medidas y estas son enviadas al ordenador, que las muestra en forma de datos o gráfica en el software viSense.
Un potenciostato es un dispositivo que mide y amplifica una señal proveniente de una reacción electroquímica, permitiendo medir las concentraciones de un analito.
Un potenciostato cualquiera puede medir en modo amperométrico, donde se fija el potencial y se mira la corriente de salida, o potenciométrico, donde se fija la corriente y se mira el voltaje. En este proyecto estamos trabajando en modo amperométrico, fijando el voltaje de la celda (Vcell) y midiendo la corriente (Icell).
Las configuraciones típicas para sensores amperométricos, que miden la corriente que sale de una reacción electroquímica, consisten en un enfoque de dos electrodos, donde hay un electrodo de trabajo en que tiene lugar la reacción y un electrodo de referencia, que rastrea el potencial resultante de la reacción y proporciona la corriente requerida. Sin embargo, este enfoque presenta un problema que se basa en la acumulación de cargas en el electrodo de referencia, que debe tener un potencial bien conocido. Para solucionar este problema, se define la configuración de tres electrodos:
A continuación, se explica en qué consisten las dos medidas programadas en este proyecto.
Una voltammetría cíclica es un tipo de medición electroquímica potenciodinámica en la que se aplica un potencial variable a una celda electroquímica mientras se mide la corriente que esta celda proporciona. El potencial entre el electrodo de trabajo (WE) y el de referencia (RE) de la celda varía con el tiempo hasta que alcanza un valor potencial establecido, luego cambia de dirección, realizando lo que se denomina barrido triangular de potencial. Este proceso se repite durante un número establecido de ciclos. El resultado se representa en un voltamograma cíclico, que representa la corriente a través de la celda frente al voltaje aplicado en esta. La CV es una técnica ampliamente utilizada para estudiar las propiedades electroquímicas de un analito en una solución. Una CV proporciona gran cantidad de información sobre el comportamiento químico y físico de un sistema. Además, se pueden observar diferentes fenómenos físicos realizando voltametrías a diferentes velocidades de exploración (modificando la velocidad de cambio de voltaje con el tiempo).
Una cronoamperometría es una técnica electroquímica que transduce la actividad de las especies biomoleculares de una celda electroquímica en una señal de corriente que cuantifica la concentración del analito de interés. En esta técnica se aplica una señal escalón y se mide la corriente a través de la celda en función del tiempo. Una de las ventajas de esta técnica es que no requiere etiquetado de analito o biorreceptor. El experimento comienza manteniendo la celda a un potencial en el que no ocurre ningún proceso faradaico. Entonces, el potencial se eleva a un valor en el cual ocurre una reacción redox.
En esta sección se presentan una serie de diagramas de flujo que ejemplifican el código programado en STM32CubeIDE para implementar el potenciostato portable.
El usuario deberá abrir la aplicación de escritorio viSens-S y seguidamente conectar con el dispositivo. Entonces seleccionará la técnica electroquímica que quiera realizar, CV o CA, y configurará los respectivos parámetros.
Parámetros CA:
eDC
(double): potencial constante de la celda electroquímica durante la CA en voltios.samplingPeriodMs
(uint32_t): tiempo en ms entre cada punto tomado.measurementTime
(uint32_t): duración (en segundos) de la CA.Parámetros CV:
eBegin
(double): potencial de celda en el que se inicia la voltametría cíclica. El potencial de la celda electroquímica se lleva del potencial de inicio al vértice de potencial 1. También indica el potencial en el que finalizará la voltametría cíclica.eVertex1
(double): nuevo potencial al que se dirige la celda una vez fijado el potencial de inicio. Una vez alcanzado el primer vértice, la celda se dirige al vértice 2.eVertex2
(double): potencial hacia el que va la celda des del vértice de potencial 1. Cuando se llega a este potencial, si quedan más ciclos, el potencial vuelve al vértice 1. En caso contrario el potencial va hacia el de inicio y termina la medición.cycles
(uint8_t): número de ciclos de la voltametría cíclica.scanRate
(double): variación de la tensión de la celda electroquímica en el tiempo (V/s).eStep
(double): incremento o decremento de la tensión de la celda (V).Una vez configurados los parámetros iniciará la medición. El dispositivo recibirá los parámetros configurados y empezará a tomar puntos, los cuales irá enviando al usuario hasta que termine la medición. Si se quiere iniciar una nueva medida se debe reiniciar el proceso, empezando por seleccionar la técnica correspondiente. En caso contrario, se cierra la aplicación.
En cuanto se inicia el microcontrolador, este inicia sus periféricos y variables. Entre los periféricos configurados se encuentran:
Con esto hecho, el micro espera una instrucción y, en cuanto recibe una, comprueba con un switch si el comando recibido es de CV o CA. Por defecto, en caso de no conocer el comando, esperará otra instrucción. Si se reciben CA o CV, se guardará la configuración recibida correspondiente y cambiará el estado de la variable "ESTADO" a CA o CV, respectivamente. Seguidamente, pasa a esperar una nueva instrucción mediante una función no bloqueante, de forma que el código sigue corriendo.
Lo siguiente que hace el microcontrolador es mirar el valor de la variable "ESTADO" mediante un switch, tanto si es CA o CV, el microcontrolador tomará una medición y enviará ese punto al host. En caso de que esa medición sea la última, la variable "ESTADO" cambia a IDLE y se mira si hay nuevas instrucciones.
En caso de no haber nuevas instrucciones, vuelve a comprobarse la variable ESTADO.
El flujo de ejecución de la cronoamperometría consiste en fijar la tensión de la celda electroquímica a un valor constante (el valor eDC configurado por el usuario) e ir midiendo la intensidad de la celda.
Para ello, después de fijar el potencial, se cierra el relé. O lo que es lo mismo, se cierra el circuito entre el sensor electroquímico y el front-end. Entonces, envía la primera medida de I y V al host y espera a que transcurra el sampling period. Cuando haya pasado ese tiempo, hace una segunda medida y manda los datos al host. Entonces el contador que lleva la cuenta del measurement time incrementa, y, si se sobrepasa el measurement time, se abre el relé y acaba la medida. En caso que el measurement time no se haya sobrepasado, se vuelve a comprobar si ha pasado el sampling period.
El flujo operativo de la voltametría cíclica empieza por fijar la tensión de la celda (Vcell) a un valor de voltaje inicial (eBegin). Entonces se establece como voltaje objetivo el primer vértice configurado y se cierra el relé.
Mientras no se trate del último ciclo de la CV, se comprobará si ha pasado el sampling period. En caso negativo, vuelve a comprobar que no sea el último ciclo. En caso de que ya haya pasado, se comprueba si el voltaje objetivo es menor al de Vcell. De ser así, establece un valor de step negativo o, en caso contrario, un valor de step positivo. Entonces mira si el step sumado a Vcell sobrepasa el voltaje objetivo. Si lo sobrepasa, Vcell se establece a vObjetivo y, si no, se le añade el step. Entonces se mandan los datos al host y se establece la tensión de la celda a Vcell.
Si vObjetivo es igual a Vcell, se mira si vObjetivo era el vértice 1, el 2 o el voltaje inicial (eBegin). Si era el vértice 1, se establece como vObjetivo el vértice 2, si era el vértice 2, se establece como objetivo eBegin, y si era eBegin se establece el vértice 1 y se aumenta el contador de ciclos realizados.
Finalmente, vuelve a mirar si es el último ciclo y en caso positivo se abre el relé y termina la medida.
Teniendo en cuenta los objetivos mencionados, el trabajo se ha repartido equitativamente entre los dos miembros que han desarrollado el proyecto.
Tanto la *cronoamperometría como la voltametría, en este orden, se han programado de forma conjunta en reuniones presenciales. Después, las demás tareas se han repartido de la siguiente forma:
.ioc
y ha generado el código. También ha generado las funciones setup()
y loop
y las ha incluido en el archivo main.c
, modificándolo. Finalmente, se ha encargado de la gestión de los timers.El repositorio Git en que se ha desarrollado el proyecto seguía la siguiente estructura de ramas:
.ioc
y main.c
. Una vez funcionando correctamente, sus contenidos se vierten en la rama master
con un Pull request
definitivo..h
como el .c
referentes a la CA se han desarrollado desde esta rama. Una vez listos, la rama se ha volcado a la develop
mediante un Pull request
..h
como el .c
referentes a la CV se han desarrollado desde esta rama. Una vez listos, la rama se ha volcado a la rama develop
mediante un Pull request
. Esta rama lleva el nombre /CV2
debido a que una rama anteriormente creada llamada feature/CV
ha quedado inutilizada.setup()
y loop()
desarrolladas en los archivos stm32main.c
y stm32main.h
. Una vez listos, el contenido de la rama se ha vertido a la rama develop
mediante un Pull request
.REPORT_ES
y REPORT_EN
, que contienen los reports en castellano e inglés, respectivamente, del proyecto realizado. Una vez terminados, se han volcado a la rama develop
mediante un Pull request
.La parte más complicada del proyecto han sido los siguientes dos aspectos:
La interferencia entre variables de mismo nombre en CA y CV, y la implementación de eVertex en diferentes posiciones (ambas positivas, negativas y una de cada una).
Hemos encontrado algunos problemas como, por ejemplo, las primeras solicitudes de extracción realizadas a la rama de desarrollo se hicieron al master porque no prestamos suficiente atención a la etiqueta de referencia. Este problema se solucionó y el control de versiones se ha utilizado correctamente desde entonces.
La primera parte de los resultados son los resultados de la simulación generados con un circuito de diodos de resistencia y los resultados se presentan a continuación.
En la CA se puede apreciar un pico de corriente al inicio de la reacción y disminuye a partir que el analito se reduce hasta llegar a corriente 0 A. Los parámetros introducidos en el programa son los siguientes:
En los resultados del CV (1 mM), el gráfico presenta los ciclos uno al lado de los otros y no supuestos como debería ser. Los parámetros introducidos en el programa son los siguientes:
La asignatura de Microcotroladores para Sistemas Biomédicos nos ha dado las herramientas para programar en C/C++ programas que nos permitan solucionar problemas biomédicos. El desarrollo de la faceta back-end de un potenciostato que hace cronoamperometrias y voltometrías cíclicas tiene la finalidad de caracterizar electroquímicamente soluciones de ferrocianuro de potasio. Este proyecto nos ha permitido desarrollar capacidades de auto-aprendizage en programación, así como de gestión de proyectos de programación de manera profesional en una plataforma HAL.