2019-04-08 13:17:46 +08:00
|
|
|
#include "core_include/api.h"
|
|
|
|
#include "../widgets_include/wave_buffer.h"
|
2017-12-06 21:43:47 +08:00
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#define MAX(a,b) (((a)>(b))?(a):(b))
|
|
|
|
#define MIN(a,b) (((a)<(b))?(a):(b))
|
|
|
|
|
|
|
|
c_wave_buffer::c_wave_buffer()
|
|
|
|
{
|
|
|
|
m_head = m_tail = m_min_old = m_max_old =
|
2019-01-17 14:39:18 +08:00
|
|
|
m_min_older = m_max_older = m_last_data = m_read_cache_sum = m_refresh_sequence = 0;
|
2017-12-06 21:43:47 +08:00
|
|
|
memset(m_wave_buf, 0, sizeof(m_wave_buf));
|
2019-01-17 14:39:18 +08:00
|
|
|
memset(m_read_cache_min, 0, sizeof(m_read_cache_min));
|
|
|
|
memset(m_read_cache_mid, 0, sizeof(m_read_cache_mid));
|
|
|
|
memset(m_read_cache_max, 0, sizeof(m_read_cache_max));
|
2017-12-06 21:43:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
short c_wave_buffer::get_cnt()
|
|
|
|
{
|
|
|
|
return (m_tail >= m_head)?(m_tail - m_head):(m_tail - m_head + WAVE_BUFFER_LEN);
|
|
|
|
}
|
|
|
|
|
|
|
|
int c_wave_buffer::write_wave_data(short data)
|
|
|
|
{
|
|
|
|
if ((m_tail + 1) % WAVE_BUFFER_LEN == m_head)
|
|
|
|
{//full
|
2019-01-21 15:27:11 +08:00
|
|
|
//log_out("wave buf full\n");
|
2017-12-06 21:43:47 +08:00
|
|
|
return BUFFER_FULL;
|
|
|
|
}
|
|
|
|
m_wave_buf[m_tail] = data;
|
|
|
|
m_tail = (m_tail + 1) % WAVE_BUFFER_LEN;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int c_wave_buffer::read_data()
|
|
|
|
{
|
|
|
|
if (m_head == m_tail)
|
|
|
|
{//empty
|
2019-01-21 15:27:11 +08:00
|
|
|
//log_out("wave buf empty\n");
|
2017-12-06 21:43:47 +08:00
|
|
|
return BUFFER_EMPTY;
|
|
|
|
}
|
|
|
|
int ret = m_wave_buf[m_head];
|
|
|
|
m_head = (m_head + 1) % WAVE_BUFFER_LEN;
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2019-01-17 14:39:18 +08:00
|
|
|
int c_wave_buffer::read_wave_data_by_frame(short &max, short &min, short frame_len, unsigned int sequence, short offset)
|
2017-12-06 21:43:47 +08:00
|
|
|
{
|
2019-01-17 14:39:18 +08:00
|
|
|
if (m_refresh_sequence != sequence)
|
2017-12-06 21:43:47 +08:00
|
|
|
{
|
2019-01-17 14:39:18 +08:00
|
|
|
m_refresh_sequence = sequence;
|
|
|
|
m_read_cache_sum = 0;
|
2017-12-06 21:43:47 +08:00
|
|
|
}
|
2019-01-17 14:39:18 +08:00
|
|
|
else if(offset < m_read_cache_sum)//(m_refresh_sequence == sequence && offset < m_fb_sum)
|
2017-12-06 21:43:47 +08:00
|
|
|
{
|
2019-01-17 14:39:18 +08:00
|
|
|
max = m_read_cache_max[offset];
|
|
|
|
min = m_read_cache_min[offset];
|
|
|
|
return m_read_cache_mid[offset];
|
2017-12-06 21:43:47 +08:00
|
|
|
}
|
2019-01-17 14:39:18 +08:00
|
|
|
|
|
|
|
m_read_cache_sum++;
|
|
|
|
ASSERT(m_read_cache_sum <= WAVE_READ_CACHE_LEN);
|
2017-12-06 21:43:47 +08:00
|
|
|
int i, data;
|
|
|
|
int tmp_min = m_last_data;
|
|
|
|
int tmp_max = m_last_data;
|
|
|
|
int mid = (m_min_old + m_max_old)>>1;
|
|
|
|
|
|
|
|
i = 0;
|
2019-01-17 14:39:18 +08:00
|
|
|
while(i++ < frame_len)
|
2017-12-06 21:43:47 +08:00
|
|
|
{
|
|
|
|
data = read_data();
|
|
|
|
if(BUFFER_EMPTY == data)
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
m_last_data = data;
|
|
|
|
|
|
|
|
if(data < tmp_min){tmp_min = data;}
|
|
|
|
if(data > tmp_max){tmp_max = data;}
|
|
|
|
}
|
|
|
|
|
2019-01-17 14:39:18 +08:00
|
|
|
min = m_read_cache_min[offset] = MIN(m_min_old, MIN(tmp_min, m_min_older));
|
|
|
|
max = m_read_cache_max[offset] = MAX(m_max_old, MAX(tmp_max, m_max_older));
|
2017-12-06 21:43:47 +08:00
|
|
|
|
|
|
|
m_min_older = m_min_old;
|
|
|
|
m_max_older = m_max_old;
|
|
|
|
m_min_old = tmp_min;
|
|
|
|
m_max_old = tmp_max;
|
2019-01-17 14:39:18 +08:00
|
|
|
return (m_read_cache_mid[offset] = mid);
|
2017-12-06 21:43:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void c_wave_buffer::clear_data()
|
|
|
|
{
|
|
|
|
m_head = m_tail = 0;
|
|
|
|
memset(m_wave_buf, 0, sizeof(m_wave_buf));
|
|
|
|
}
|
|
|
|
|
|
|
|
void c_wave_buffer::reset()
|
|
|
|
{
|
|
|
|
m_head = m_tail;
|
|
|
|
}
|