|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
13-Июн-21 12:52
(3 года 7 месяцев назад, ред. 13-Июн-21 12:52)
Тема была выделена из Обработка и пересжатие видео [обсуждение] xfiles
Здрасьте. Вы в курсе, что в новых телеках есть режим Dynamic?
Так вот, я сделал эту фишку на C.
С помощью моей проги Dynamic Range Optimization можно сделать прямо внутри рипа.
Этим мы убиваем двух зайцев. Во-первых, поддерживаем старые телеки, где этой фишки нет.
А во-вторых, улучшаем сжимаемость потока.
Минус один - ужастики перестают быть страшными.
Вот чё эта штука делает. Из этого:
вот это.
Это не тупой энханкер, который всего лишь вытягивает уровни. Пруф.
Как видим, гистограмма плоская. То, что сначала дыры - это потому, что точность у исходника только 8 бит на канал.
Если кто не понял - повторное применение фильтра изображение не изменит.
Прогу дам за лайк, и компрессор звука, работающий по тому же принципу в придачу. Будет реветь.
Если кому надо, пишите.
|
|
garageforsale
Стаж: 15 лет 1 месяц Сообщений: 4482
|
garageforsale ·
13-Июн-21 13:12
(спустя 19 мин., ред. 13-Июн-21 13:54)
bckpkol, это для тех кто в детстве вырос на ярких эпилептических мультиках типа Лунтика и уже нормальную мягкую натуральную картинку с полутонами не в силах воспринимать? (то же и про звук). Бедняги...
P.S. у меня в одиннадцатилетнем телеке есть этот динамический (вырви-глас) режим. Ничего нового.
|
|
shinkiroo
Стаж: 15 лет 1 месяц Сообщений: 363
|
shinkiroo ·
13-Июн-21 14:11
(спустя 58 мин.)
скрытый текст
bckpkol писал(а):
81562836Здрасьте. Вы в курсе, что в новых телеках есть режим Dynamic?
Так вот, я сделал эту фишку на C.
С помощью моей проги Dynamic Range Optimization можно сделать прямо внутри рипа.
Этим мы убиваем двух зайцев. Во-первых, поддерживаем старые телеки, где этой фишки нет.
А во-вторых, улучшаем сжимаемость потока.
Минус один - ужастики перестают быть страшными.
Вот чё эта штука делает. Из этого:
вот это.
Это не тупой энханкер, который всего лишь вытягивает уровни. Пруф.
Как видим, гистограмма плоская. То, что сначала дыры - это потому, что точность у исходника только 8 бит на канал.
Если кто не понял - повторное применение фильтра изображение не изменит.
Прогу дам за лайк, и компрессор звука, работающий по тому же принципу в придачу. Будет реветь.
Если кому надо, пишите.
|
|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
13-Июн-21 16:47
(спустя 2 часа 36 мин., ред. 13-Июн-21 16:47)
скрытый текст
Мой dynamic как раз и делает мягкие тона, а яркие вырвиглазные мультики перестанут быть и яркими и вырвиглазными.
Вот пруфы:
До:
После:
IMHO, после обработки напоминает Союзмультфильм.
|
|
Tempter57
Стаж: 16 лет 3 месяца Сообщений: 4963
|
Tempter57 ·
13-Июн-21 16:55
(спустя 7 мин.)
bckpkol
Вердикт: тихий ужас по результату "после". Упаси бог нас от таких пруфов...
|
|
garageforsale
Стаж: 15 лет 1 месяц Сообщений: 4482
|
garageforsale ·
13-Июн-21 17:10
(спустя 14 мин., ред. 13-Июн-21 17:18)
Это лютый звиздец
Вы даже Лунтика умудрились изуродовать (хотя казалось бы это невозможно...)
|
|
Koo1
Стаж: 15 лет 8 месяцев Сообщений: 1145
|
Koo1 ·
13-Июн-21 17:27
(спустя 16 мин.)
|
|
shinkiroo
Стаж: 15 лет 1 месяц Сообщений: 363
|
shinkiroo ·
13-Июн-21 17:34
(спустя 7 мин.)
скрытый текст
bckpkol писал(а):
81563835Мой dynamic как раз и делает мягкие тона, а яркие вырвиглазные мультики перестанут быть и яркими и вырвиглазными.
Вот пруфы:
До:
После:
IMHO, после обработки напоминает Союзмультфильм.
мать мая женщина, это вообще что? пожалуйста скажите что вы скрины местами перепутали, потому что такое наверно только под наркотой можно увидеть, ночь в день превратилась.
|
|
xfiles
Стаж: 17 лет 2 месяца Сообщений: 51457
|
xfiles ·
13-Июн-21 17:48
(спустя 14 мин.)
Кто-то серьезно воспринимает залётного тролля?
|
|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
13-Июн-21 18:46
(спустя 57 мин., ред. 13-Июн-21 18:46)
скрытый текст
Буду считать за пол-лайка. Компиляйте с VC6.
Usage: ffmpeg -i %1 -f rawvideo -pix_fmt bgr24 -s 512x288 - | proc24 512 288 | ffplay - -f rawvideo -pix_fmt bgr24 -s 512x288
Код:
#include <stdlib.h>
#include <fcntl.h>
#include <io.h>
#include <stdio.h>
#define int64_t __int64
typedef struct{
int64_t acc[256];
int64_t buf[1024][256];
}channelfilter;
int main(int argc,char**argv){
unsigned char*fb;
unsigned char*fbe;
channelfilter*cf;
long n,fbsz;
short roll;
char full,i;
_setmode(_fileno(stdin),O_BINARY);
_setmode(_fileno(stdout),O_BINARY);
n=1;
while(--argc)n*=atol(argv[argc]);
fbsz=n*3;
fb=malloc(fbsz);
fbe=fb+fbsz;
cf=calloc(3,sizeof(channelfilter));
roll=0;
full=0;
while(fread(fb,fbsz,1,stdin)==1){
int64_t pal[3][256];
unsigned char*ch;
long j;
for(i=0;i<3;++i){
if(full)for(j=0;j<256;++j){
cf[i].acc[j]-=cf[i].buf[roll][j];
cf[i].buf[roll][j]=0;
}
for(ch=fb+i;ch<fbe;ch+=3){
cf[i].buf[roll][*ch]+=1;
}
cf[i].acc[0]+=cf[i].buf[roll][0];
pal[i][0]=0;
for(j=1;j<256;++j){
cf[i].acc[j]+=cf[i].buf[roll][j];
pal[i][j]=pal[i][j-1]+cf[i].acc[j];
}
if(pal[i][255])for(j=1;j<255;++j){
pal[i][j]=(pal[i][j]*255)/pal[i][255];
}
pal[i][255]=255;
}
++roll;
if(roll==1024){roll=0;full=1;}
//fwrite(fb,fbsz,1,stdout);
i=0;
for(j=0;j<fbsz;++j){
fb[j]=(unsigned char)pal[i][fb[j]];
++i;
if(i==3)i=0;
}
fwrite(fb,fbsz,1,stdout);
}
free(cf);
free(fb);
fputs("END\n",stderr);
return 0;
}
Цитата:
мать мая женщина, это вообще что? пожалуйста скажите что вы скрины местами перепутали, потому что такое наверно только под наркотой можно увидеть, ночь в день превратилась.
Читай Википедию.
Картинка оттуда:
|
|
garageforsale
Стаж: 15 лет 1 месяц Сообщений: 4482
|
garageforsale ·
13-Июн-21 18:57
(спустя 10 мин.)
bckpkol, Вы путаете расширение динамического диапазона (HDR) с выкручиванием уровней яркости. Перестаньте идиотничать
|
|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
13-Июн-21 20:11
(спустя 1 час 14 мин., ред. 13-Июн-21 20:11)
скрытый текст
bckpkol писал(а):
81562836Это не тупой энханкер, который всего лишь вытягивает уровни. Пруф.
Повторяю - это не тупой энханкер, который всего лишь вытягивает уровни.
Если кого волнуют дыры в гистограмме, вот что делает с ней добавочный gaussian blur.
И вот оригинал.
Новая линия практически плоская - каждому значению между 0-255 достаётся одинаковое количество пикселей. Это называется uniform distribution.
Если кого-то волнует отсутствие полутонов, просто перекодируйте файл в lossy кодек.
Цитата:
bckpkol, Вы путаете расширение динамического диапазона (HDR) с выкручиванием уровней яркости. Перестаньте идиотничать
Это вы что-то путаете, я говорил о сжатии динамического диапазона.
Цитата:
нормальную мягкую натуральную картинку с полутонами
Для особо. Большинство видеокарт (которые не HDR) поддерживают цвет максимум 6 бит на канал, то есть 18 бит.
True Color не 32 и не 24 бита, девочки. Два нижних бита попросту выкидываются системой, они нужны, потому что в C самый маленький тип 8 бит.
Ещё есть chroma subsampling. Голубой и розовый хранятся в половину от жёлтого.
Ладно,я не помню, какое разрешение у NTSC, но вот.
|
|
garageforsale
Стаж: 15 лет 1 месяц Сообщений: 4482
|
garageforsale ·
13-Июн-21 20:18
(спустя 6 мин., ред. 13-Июн-21 20:29)
bckpkol, отлично! Вы открыли (для себя) YUV кодирование цветности и цветовую субдискретизацию. Поздравляю!
bckpkol писал(а):
81564601Если кого-то волнует отсутствие полутонов, просто перекодируйте файл в lossy кодек. Два нижних бита попросту выкидываются системой, они нужны, потому что в C самый маленький тип 8 бит. True Color не 32 и не 24 бита, девочки. Ещё есть chroma subsampling. Голубой и розовый хранятся в половину от жёлтого. NTSC цветность всего-то 25x576. 25 пикселей по ширине, детки.
120 минут, центральное телевидение, один три нуля, Москва - посольство США, послу Ричарду Чейни США, министру обороны США, НАТО, НАСА, Барак 4, комната 14, длина стола 840мм, ширина 630мм, шифровка была в 0 часов на погран.заставу СССР, пост №5 поступило 5 миллиардов рублей золотом из Пакистана на электрогидростанции на Амуре...
У Вас в голове каша и нарушение причинно-следственных связей. Впрочем, это объясняет тягу к пастеризованным высветленным изображениям.
P.S. о... пока писал ответ, вы про "25 пикселей по ширине, детки" удалили...
|
|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
13-Июн-21 20:59
(спустя 41 мин., ред. 13-Июн-21 20:59)
|
|
garageforsale
Стаж: 15 лет 1 месяц Сообщений: 4482
|
garageforsale ·
13-Июн-21 21:08
(спустя 8 мин.)
|
|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
13-Июн-21 22:27
(спустя 1 час 19 мин., ред. 01-Окт-22 15:49)
@garageforsale, тогда бинарники.
https://drive.google.com/file/d/1SokNPlP0bRRg1e02_ysxe98RjSn1GOzt/view?usp=sharing
https://drive.google.com/file/d/1b0gY-6hZZLfiwp_8pa_ngAponzQ7M4dY/view?usp=sharing
Исходники под спойлером.
Код:
ffmpeg -i "%1" -f u16le -af "pan=mono|c0=c0+c1+c2+c3+c4+c5" -|proc16_monov2|ffmpeg -f u16le -ac 1 -ar 48000 -i - -c:a pcm_s16le -bitexact -ar 22050 "%1.wav"
ffmpeg -ss 35 -t 400 -i %1 -f rawvideo -pix_fmt rgb24 -s 512x288 -r 10 - | proc24 512 288 | ffmpeg -f rawvideo -pix_fmt rgb24 -s 512x288 -r 60 -i - -c:v libxvid -q:v 20 -me_method zero -mbd rd -variance_aq 1 -flags +aic %1.dro.avi
Кстати, лучшие настройки xvid для низкого качества, проверено экспериментально. На совместимость не проверял.
скрытый текст
Код:
// proc16_mono.cpp : Defines the entry point for the console application.
// #include <stdlib.h>
#include <fcntl.h>
#include <io.h>
#include <stdio.h>
#include <string.h>
int main(){
int i;
unsigned short lcnt[65536];
unsigned short buf[65535];
unsigned short j;
_setmode(_fileno(stdin),O_BINARY);
_setmode(_fileno(stdout),O_BINARY);
for(i=1;i<32768;++i){
buf[i*2-2]=32768+i;
buf[i*2-1]=32768-i;
}
buf[65534]=32768;
for(i=0;i<65536;++i)lcnt[i]=i;
i=0;
do{
j=buf[i];
if(!fread(buf+i,2,1,stdin))break;
if(j<buf[i])do{--lcnt[j++];}while(j<buf[i]);
else while(j>buf[i]){++lcnt[--j];}
fwrite(lcnt+j,2,1,stdout);
i+=1;
i%=65535;
}while(1);
return 0;
}
Код:
#include <stdlib.h>
#include <fcntl.h>
#include <io.h>
#include <stdio.h>
#define int64_t __int64
typedef struct{
int64_t acc[256];
int64_t buf[1024][256];
}channelfilter;
int main(int argc,char**argv){
unsigned char*fb;
unsigned char*fbe;
channelfilter*cf;
long n,fbsz;
short roll;
char full,i;
_setmode(_fileno(stdin),O_BINARY);
_setmode(_fileno(stdout),O_BINARY);
n=1;
while(--argc)n*=atol(argv[argc]);
fbsz=n*3;
fb=malloc(fbsz);
fbe=fb+fbsz;
cf=calloc(3,sizeof(channelfilter));
roll=0;
full=0;
while(fread(fb,fbsz,1,stdin)==1){
int64_t pal[3][256];
unsigned char*ch;
long j;
for(i=0;i<3;++i){
if(full)for(j=0;j<256;++j){
cf[i].acc[j]-=cf[i].buf[roll][j];
cf[i].buf[roll][j]=0;
}
for(ch=fb+i;ch<fbe;ch+=3){
cf[i].buf[roll][*ch]+=1;
}
cf[i].acc[0]+=cf[i].buf[roll][0];
pal[i][0]=0;
for(j=1;j<256;++j){
cf[i].acc[j]+=cf[i].buf[roll][j];
pal[i][j]=pal[i][j-1]+cf[i].acc[j];
}
if(pal[i][255])for(j=1;j<255;++j){
pal[i][j]=(pal[i][j]*255)/pal[i][255];
}
pal[i][255]=255;
}
++roll;
if(roll==1024){roll=0;full=1;}
//fwrite(fb,fbsz,1,stdout);
i=0;
for(j=0;j<fbsz;++j){
fb[j]=(unsigned char)pal[i][fb[j]];
++i;
if(i==3)i=0;
}
fwrite(fb,fbsz,1,stdout);
}
free(cf);
free(fb);
fputs("END\n",stderr);
return 0;
}
UPD: крошечная поправочка, мог быть треск во время полной тишины. Логарифмическая версия не содержит этого бага.
|
|
volta_john
Стаж: 14 лет 7 месяцев Сообщений: 780
|
volta_john ·
13-Июн-21 23:13
(спустя 46 мин.)
bckpkol
Вы молодец, умный человек, отличный программист и знаете толк в прекрасном.
С пользой для себя и других проводите свои выходные.
Лунтик заиграл новыми красками.
Дам совет.
скрытый текст
Для расширения визуального восприятия и переноса полученного опыта в код попробуйте ещё диэтиламид d-лизергиновой кислоты.
|
|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
14-Июн-21 07:08
(спустя 7 часов, ред. 14-Июн-21 07:08)
https://wiki.osdev.org/VGA_Hardware
Цитата:
Port 0x3C8, 0x3C9 and 0x3C7 control the DAC. Each register in the DAC consists of 18 bits, 6 bits for each color component.
https://gist.github.com/YamashitaRen/2dcea6fd5830ecd53236
Цитата:
Here’s a bit of side info: Most LCD displays (TN panels to be precise) can only
represent a bit depth of 6 bits per channel (a mere 64 levels). This would look
pretty awful under normal circumstances, so these displays use a little trick
called “dithering” to simulate a bit depth of 8 bits per channel.
@volta_john, Щас это тоже обработаю.
Разница, в принципе, небольшая.
Плюс добавлю, что алгоритм вытягивает только спокойные сцены. Динамичные остаются почти как есть.
|
|
volta_john
Стаж: 14 лет 7 месяцев Сообщений: 780
|
volta_john ·
14-Июн-21 13:25
(спустя 6 часов)
bckpkol писал(а):
Щас это тоже обработаю.
Разница, в принципе, небольшая.
Да, есть ещё куда стремиться.
bckpkol писал(а):
Плюс добавлю, что алгоритм вытягивает только спокойные сцены. Динамичные остаются почти как есть.
Надо бы и их добить.
|
|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
15-Июн-21 08:45
(спустя 19 часов, ред. 15-Июн-21 08:45)
Цитата:
Вы молодец, умный человек, отличный программист и знаете толк в прекрасном.
А знаете что. Я действительно отличный хакер и могу закодить это как раз плюнуть.
Цитата:
Надо бы и их добить.
Первая версия, которая была ещё на Python, так и делала. Появлялись внезапные вспышки, которые меня раздражали.
Я стал усреднять гистограмму по 1000 кадрам и получил гладкий результат.
Нет ничего проще, чем добить динамичные сцены, но это не красиво, и битрейт распухнет.
P.S Могу дать Python версию, она наглядней.
О, круто. Тему выделили. Товарищи модеры, тогда пожалуйста, добавьте "и звука" к названию темы.
|
|
volta_john
Стаж: 14 лет 7 месяцев Сообщений: 780
|
volta_john ·
15-Июн-21 09:31
(спустя 45 мин.)
Во! То, что доктор Хофман прописал!
bckpkol писал(а):
Первая версия, которая была ещё на Python, так и делала. Появлялись внезапные вспышки, которые меня раздражали.
Я стал усреднять гистограмму по 1000 кадрам и получил гладкий результат.
1000 - очень много. Можно попробовать начать с 25 кадра. Должно и статику, и динамику прибить безо всяких внезапностей. Ну а если вспышки всё равно будут прорываться, перейти на 42 кадра. 42 наверняка должно сработать.
bckpkol писал(а):
Нет ничего проще, чем добить динамичные сцены, но это не красиво, и битрейт распухнет.
Добейте их красиво. Битрейту же пухнуть полезно, говорят, от этого артефакты сжатия из тела рипов выводятся.
bckpkol писал(а):
P.S Могу дать Python версию, она наглядней.
Я в питонах ни бум-бум, но можно попробовать подушить этого удава.
bckpkol писал(а):
О, круто. Тему выделили. Товарищи модеры, тогда пожалуйста, добавьте "и звука" к названию темы.
Вот это правильный подход, браво!
|
|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
15-Июн-21 16:01
(спустя 6 часов, ред. 20-Сен-21 19:27)
Так, скоро будет. А пока.
GIF-изображения загружены на хостинг картинок Япикс
Оригинал.
Классическая с атакой 1024. Почти плацебо.
Атака 42.
Атака 25.
Атака 1. То есть без усреднения по кадрам.
С атакой 1 может быть такая проблема. Если в фильме есть гроза.
Смотря как её сделали. Если подкрутили уровни - от грозы ничего не останется.
Если школа старая и режиссёр брал фонарь, то будет глубокая тень, а всё, что не в тени, станет ярким.
Но всё равно эффект будет ослаблен. Поэтому надо хотя бы 4, я думаю.
Кстати, гистограмма YUV. То есть яркость только первый слайдер.
Так, репост всех последних версий утилит.
Начну с психоделизма.
https://drive.google.com/file/d/1HVV0u35vPhcIufWRNEx8_9_5G7dIYltd/view?usp=sharing
Для оптимального эффекта нужна цепочка фильтров нормализация - глюк - нормализация.
Usage: proc24adv w h attack_time|glitch w h|proc24adv w h attack_time
Так, теперь нормализация видео с регулятором времени атаки.
https://drive.google.com/file/d/1n-EYcKC_0UrM2yun6kvBdBUuC4BIxcLG/view?usp=sharing
Usage: proc24adv w h attack_time
И для звука. Формат нужен 16 бит unsigned little endian.
24 бита можно, но кодирование займёт год. А 16 бит обрабатывается realtime.
Usage:proc16_monov2
Моно мне больше подходит. Могу сделать стерео версию, а пока можно разделять каналы.
https://drive.google.com/file/d/1SokNPlP0bRRg1e02_ysxe98RjSn1GOzt/view?usp=sharing
Исходники на Python:
Код:
import sys,numpy as np
res=int(sys.argv[1])*int(sys.argv[2])
sz=res*3
def bcnt(x):
y=np.bincount(x.ravel())
y=y*(1./y.max())
y[0]=0
y=np.cumsum(y)
y*=255.9/y.max()
return np.uint8(y)[x]
while True:
try:
im=np.fromfile(sys.stdin,dtype=np.uint8,count=sz).reshape(-1,3)
except Exception:
break
np.dstack([bcnt(im[:,0]),bcnt(im[:,1]),bcnt(im[:,2])]).tofile(sys.stdout)
Исходники на C.
скрытый текст
Код:
// glitch.cpp : Defines the entry point for the console application.
// #include <stdlib.h>
#include <fcntl.h>
#include <io.h>
#include <time.h>
#include <math.h>
#include <stdio.h>
#include <string.h>
int main(int argc,char**argv){
int sz=1;
int i;
int j;
int tmp;
short*mode;
unsigned char*buf;
short shuffle[384];
short tmp2;
unsigned char b;
unsigned char g;
unsigned char r;
unsigned char shift=0;
_setmode(_fileno(stdin),O_BINARY);
_setmode(_fileno(stdout),O_BINARY);
while(--argc)sz*=atoi(argv[argc]);
for(i=0;i<384;++i)shuffle[i]=383-i;
srand(time(NULL));
for(i=1;i<383;++i){
j=rand()%(i+1);
tmp=shuffle[j];
shuffle[j]=shuffle[i];
shuffle[i]=tmp;
}
mode=malloc(sz*sizeof(short));
j=sz*3;
buf=malloc(j);
if(!mode||!buf)goto oom;
for(i=0;i<sz;++i){
mode[i]=383;
}
while(fread(buf,j,1,stdin)){
for(i=0;i<sz;++i){
tmp=i*3;
tmp2=shuffle[mode[i]];
switch(tmp2>>6){
case 0:
b=buf[tmp];
g=buf[tmp+1];
r=buf[tmp+2];
break;
case 1:
b=buf[tmp];
g=buf[tmp+2];
r=buf[tmp+1];
break;
case 2:
b=buf[tmp+1];
g=buf[tmp+2];
r=buf[tmp];
break;
case 3:
b=buf[tmp+1];
g=buf[tmp];
r=buf[tmp+2];
break;
case 4:
b=buf[tmp+2];
g=buf[tmp];
r=buf[tmp+1];
break;
case 5:
b=buf[tmp+2];
g=buf[tmp+1];
r=buf[tmp];
break;
}
if(tmp2&32)b=~b;
if(tmp2&16)g=~g;
if(tmp2&8)r=~r;
if(tmp2&4)b-=shift;else b+=shift;
if(tmp2&2)g-=shift;else g+=shift;
if(tmp2&1)r-=shift;else r+=shift;
buf[tmp]=b;
buf[tmp+1]=g;
buf[tmp+2]=r;
if(!b||!g||!r)mode[i]=(mode[i]+1)%384;
}
fwrite(buf,j,1,stdout);
shift+=32;
}
oom:
free(mode);
free(buf);
return 0;
}
Код:
#include <stdlib.h>
#include <fcntl.h>
#include <io.h>
#include <stdio.h>
#define int64_t __int64
typedef struct{
int64_t acc[256];
int64_t buf[1][256];
}channelfilter;
int main(int argc,char**argv){
unsigned char*fb;
unsigned char*fbe;
channelfilter*cf[3];
long n,fbsz,tmp;
short roll;
char full,i;
long attack_time=1024;
_setmode(_fileno(stdin),O_BINARY);
_setmode(_fileno(stdout),O_BINARY);
fputs("By Denis Cullassnekuff\nUsage: proc24adv width height [attack time]\nAttack time defaults to 1024.",stderr);
fflush(stderr);
if(argc<3)return 1;
n=1;
n=atol(argv[1])*atol(argv[2]);
if(argc>=4){
if(!(attack_time=atol(argv[3])))attack_time=1;
else if(attack_time&0xffff0000)attack_time=1024;
}
fbsz=n*3;
fb=malloc(fbsz);
fbe=fb+fbsz;
tmp=sizeof(channelfilter)+(sizeof(int64_t)*256*(attack_time-1));
cf[0]=calloc(1,tmp);
cf[1]=calloc(1,tmp);
cf[2]=calloc(1,tmp);
if(!fb||!cf[0]||!cf[1]||!cf[2])goto oom;
roll=0;
full=0;
while(fread(fb,fbsz,1,stdin)==1){
int64_t pal[3][256];
unsigned char*ch;
long j;
for(i=0;i<3;++i){
if(full)for(j=0;j<256;++j){
cf[i]->acc[j]-=cf[i]->buf[roll][j];
cf[i]->buf[roll][j]=0;
}
for(ch=fb+i;ch<fbe;ch+=3){
cf[i]->buf[roll][*ch]+=1;
}
cf[i]->acc[0]+=cf[i]->buf[roll][0];
pal[i][0]=0;
for(j=1;j<256;++j){
cf[i]->acc[j]+=cf[i]->buf[roll][j];
pal[i][j]=pal[i][j-1]+cf[i]->acc[j];
}
if(pal[i][255])for(j=1;j<255;++j){
pal[i][j]=(pal[i][j]*255)/pal[i][255];
}
pal[i][255]=255;
}
++roll;
if(roll==attack_time){roll=0;full=1;}
//fwrite(fb,fbsz,1,stdout);
i=0;
for(j=0;j<fbsz;++j){
fb[j]=(unsigned char)pal[i][fb[j]];
++i;
if(i==3)i=0;
}
fwrite(fb,fbsz,1,stdout);
}
oom:
free(cf[0]);
free(cf[1]);
free(cf[2]);
free(fb);
fputs("END\n",stderr);
return 0;
}
Код:
// proc16_mono.cpp : Defines the entry point for the console application.
// #include <stdlib.h>
#include <fcntl.h>
#include <io.h>
#include <stdio.h>
#include <string.h>
int main(){
int i;
unsigned short lcnt[65536];
unsigned short buf[65535];
unsigned short j;
_setmode(_fileno(stdin),O_BINARY);
_setmode(_fileno(stdout),O_BINARY);
for(i=1;i<32768;++i){
buf[i*2-2]=32768+i;
buf[i*2-1]=32768-i;
}
buf[65534]=0;
for(i=0;i<32768;++i)lcnt[i]=i;
for(;i<65536;++i)lcnt[i]=i-1;
i=0;
do{
j=buf[i];
if(!fread(buf+i,2,1,stdin))break;
if(j<buf[i])do{--lcnt[j++];}while(j<buf[i]);
else while(j>buf[i]){++lcnt[--j];}
fwrite(lcnt+buf[i],2,1,stdout);
i+=1;
i%=65535;
}while(1);
return 0;
}
|
|
volta_john
Стаж: 14 лет 7 месяцев Сообщений: 780
|
volta_john ·
15-Июн-21 23:49
(спустя 7 часов)
Спасибо. 25 кадр, как и ожидалось, творит чудеса. Сочно, ясно, светло, с переливами и без вспышек. Приятная глазу цветомузыка, хоть в пляс иди.
bckpkol писал(а):
И для звука. Формат нужен 16 бит unsigned little endian.
24 бита можно, но кодирование займёт год. А 16 бит обрабатывается realtime.
Правильно, долой это излишнее квантование. Диды в PCM процессорах 14 бит использовали, в Луч-001 - 11, а в NICAM728 - вообще 10, и ничего - hi-fi оставался hi-fi.
bckpkol писал(а):
Моно мне больше подходит.
Вот кстати тоже хороший выбор формата. Понятный и краткий. А краткость - сестра таланта. Полвека с гаком моно-звуком в кино и ТВ пользовались и никто от этого не умер. К тому же ширина экранов меньше ширины звуковой стереобазы, равной расстоянию между акустическими системами, что вызывает несовпадение зрительных и слуховых образов.
|
|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
16-Июн-21 09:49
(спустя 10 часов, ред. 16-Июн-21 12:44)
Поправочка к компрессору звука. Я нечаянно вставил секунду тишины в начало. Последний пост я исправил, файл перезалит.
А про 24 бит. До меня дошло, что гистограмму можно считать в логарифмическое время. Это сделало обработку в 24 бит возможной.
В 2 раз быстрее, чем 16 бит. Пока. Я сделаю бэкпорт.
Принимает 24 на входе и выводит 16 бит.
Подождите, какой-то баг.
Готово, надеюсь.
Маленькая проблема, 24 бита версия падает в конце кодирования. Это не критично.
Исправлено в обоих версиях.
24 бита, выхлоп 16 (2x скорость):
https://drive.google.com/file/d/1LwM87nHf1SIpXBzXWhE3MIKmXvUtYZrf/view?usp=sharing
16 бит (5x скорость):
https://drive.google.com/file/d/16J7YZZV-d3Vo8zC_XttVSoZ_EAODwk2O/view?usp=sharing
Исходники.
скрытый текст
Код:
// proc24_mono.cpp : Defines the entry point for the console application.
// #include <stdlib.h>
#include <fcntl.h>
#include <io.h>
#include <stdio.h>
#include <string.h>
#define trunc(a,b) (((a)+(b))&~(b))
#define crement_from(op,x) {\
int tmp;\
int y=0x1000000;\
int mode=0x800000;\
while(mode){\
tmp=trunc(x,mode-1);\
while(tmp<y){\
op lcnt[tmp];\
tmp+=mode;\
}\
tmp=trunc(x,mode-1);\
if(y>tmp)y=tmp;\
mode>>=1;\
}\
}
int main(){
int i;
int*lcnt;
unsigned int buf[65535];
unsigned int j;
unsigned int k;
unsigned int l;
unsigned int tmp;
_setmode(_fileno(stdin),O_BINARY);
_setmode(_fileno(stdout),O_BINARY);
if(!(lcnt=(int*)calloc(16777216,sizeof(int))))goto oom;
for(i=0;i<32767;++i){
buf[i*2]=(32768+i)<<8;
buf[i*2+1]=(32768-i)<<8;
}
buf[65534]=0;
for(i=0;i<65535;++i)crement_from(++,buf[i]);
i=0;
do{
j=buf[i];
if(!fread(buf+i,3,1,stdin))break;
crement_from(--,j);
crement_from(++,buf[i]);
j=0;
l=-1;
for(k=0x800000;k;k>>=1){
tmp=buf[i]&~(k-1);
if(tmp!=l){
l=tmp;
j+=lcnt[l];
}
if(!(buf[i]&(k-1)))break;
}
fwrite(&j,2,1,stdout);
i+=1;
i%=65535;
}while(1);
oom:
free(lcnt);
return 0;
}
Код:
// proc16_monov3.cpp : Defines the entry point for the console application.
// #include <stdlib.h>
#include <fcntl.h>
#include <io.h>
#include <stdio.h>
#include <string.h>
#define trunc(a,b) (((a)+(b))&~(b))
#define crement_from(op,x) {\
int tmp;\
int y=0x10000;\
int mode=0x8000;\
while(mode){\
tmp=trunc(x,mode-1);\
while(tmp<y){\
op lcnt[tmp];\
tmp+=mode;\
}\
tmp=trunc(x,mode-1);\
if(y>tmp)y=tmp;\
mode>>=1;\
}\
}
int main(){
int i;
int*lcnt;
unsigned short buf[65535];
unsigned int j;
unsigned int k;
unsigned int l;
unsigned int tmp;
_setmode(_fileno(stdin),O_BINARY);
_setmode(_fileno(stdout),O_BINARY);
if(!(lcnt=(int*)calloc(65536,sizeof(int))))goto oom;
for(i=1;i<32767;++i){
buf[i*2-2]=32768+i;
buf[i*2-1]=32768-i;
}
buf[65534]=0;
for(i=0;i<65535;++i)crement_from(++,buf[i]);
/*crypto check
for(i=0;i<65536;++i){
j=0;
l=-1;
for(k=0x8000;k;k>>=1){
tmp=i&~(k-1);
if(tmp!=l){
l=tmp;
j+=lcnt[l];
}
if(!(i&(k-1)))break;
}
fprintf(stderr,"%d\n",j);
}*/
i=0;
do{
j=buf[i];
if(!fread(buf+i,2,1,stdin))break;
crement_from(--,j);
crement_from(++,buf[i]);
j=0;
l=-1;
for(k=0x8000;k;k>>=1){
tmp=buf[i]&~(k-1);
if(tmp!=l){
l=tmp;
j+=lcnt[l];
}
if(!(buf[i]&(k-1)))break;
}
fwrite(&j,2,1,stdout);
i+=1;
i%=65535;
}while(1);
oom:
free(lcnt);
return 0;
}
|
|
Loud_Swir
Стаж: 16 лет 9 месяцев Сообщений: 1677
|
Loud_Swir ·
16-Июн-21 09:54
(спустя 4 мин.)
volta_john писал(а):
81575271Спасибо. 25 кадр, как и ожидалось, творит чудеса. Сочно, ясно, светло, с переливами и без вспышек. Приятная глазу цветомузыка, хоть в пляс иди.
bckpkol писал(а):
И для звука. Формат нужен 16 бит unsigned little endian.
24 бита можно, но кодирование займёт год. А 16 бит обрабатывается realtime.
Правильно, долой это излишнее квантование. Диды в PCM процессорах 14 бит использовали, в Луч-001 - 11, а в NICAM728 - вообще 10, и ничего - hi-fi оставался hi-fi.
bckpkol писал(а):
Моно мне больше подходит.
Вот кстати тоже хороший выбор формата. Понятный и краткий. А краткость - сестра таланта. Полвека с гаком моно-звуком в кино и ТВ пользовались и никто от этого не умер. К тому же ширина экранов меньше ширины звуковой стереобазы, равной расстоянию между акустическими системами, что вызывает несовпадение зрительных и слуховых образов.
|
|
xfiles
Стаж: 17 лет 2 месяца Сообщений: 51457
|
xfiles ·
16-Июн-21 14:23
(спустя 4 часа)
Тут все собрались чисто поржать.
|
|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
16-Июн-21 15:54
(спустя 1 час 31 мин., ред. 16-Июн-21 15:54)
Цитата:
Тут все собрались чисто поржать.
Лично я нет.
А кому охота поржать, идите сюда.
https://drive.google.com/file/d/11wkKW4LtW-OkStthkY1exmga-t6PN8Qm/view?usp=sharing
|
|
volta_john
Стаж: 14 лет 7 месяцев Сообщений: 780
|
volta_john ·
16-Июн-21 17:13
(спустя 1 час 18 мин.)
bckpkol
Радует ваша целеустремлённость, сообразительность, серьёзность, настойчивость, находчивость, упорство и работоспособность, а так же то, что неудачи/ошибки вас не останавливают.
Браво! Продолжайте и никого не слушайте.
|
|
bckpkol
Стаж: 14 лет 2 месяца Сообщений: 78
|
bckpkol ·
17-Июн-21 06:17
(спустя 13 часов, ред. 17-Июн-21 14:33)
Тогда предложение. Я сделаю психотропный BDRip "Секрета крыс" Дона Блата(Блут на трекере) и выложу под названием "реставрация". Ну как?
Вот семпл. https://drive.google.com/file/d/1OUXx-wQVJX8Fn5SziSIIC-PD2jZv7Jpi/view?usp=sharing
---
Всё на следующей странице уже.
|
|
xfiles
Стаж: 17 лет 2 месяца Сообщений: 51457
|
xfiles ·
17-Июн-21 08:22
(спустя 2 часа 4 мин.)
С этой разработкой надо идти на дум9.
|
|
|