O Google tem o compromisso de promover a igualdade racial para as comunidades negras. Saiba como.

Monitoramento do canal

Este módulo inclui funções para o recurso de monitoramento de canal.

Resumo

As funções deste módulo estão disponíveis quando o recurso de monitoramento do canal (OPENTHREAD_CONFIG_CHANNEL_MONITOR_ENABLE) está ativado.

O monitoramento frequente de canais ajuda a determinar os canais mais limpos (canais com menos interferência).

Quando o monitoramento de canais está ativo, uma busca de energia com duração zero é realizada, coletando uma única amostra RSSI em cada canal por intervalo de amostra. As amostras de RSSI são comparadas com um limite RSSI pré-especificado. Como um indicador de qualidade do canal, o módulo de monitoramento de canal mantém e fornece a taxa/porcentagem média de amostras de RSSI que estão acima do limite (aproximadamente) em uma janela de amostra especificada (chamada de ocupação de canal).

Functions

otChannelMonitorGetChannelOccupancy(otInstance *aInstance, uint8_t aChannel)
uint16_t
Recebe a ocupação atual de um determinado canal.
otChannelMonitorGetRssiThreshold(otInstance *aInstance)
int8_t
Receba o limite RSSI de monitoramento do canal em dBm.
otChannelMonitorGetSampleCount(otInstance *aInstance)
uint32_t
Recebe o monitoramento total do canal de amostras de RSSI (por canal).
otChannelMonitorGetSampleInterval(otInstance *aInstance)
uint32_t
Receber intervalo de amostra de monitoramento de canal em milissegundos.
otChannelMonitorGetSampleWindow(otInstance *aInstance)
uint32_t
Calcula a média dos tamanhos das janelas de amostras (número de amostras) para monitoramento de canais.
otChannelMonitorIsEnabled(otInstance *aInstance)
bool
Essa função indica se a operação de monitoramento do canal está ativada e em execução.
otChannelMonitorSetEnabled(otInstance *aInstance, bool aEnabled)
Essa função ativa/desativa a operação de monitoramento do canal.

Functions

OtChannelMonitorGetChannelOccupancy

uint16_t otChannelMonitorGetChannelOccupancy(
  otInstance *aInstance,
  uint8_t aChannel
)

Recebe a ocupação atual de um determinado canal.

O valor de ocupação do canal representa a taxa/porcentagem média de amostras de RSSI que estavam acima do limite de RSSI (amostras de RSSI "quoquo;bad").

Para as primeiras amostras de "exemplo</quo>, a média é mantida como a porcentagem real (isto é, a proporção do número de amostras "bad" pelo número total de amostras). Após as amostras de "janela" a média usa uma média móvel exponencialmente ponderada. Na prática, isso significa que a média representa até 3 * window últimas amostras com a ponderação mais alta atribuída às kSampleWindow amostras mais recentes.

O valor máximo de 0xffff indica que todas as amostras de RSSI estavam acima do limite de RSSI (ou seja, 100% das amostras estavam "bad").

Detalhes
Parâmetros
[in] aInstance
Um ponteiro para uma instância do OpenThread.
[in] aChannel
Canal em que o link será ocupado.
Retorna
A ocupação atual do canal especificado.

OtChannelMonitorGetRssiThreshold

int8_t otChannelMonitorGetRssiThreshold(
  otInstance *aInstance
)

Receba o limite RSSI de monitoramento do canal em dBm.

Detalhes
Parâmetros
[in] aInstance
Um ponteiro para uma instância do OpenThread.
Retorna
O limite de RSSI em dBm.

OtChannelMonitorGetSampleCount

uint32_t otChannelMonitorGetSampleCount(
  otInstance *aInstance
)

Recebe o monitoramento total do canal de amostras de RSSI (por canal).

A contagem indica o número total de amostras por canal por módulo de monitoramento de canal desde o início (já que a interface da rede Thread foi ativada).

Detalhes
Parâmetros
[in] aInstance
Um ponteiro para uma instância do OpenThread.
Retorna
Número total de amostras de RSSI (por canal) coletadas até o momento.

OtChannelMonitorGetSampleInterval

uint32_t otChannelMonitorGetSampleInterval(
  otInstance *aInstance
)

Receber intervalo de amostra de monitoramento de canal em milissegundos.

Detalhes
Parâmetros
[in] aInstance
Um ponteiro para uma instância do OpenThread.
Retorna
O intervalo de exemplo do monitoramento de canal em milissegundos.

OtChannelMonitorGetSampleWindow

uint32_t otChannelMonitorGetSampleWindow(
  otInstance *aInstance
)

Calcula a média dos tamanhos das janelas de amostras (número de amostras) para monitoramento de canais.

Detalhes
Parâmetros
[in] aInstance
Um ponteiro para uma instância do OpenThread.
Retorna
A janela de amostra média.

OtChannelMonitorIsEnabled

bool otChannelMonitorIsEnabled(
  otInstance *aInstance
)

Essa função indica se a operação de monitoramento do canal está ativada e em execução.

Detalhes
Parâmetros
[in] aInstance
Um ponteiro para uma instância do OpenThread.
Retorna
TRUE se a operação de monitoramento do canal estiver ativada. Caso contrário, será FALSE.

OtChannelMonitorSetEnabled

otError otChannelMonitorSetEnabled(
  otInstance *aInstance,
  bool aEnabled
)

Essa função ativa/desativa a operação de monitoramento do canal.

Quando a operação é iniciada, todos os dados coletados anteriormente são apagados. No entanto, após a desativação da operação, os dados coletados anteriormente continuam válidos e podem ser lidos.

Detalhes
Parâmetros
[in] aInstance
Um ponteiro para uma instância do OpenThread.
[in] aEnabled
VERDADEIRO para ativar/iniciar a operação de monitoramento do canal; FALSO para desativá-la/interrompê-la.
Valores de retorno
OT_ERROR_NONE
O estado do monitoramento do canal foi alterado
OT_ERROR_ALREADY
O monitoramento de canais já está no mesmo estado.

Recursos

Os tópicos de referência da API OpenThread são originados do código-fonte, disponível no GitHub. Para saber mais ou contribuir com nossa documentação, consulte Recursos.