English | 简体中文 | 繁體中文 | 日本語 | Deutsch | 한국어
MAX30102は、統合されたパルスオキシメトリおよび心拍数モニターモジュールです。 これには、内部LED、光検出器、光学素子、および周囲光を除去する低ノイズの電子機器が含まれます。 MAX30102は、モバイルおよびウェアラブルデバイスの設計プロセスを容易にする完全なシステムソリューションを提供します。MAX30102は、単一の1.8V電源と内部LED用の個別の3.3V電源で動作します。 通信は、標準のI2C互換インターフェースを介して行われます。 モジュールは、スタンバイ電流がゼロのソフトウェアを介してシャットダウンできるため、電源レールに常に電力が供給されたままになります。ウェアラブルデバイス、フィットネスアシスタントデバイス、スマートフォン、タブレットなどで使用できます。
LibDriver MAX30102は、LibDriverによって起動されたMAX30102の全機能ドライバーです。 これは、FIFO読み取り、ID読み取り、およびその他の機能を提供します。 LibDriverはMISRAに準拠しています。
/ srcディレクトリには、LibDriver MAX30102のソースファイルが含まれています。
/ interfaceディレクトリには、LibDriver MAX30102用のプラットフォームに依存しないIICバステンプレートが含まれています。
/ testディレクトリには、チップの必要な機能を簡単にテストできるLibDriver MAX30102ドライバーテストプログラムが含まれています。
/ exampleディレクトリには、LibDriver MAX30102プログラミング例が含まれています。
/ docディレクトリには、LibDriver MAX30102オフラインドキュメントが含まれています。
/ datasheetディレクトリには、MAX30102データシートが含まれています。
/ projectディレクトリには、一般的に使用されるLinuxおよびマイクロコントローラー開発ボードのプロジェクトサンプルが含まれています。 すべてのプロジェクトは、デバッグ方法としてシェルスクリプトを使用しています。詳細については、各プロジェクトのREADME.mdを参照してください。
/ misraはLibDriver misraコードスキャン結果を含む。
/ interfaceディレクトリにあるプラットフォームに依存しないIICバステンプレートを参照して、指定したプラットフォームのIICバスドライバを完成させます。
/src ディレクトリ、プラットフォームのインターフェイス ドライバー、および独自のドライバーをプロジェクトに追加します。デフォルトのサンプル ドライバーを使用する場合は、/example ディレクトリをプロジェクトに追加します。
/example ディレクトリ内のサンプルを参照して、独自のドライバーを完成させることができます。 デフォルトのプログラミング例を使用したい場合の使用方法は次のとおりです。
#include "driver_max30102_fifo.h"
static uint8_t gs_flag;
static uint32_t gs_raw_red[32];
static uint32_t gs_raw_ir[32];
uint8_t res;
uint32_t timeout;
uint32_t times;
uint8_t (*g_gpio_irq)(void) = NULL;
...
void max30102_receive_callback(uint8_t type)
{
switch (type)
{
case MAX30102_INTERRUPT_STATUS_FIFO_FULL :
{
uint8_t res;
uint8_t len;
/* read data */
len = 32;
res = max30102_fifo_read((uint32_t *)gs_raw_red, (uint32_t *)gs_raw_ir, (uint8_t *)&len);
if (res != 0)
{
max30102_interface_debug_print("max30102: read failed.\n");
}
max30102_interface_debug_print("max30102: irq fifo full with %d.\n", len);
gs_flag = 1;
break;
}
case MAX30102_INTERRUPT_STATUS_PPG_RDY :
{
max30102_interface_debug_print("max30102: irq ppg rdy.\n");
break;
}
case MAX30102_INTERRUPT_STATUS_ALC_OVF :
{
max30102_interface_debug_print("max30102: irq alc ovf.\n");
break;
}
case MAX30102_INTERRUPT_STATUS_PWR_RDY :
{
max30102_interface_debug_print("max30102: irq pwr rdy.\n");
break;
}
case MAX30102_INTERRUPT_STATUS_DIE_TEMP_RDY :
{
max30102_interface_debug_print("max30102: irq die temp rdy.\n");
break;
}
default :
{
max30102_interface_debug_print("max30102: unknown code.\n");
break;
}
}
}
...
/* set gpio */
g_gpio_irq = max30102_fifo_irq_handler;
res = gpio_interrupt_init();
if (res != 0)
{
g_gpio_irq = NULL;
return 1;
}
/* fifo init */
res = max30102_fifo_init(max30102_receive_callback);
if (res != 0)
{
(void)gpio_interrupt_deinit();
g_gpio_irq = NULL;
return 1;
}
/* read data */
times = 3;
gs_flag = 0;
timeout = 5000;
while (timeout != 0)
{
if (gs_flag != 0)
{
/* clear config */
gs_flag = 0;
timeout = 5000;
times--;
if (times == 0)
{
break;
}
}
max30102_interface_delay_ms(1);
timeout--;
}
/* check timeout */
if (timeout == 0)
{
max30102_interface_debug_print("max30102: read timeout failed.\n");
(void)max30102_fifo_deinit();
(void)gpio_interrupt_deinit();
g_gpio_irq = NULL;
return 1;
}
(void)max30102_fifo_deinit();
(void)gpio_interrupt_deinit();
g_gpio_irq = NULL;
return 0;
オンラインドキュメント: https://www.libdriver.com/docs/max30102/index.html。
オフラインドキュメント: /doc/html/index.html。
CONTRIBUTING.mdを参照してください。
著作権(c)2015-今 LibDriver 全著作権所有
MITライセンス(MIT)
このソフトウェアおよび関連するドキュメントファイル(「ソフトウェア」)のコピーを取得した人は、無制限の使用、複製、変更、組み込み、公開、配布、サブライセンスを含む、ソフトウェアを処分する権利を制限なく付与されます。ソフトウェアのライセンスおよび/またはコピーの販売、および上記のようにソフトウェアが配布された人の権利のサブライセンスは、次の条件に従うものとします。
上記の著作権表示およびこの許可通知は、このソフトウェアのすべてのコピーまたは実体に含まれるものとします。
このソフトウェアは「現状有姿」で提供され、商品性、特定目的への適合性、および非侵害の保証を含むがこれらに限定されない、明示または黙示を問わず、いかなる種類の保証もありません。 いかなる場合も、作者または著作権所有者は、契約、不法行為、またはその他の方法で、本ソフトウェアおよび本ソフトウェアの使用またはその他の廃棄に起因または関連して、請求、損害、またはその他の責任を負わないものとします。
お問い合わせくださいlishifenging@outlook.com。