kopia lustrzana https://github.com/xdsopl/robot36
replaced some float timing code with int
rodzic
acde6a9a70
commit
6195ab5fb2
55
decode.c
55
decode.c
|
@ -160,15 +160,23 @@ int decode(int *reset, struct img **img, char *img_name, float cnt_freq, float d
|
||||||
{
|
{
|
||||||
const int width = 320;
|
const int width = 320;
|
||||||
const int height = 240;
|
const int height = 240;
|
||||||
const float sync_porch_len = 0.003;
|
const double sync_porch_sec = 0.003l;
|
||||||
const float porch_len = 0.0015;
|
const double porch_sec = 0.0015l;
|
||||||
const float y_len = 0.088;
|
const double y_sec = 0.088l;
|
||||||
const float uv_len = 0.044;
|
const double uv_sec = 0.044l;
|
||||||
const float hor_len = 0.15;
|
const double hor_sec = 0.15l;
|
||||||
const float hor_sync_len = 0.009;
|
const double hor_sync_sec = 0.009l;
|
||||||
const float seperator_len = 0.0045;
|
const double seperator_sec = 0.0045l;
|
||||||
const float sync_tolerance = 0.7;
|
const float sync_tolerance = 0.7;
|
||||||
|
|
||||||
|
static int sync_porch_drate_ticks = 0;
|
||||||
|
static int porch_drate_ticks = 0;
|
||||||
|
static int y_drate_ticks = 0;
|
||||||
|
static int uv_drate_ticks = 0;
|
||||||
|
static int hor_drate_ticks = 0;
|
||||||
|
static int hor_sync_drate_ticks = 0;
|
||||||
|
static int seperator_drate_ticks = 0;
|
||||||
|
|
||||||
static int hor_ticks = 0;
|
static int hor_ticks = 0;
|
||||||
static int latch_sync = 0;
|
static int latch_sync = 0;
|
||||||
|
|
||||||
|
@ -179,8 +187,16 @@ int decode(int *reset, struct img **img, char *img_name, float cnt_freq, float d
|
||||||
|
|
||||||
static int init = 0;
|
static int init = 0;
|
||||||
if (!init) {
|
if (!init) {
|
||||||
y_width = drate * y_len;
|
sync_porch_drate_ticks = sync_porch_sec * drate;
|
||||||
uv_width = drate * uv_len;
|
porch_drate_ticks = porch_sec * drate;
|
||||||
|
y_drate_ticks = y_sec * drate;
|
||||||
|
uv_drate_ticks = uv_sec * drate;
|
||||||
|
hor_drate_ticks = hor_sec * drate;
|
||||||
|
hor_sync_drate_ticks = hor_sync_sec * drate;
|
||||||
|
seperator_drate_ticks = seperator_sec * drate;
|
||||||
|
|
||||||
|
y_width = y_drate_ticks;
|
||||||
|
uv_width = uv_drate_ticks;
|
||||||
y_pixel = malloc(y_width * 2);
|
y_pixel = malloc(y_width * 2);
|
||||||
memset(y_pixel, 0, y_width * 2);
|
memset(y_pixel, 0, y_width * 2);
|
||||||
uv_pixel = malloc(uv_width * 2);
|
uv_pixel = malloc(uv_width * 2);
|
||||||
|
@ -191,7 +207,7 @@ int decode(int *reset, struct img **img, char *img_name, float cnt_freq, float d
|
||||||
hor_ticks = fabsf(cnt_freq - 1200.0) < 50.0 ? hor_ticks + 1 : 0;
|
hor_ticks = fabsf(cnt_freq - 1200.0) < 50.0 ? hor_ticks + 1 : 0;
|
||||||
|
|
||||||
// we want a pulse at the falling edge
|
// we want a pulse at the falling edge
|
||||||
latch_sync = hor_ticks > (int)(drate * sync_tolerance * hor_sync_len) ? 1 : latch_sync;
|
latch_sync = hor_ticks > (int)(sync_tolerance * hor_sync_drate_ticks) ? 1 : latch_sync;
|
||||||
int hor_sync = (cnt_freq > 1299.0) && latch_sync;
|
int hor_sync = (cnt_freq > 1299.0) && latch_sync;
|
||||||
latch_sync = hor_sync ? 0 : latch_sync;
|
latch_sync = hor_sync ? 0 : latch_sync;
|
||||||
|
|
||||||
|
@ -228,15 +244,15 @@ int decode(int *reset, struct img **img, char *img_name, float cnt_freq, float d
|
||||||
}
|
}
|
||||||
|
|
||||||
// if horizontal sync is too early, we reset to the beginning instead of ignoring
|
// if horizontal sync is too early, we reset to the beginning instead of ignoring
|
||||||
if (hor_sync && ticks < (int)((hor_len - sync_porch_len) * drate)) {
|
if (hor_sync && (ticks < (hor_drate_ticks - sync_porch_drate_ticks))) {
|
||||||
ticks = 0;
|
ticks = 0;
|
||||||
y_pixel_x = 0;
|
y_pixel_x = 0;
|
||||||
uv_pixel_x = 0;
|
uv_pixel_x = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// we always sync if sync pulse is where it should be.
|
// we always sync if sync pulse is where it should be.
|
||||||
if (hor_sync && (ticks >= (int)((hor_len - sync_porch_len) * drate) &&
|
if (hor_sync && (ticks >= (hor_drate_ticks - sync_porch_drate_ticks)) &&
|
||||||
ticks < (int)((hor_len + sync_porch_len) * drate))) {
|
(ticks < (hor_drate_ticks + sync_porch_drate_ticks))) {
|
||||||
process_line((*img)->pixel, y_pixel, uv_pixel, y_width, uv_width, width, height, y++);
|
process_line((*img)->pixel, y_pixel, uv_pixel, y_width, uv_width, width, height, y++);
|
||||||
if (y == height) {
|
if (y == height) {
|
||||||
close_img(*img);
|
close_img(*img);
|
||||||
|
@ -250,7 +266,7 @@ int decode(int *reset, struct img **img, char *img_name, float cnt_freq, float d
|
||||||
}
|
}
|
||||||
|
|
||||||
// if horizontal sync is missing, we extrapolate from last sync
|
// if horizontal sync is missing, we extrapolate from last sync
|
||||||
if (ticks >= (int)((hor_len + sync_porch_len) * drate)) {
|
if (ticks >= (hor_drate_ticks + sync_porch_drate_ticks)) {
|
||||||
process_line((*img)->pixel, y_pixel, uv_pixel, y_width, uv_width, width, height, y++);
|
process_line((*img)->pixel, y_pixel, uv_pixel, y_width, uv_width, width, height, y++);
|
||||||
if (y == height) {
|
if (y == height) {
|
||||||
close_img(*img);
|
close_img(*img);
|
||||||
|
@ -258,24 +274,25 @@ int decode(int *reset, struct img **img, char *img_name, float cnt_freq, float d
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
odd ^= 1;
|
odd ^= 1;
|
||||||
ticks -= (int)(hor_len * drate);
|
ticks -= hor_drate_ticks;
|
||||||
// we are not at the pixels yet, so no correction here
|
// we are not at the pixels yet, so no correction here
|
||||||
y_pixel_x = 0;
|
y_pixel_x = 0;
|
||||||
uv_pixel_x = 0;
|
uv_pixel_x = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sep_count = 0;
|
static int sep_count = 0;
|
||||||
if (ticks > (int)((sync_porch_len + y_len) * drate) && ticks < (int)((sync_porch_len + y_len + seperator_len) * drate))
|
if ((ticks > (sync_porch_drate_ticks + y_drate_ticks)) &&
|
||||||
|
(ticks < (sync_porch_drate_ticks + y_drate_ticks + seperator_drate_ticks)))
|
||||||
sep_count += dat_freq < 1900.0 ? 1 : -1;
|
sep_count += dat_freq < 1900.0 ? 1 : -1;
|
||||||
// we try to correct from odd / even seperator
|
// we try to correct from odd / even seperator
|
||||||
if (sep_count && ticks > (int)((sync_porch_len + y_len + seperator_len) * drate)) {
|
if (sep_count && (ticks > (sync_porch_drate_ticks + y_drate_ticks + seperator_drate_ticks))) {
|
||||||
odd = sep_count < 0;
|
odd = sep_count < 0;
|
||||||
sep_count = 0;
|
sep_count = 0;
|
||||||
}
|
}
|
||||||
if (y_pixel_x < y_width && ticks >= (int)(sync_porch_len * drate))
|
if ((y_pixel_x < y_width) && (ticks >= sync_porch_drate_ticks))
|
||||||
y_pixel[y_pixel_x++ + (y % 2) * y_width] = fclampf(255.0 * (dat_freq - 1500.0) / 800.0, 0.0, 255.0);
|
y_pixel[y_pixel_x++ + (y % 2) * y_width] = fclampf(255.0 * (dat_freq - 1500.0) / 800.0, 0.0, 255.0);
|
||||||
|
|
||||||
if (uv_pixel_x < uv_width && ticks >= (int)((sync_porch_len + y_len + seperator_len + porch_len) * drate))
|
if ((uv_pixel_x < uv_width) && (ticks >= (sync_porch_drate_ticks + y_drate_ticks + seperator_drate_ticks + porch_drate_ticks)))
|
||||||
uv_pixel[uv_pixel_x++ + odd * uv_width] = fclampf(255.0 * (dat_freq - 1500.0) / 800.0, 0.0, 255.0);
|
uv_pixel[uv_pixel_x++ + odd * uv_width] = fclampf(255.0 * (dat_freq - 1500.0) / 800.0, 0.0, 255.0);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Ładowanie…
Reference in New Issue