forked from handaimaoh/removedirtvs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathshared.h
76 lines (68 loc) · 2.68 KB
/
shared.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
#include "VapourSynth.h"
#include "VSHelper.h"
#if defined(_MSC_VER)
#define _ALLOW_KEYWORD_MACROS
#define alignas(x) __declspec(align(x))
#define ALIGNED_ARRAY(decl, alignment) alignas(alignment) decl
#else
#define __forceinline inline
#define ALIGNED_ARRAY(decl, alignment) __attribute__((aligned(16))) decl
#endif
typedef struct {
uint8_t ALIGNED_ARRAY(noiselevel, 16)[16];
uint8_t *blockproperties_addr;
uint32_t threshold;
int32_t pline;
int32_t nline;
int32_t motionblocks;
uint8_t *blockproperties;
int32_t linewidth;
int32_t hblocks;
int32_t vblocks;
int32_t hblocksSSE2;
bool remainderSSE2;
int32_t linewidthSSE2;
uint32_t (*blockcompare)(const uint8_t *p1, int32_t pitch1, const uint8_t *p2, int32_t pitch2, const uint8_t *noiselevel);
void (*blockcompareSSE2)(const uint8_t *p1, const uint8_t *p2, int32_t pitch, const uint8_t *noiselevel);
} MotionDetectionData;
typedef struct MotionDetectionDistData MotionDetectionDistData;
struct MotionDetectionDistData{
int32_t distblocks;
uint32_t blocks;
uint32_t tolerance;
uint32_t *isum;
int32_t dist;
int32_t dist1;
int32_t dist2;
int32_t hint32_terior;
int32_t vint32_terior;
int32_t colinc;
int32_t isumline;
int32_t isuminc1;
int32_t isuminc2;
void (*processneighbours)(MotionDetectionDistData*);
MotionDetectionData md;
};
typedef struct {
int32_t linewidthUV;
int32_t chromaheight;
int32_t chromaheightm;
int32_t pthreshold;
int32_t cthreshold;
int32_t loops;
int32_t restored_blocks;
int32_t (*vertical_diff_chroma)(const uint8_t *u, const uint8_t *v, int32_t pitch, const uint8_t *noiselevel);
MotionDetectionDistData mdd;
} PostProcessingData;
typedef struct {
bool grey;
bool show;
PostProcessingData pp;
} RemoveDirtData;
void VS_CC SCSelectCreate(const VSMap *in, VSMap *out, void *userData, VSCore *core, const VSAPI *vsapi);
void VS_CC RestoreMotionBlocksCreate(const VSMap *in, VSMap *out, void *userData, VSCore *core, const VSAPI *vsapi);
void VS_CC DupBlocksCreate(const VSMap *in, VSMap *out, void *userData, VSCore *core, const VSAPI *vsapi);
uint32_t gdiff(const uint8_t *sp1, int32_t spitch1, const uint8_t *sp2, int32_t spitch2, int32_t hblocks, int32_t incpitch, int32_t height);
void copyChroma(VSFrameRef *dest, const VSFrameRef *source, const VSVideoInfo *vi, const VSAPI *vsapi);
int32_t RemoveDirtProcessFrame(RemoveDirtData *rd, VSFrameRef *dest, const VSFrameRef *src, const VSFrameRef *previous, const VSFrameRef *next, const VSAPI *vsapi, const VSVideoInfo *vi);
void FillRemoveDirt(RemoveDirtData *rd, const VSMap *in, VSMap *out, const VSAPI *vsapi, const VSVideoInfo *vi);