Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
cdy816
Mars
提交
7674c9b8
Mars
项目概览
cdy816
/
Mars
通知
3
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
Mars
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
7674c9b8
编写于
6月 25, 2020
作者:
cdy816
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
修正无损压缩Bug
上级
35baa02d
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
35 addition
and
28 deletion
+35
-28
RunTime/DBRuntime/His/Compress/Special/DeadAreaCompressUnit.cs
...me/DBRuntime/His/Compress/Special/DeadAreaCompressUnit.cs
+22
-16
RunTime/DBRuntime/His/Compress/Special/DoubleCompressBuffer.cs
...me/DBRuntime/His/Compress/Special/DoubleCompressBuffer.cs
+1
-1
RunTime/DBRuntime/His/Compress/Special/FloatCompressBuffer.cs
...ime/DBRuntime/His/Compress/Special/FloatCompressBuffer.cs
+1
-1
RunTime/DBRuntime/His/Compress/Special/LosslessCompressUnit.cs
...me/DBRuntime/His/Compress/Special/LosslessCompressUnit.cs
+2
-1
RunTime/DBRuntime/His/Compress/Special/SlopeCompressUnit.cs
RunTime/DBRuntime/His/Compress/Special/SlopeCompressUnit.cs
+9
-9
未找到文件。
RunTime/DBRuntime/His/Compress/Special/DeadAreaCompressUnit.cs
浏览文件 @
7674c9b8
...
...
@@ -76,9 +76,9 @@ namespace Cdy.Tag
bool
isFirst
=
true
;
int
ig
=
-
1
;
ig
=
emptys
.
WriteIndex
>=
0
?
emptys
.
Remove
()
:
-
1
;
ig
=
emptys
.
ReadIndex
<
emptys
.
WriteIndex
?
emptys
.
IncRead
()
:
-
1
;
switch
(
type
)
switch
(
type
)
{
case
TagType
.
Byte
:
byte
sval
=
0
;
...
...
@@ -105,7 +105,7 @@ namespace Cdy.Tag
else
{
ig
=
emptys
.
WriteIndex
>=
0
?
emptys
.
Remove
()
:
-
1
;
ig
=
emptys
.
ReadIndex
<
emptys
.
WriteIndex
?
emptys
.
IncRead
()
:
-
1
;
}
}
return
mMarshalMemory
.
StartMemory
.
AsMemory
<
byte
>(
0
,
(
int
)
mMarshalMemory
.
Position
);
...
...
@@ -134,7 +134,7 @@ namespace Cdy.Tag
else
{
ig
=
emptys
.
WriteIndex
>=
0
?
emptys
.
Remove
()
:
-
1
;
ig
=
emptys
.
ReadIndex
<
emptys
.
WriteIndex
?
emptys
.
IncRead
()
:
-
1
;
}
}
break
;
...
...
@@ -163,7 +163,7 @@ namespace Cdy.Tag
else
{
ig
=
emptys
.
WriteIndex
>=
0
?
emptys
.
Remove
()
:
-
1
;
ig
=
emptys
.
ReadIndex
<
emptys
.
WriteIndex
?
emptys
.
IncRead
()
:
-
1
;
}
}
break
;
...
...
@@ -191,8 +191,7 @@ namespace Cdy.Tag
}
else
{
ig
=
emptys
.
WriteIndex
>=
0
?
emptys
.
Remove
()
:
-
1
;
ig
=
emptys
.
ReadIndex
<
emptys
.
WriteIndex
?
emptys
.
IncRead
()
:
-
1
;
}
}
break
;
...
...
@@ -221,7 +220,7 @@ namespace Cdy.Tag
else
{
ig
=
emptys
.
WriteIndex
>=
0
?
emptys
.
Remove
()
:
-
1
;
ig
=
emptys
.
ReadIndex
<
emptys
.
WriteIndex
?
emptys
.
IncRead
()
:
-
1
;
}
}
break
;
...
...
@@ -250,7 +249,7 @@ namespace Cdy.Tag
else
{
ig
=
emptys
.
WriteIndex
>=
0
?
emptys
.
Remove
()
:
-
1
;
ig
=
emptys
.
ReadIndex
<
emptys
.
WriteIndex
?
emptys
.
IncRead
()
:
-
1
;
}
}
break
;
...
...
@@ -279,12 +278,14 @@ namespace Cdy.Tag
else
{
ig
=
emptys
.
WriteIndex
>=
0
?
emptys
.
Remove
()
:
-
1
;
ig
=
emptys
.
ReadIndex
<
emptys
.
WriteIndex
?
emptys
.
IncRead
()
:
-
1
;
}
}
break
;
case
TagType
.
Double
:
double
dsval
=
0
;
mDCompress
.
Reset
();
mDCompress
.
Precision
=
this
.
Precision
;
for
(
int
i
=
0
;
i
<
count
;
i
++)
{
if
(
i
!=
ig
)
...
...
@@ -292,7 +293,7 @@ namespace Cdy.Tag
var
id
=
source
.
ReadDouble
(
offset
+
i
*
8
);
if
(
isFirst
)
{
m
MarshalMemory
.
Write
(
id
);
m
DCompress
.
Append
(
id
);
isFirst
=
false
;
dsval
=
id
;
}
...
...
@@ -300,7 +301,8 @@ namespace Cdy.Tag
{
if
(
CheckIsNeedRecord
(
dsval
,
id
,
deadArea
,
deadType
))
{
mMarshalMemory
.
Write
(
id
);
mDCompress
.
Append
(
id
);
// mMarshalMemory.Write(id);
dsval
=
id
;
}
}
...
...
@@ -308,11 +310,14 @@ namespace Cdy.Tag
else
{
ig
=
emptys
.
WriteIndex
>=
0
?
emptys
.
Remove
()
:
-
1
;
ig
=
emptys
.
ReadIndex
<
emptys
.
WriteIndex
?
emptys
.
IncRead
()
:
-
1
;
}
}
mDCompress
.
Compress
();
return
mMarshalMemory
.
StartMemory
.
AsMemory
<
byte
>(
0
,
(
int
)
mMarshalMemory
.
Position
);
case
TagType
.
Float
:
mFCompress
.
Reset
();
mFCompress
.
Precision
=
this
.
Precision
;
float
fsval
=
0
;
for
(
int
i
=
0
;
i
<
count
;
i
++)
{
...
...
@@ -321,7 +326,7 @@ namespace Cdy.Tag
var
id
=
source
.
ReadFloat
(
offset
+
i
*
4
);
if
(
isFirst
)
{
m
MarshalMemory
.
Write
(
id
);
m
FCompress
.
Append
(
id
);
isFirst
=
false
;
fsval
=
id
;
}
...
...
@@ -329,7 +334,7 @@ namespace Cdy.Tag
{
if
(
CheckIsNeedRecord
(
fsval
,
id
,
deadArea
,
deadType
))
{
m
MarshalMemory
.
Write
(
id
);
m
FCompress
.
Append
(
id
);
fsval
=
id
;
}
}
...
...
@@ -337,9 +342,10 @@ namespace Cdy.Tag
else
{
ig
=
emptys
.
WriteIndex
>=
0
?
emptys
.
Remove
()
:
-
1
;
ig
=
emptys
.
ReadIndex
<
emptys
.
WriteIndex
?
emptys
.
IncRead
()
:
-
1
;
}
}
mFCompress
.
Compress
();
return
mMarshalMemory
.
StartMemory
.
AsMemory
<
byte
>(
0
,
(
int
)
mMarshalMemory
.
Position
);
default
:
return
base
.
CompressValues
<
T
>(
source
,
offset
,
count
,
emptys
,
type
);
...
...
RunTime/DBRuntime/His/Compress/Special/DoubleCompressBuffer.cs
浏览文件 @
7674c9b8
...
...
@@ -137,7 +137,7 @@ namespace DBRuntime.His.Compress
/// </summary>
public
void
Compress
()
{
if
(
mCanCompress
)
if
(
mCanCompress
&&
index
>
2
)
{
MemoryBlock
.
Write
((
byte
)
this
.
Precision
);
MemoryBlock
.
Write
(
mBuffer
[
0
]);
...
...
RunTime/DBRuntime/His/Compress/Special/FloatCompressBuffer.cs
浏览文件 @
7674c9b8
...
...
@@ -137,7 +137,7 @@ namespace DBRuntime.His.Compress
/// </summary>
public
void
Compress
()
{
if
(
mCanCompress
)
if
(
mCanCompress
&&
index
>
2
)
{
MemoryBlock
.
Write
((
byte
)
this
.
Precision
);
MemoryBlock
.
Write
(
mBuffer
[
0
]);
...
...
RunTime/DBRuntime/His/Compress/Special/LosslessCompressUnit.cs
浏览文件 @
7674c9b8
...
...
@@ -388,13 +388,14 @@ namespace Cdy.Tag
if
(
i
!=
ig
)
{
var
id
=
source
.
ReadFloat
(
offset
+
i
*
4
);
m
MarshalMemory
.
Write
(
id
);
m
FCompress
.
Append
(
id
);
}
else
{
ig
=
emptys
.
ReadIndex
<
emptyIds
.
WriteIndex
?
emptys
.
IncRead
()
:
-
1
;
}
}
mFCompress
.
Compress
();
return
mMarshalMemory
.
StartMemory
.
AsMemory
<
byte
>(
0
,
(
int
)
mMarshalMemory
.
Position
);
case
TagType
.
IntPoint
:
int
psval
=
0
;
...
...
RunTime/DBRuntime/His/Compress/Special/SlopeCompressUnit.cs
浏览文件 @
7674c9b8
...
...
@@ -219,7 +219,7 @@ namespace Cdy.Tag
{
if
(
i
==
1
)
{
slope
=
CalSlope
(
pval
,
vals
[
i
],
vals
[
i
].
Key
-
ptim
);
slope
=
CalSlope
(
pval
,
vals
[
i
]
.
Value
,
vals
[
i
].
Key
-
ptim
);
}
else
{
...
...
@@ -267,7 +267,7 @@ namespace Cdy.Tag
{
if
(
i
==
1
)
{
slope
=
CalSlope
(
pval
,
vals
[
i
],
vals
[
i
].
Key
-
ptim
);
slope
=
CalSlope
(
pval
,
vals
[
i
]
.
Value
,
vals
[
i
].
Key
-
ptim
);
}
else
{
...
...
@@ -315,7 +315,7 @@ namespace Cdy.Tag
{
if
(
i
==
1
)
{
slope
=
CalSlope
(
pval
,
vals
[
i
],
vals
[
i
].
Key
-
ptim
);
slope
=
CalSlope
(
pval
,
vals
[
i
]
.
Value
,
vals
[
i
].
Key
-
ptim
);
}
else
{
...
...
@@ -362,7 +362,7 @@ namespace Cdy.Tag
{
if
(
i
==
1
)
{
slope
=
CalSlope
(
pval
,
vals
[
i
],
vals
[
i
].
Key
-
ptim
);
slope
=
CalSlope
(
pval
,
vals
[
i
]
.
Value
,
vals
[
i
].
Key
-
ptim
);
}
else
{
...
...
@@ -409,7 +409,7 @@ namespace Cdy.Tag
{
if
(
i
==
1
)
{
slope
=
CalSlope
(
pval
,
vals
[
i
],
vals
[
i
].
Key
-
ptim
);
slope
=
CalSlope
(
pval
,
vals
[
i
]
.
Value
,
vals
[
i
].
Key
-
ptim
);
}
else
{
...
...
@@ -456,7 +456,7 @@ namespace Cdy.Tag
{
if
(
i
==
1
)
{
slope
=
CalSlope
(
pval
,
vals
[
i
],
vals
[
i
].
Key
-
ptim
);
slope
=
CalSlope
(
pval
,
vals
[
i
]
.
Value
,
vals
[
i
].
Key
-
ptim
);
}
else
{
...
...
@@ -503,7 +503,7 @@ namespace Cdy.Tag
{
if
(
i
==
1
)
{
slope
=
CalSlope
(
pval
,
vals
[
i
],
vals
[
i
].
Key
-
ptim
);
slope
=
CalSlope
(
pval
,
vals
[
i
]
.
Value
,
vals
[
i
].
Key
-
ptim
);
}
else
{
...
...
@@ -550,7 +550,7 @@ namespace Cdy.Tag
{
if
(
i
==
1
)
{
slope
=
CalSlope
(
pval
,
vals
[
i
],
vals
[
i
].
Key
-
ptim
);
slope
=
CalSlope
(
pval
,
vals
[
i
]
.
Value
,
vals
[
i
].
Key
-
ptim
);
}
else
{
...
...
@@ -603,7 +603,7 @@ namespace Cdy.Tag
{
if
(
i
==
1
)
{
slope
=
CalSlope
(
pval
,
vals
[
i
],
vals
[
i
].
Key
-
ptim
);
slope
=
CalSlope
(
pval
,
vals
[
i
]
.
Value
,
vals
[
i
].
Key
-
ptim
);
}
else
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录