里程表数据的算法
( y" f0 E8 w& c" y5 h& u
1 e7 m. P& d& B+ q, C" k' J: r. v9 D/ C; R& r( D% d) b9 o
一、10进制和16进制! N, n: t, {; T( N9 A0 V2 O' q
在电子仪表的存储芯片中,一般因为存储次数的问题,存储的数据不是使用10进制,而是使用16进制的算法,十进制数字为0、1、2、3、4、5、6、7、8、9。16进制数字为0、1、2、3、4、5、6、7、8、9、A、B、C、D、E、F,其中A为10、B为11、C为12、D为13、E为14、F为15。! ]) {. w6 a3 `5 w+ y, e6 J
16进制和10进制中间的转换互算法其实比较简单:即把16进制的“百位”、“十位”、“个位”视为百位*256、十位*16、个位不变数相加的和就是10进制的数值。
4 w# N L% U' L- l 例一:16进制021换算成10进制为:
/ c1 D/ q% z9 W D6 R$ y& M 百位:256×0=0
7 ~- P0 z3 e. r. u0 ^4 r) l 十位:2×16=32
) K* T$ K1 p& | E 个位:1不变=13 H0 @. y8 X5 K3 o" ?
0十32十1=338 y. C! ^" C; ^5 Z8 j; U
换算结果:10进制数值为33。
+ O' }# m# g% l 例二:16进制C44换算成10进制数值:
. j R2 y* H* d% V0 C7 ] 百位:C为12×256=3072
5 _+ r- x( N5 U! U2 B0 e 十位:4×16=64
+ q9 ]- V. Y5 o 个位:4不变=42 M1 r, ]/ I ?3 a) S
换算结果:10进制数值为3140! ]8 W! ?2 Y% U7 _* H4 A* p
如10进制数值要换算成16进制,可用相反的方法计算,以10进制码1211为例:1211除以256的整数商为4,余187,商4为16进制的“百位”;余数187除以16的整数商为11,余11,商11位16进制的“十位”,即B,组成16进制为4BB。
5 M- o: F: R4 d3 } 二、反码与正码( |* F3 O5 J: ~: D
在存储器中数据记录我们通常使用16进制的正码记录方法,如把12345(10进制)记录为:3039(16进制)。. E; `* X3 w! a7 r" k) O
但在汽车仪表中还有另一种记录方式:16进制反码,如把12345(10进制)记录为:CFC6(16进制反码)。有时也称反码为补码。4 \$ Q' k3 h# A$ M
那么反码与正码怎么转换呢?我们看一下用16进制的计算:CFC6=FFFF-3039;
5 q7 E" n; L# b# h0 n8 c B 其实我们还可以用另一种更直接的简单转换方式,只要按下正、反码对照进行一位对一位的转换即可:5 P4 G& M# I2 z: ?5 N2 b
正码:0123456789ABCDEF
5 W' g# K2 j# }9 g7 E" d7 Y5 G 反码:FEDCBA9876543210
* g4 t! @# [ h5 B 三、数据高低位问题/ p. C8 y5 `0 u: K
由于CPU设计和存储器设计的差异,对于同一个16位的16进制数记录时可能有高位在前或低位在前的设计差异。
( a( J. ^! O% S# M( V; Z 如数据3039(16进制),在某些仪表中会记录为:3930。$ ^1 S ?+ q' t
在调表之前我们必需弄清,我们的仪表是用那一种数据记录方式,其中有4种可能,即:正码+高位在前,正码+低位在前,反码+高位在前,反码+低位在前。/ f8 `2 d L* Q A4 q9 C; c$ _
四、里程表算法% k3 Q: }, h) N
知道了以上几点后,我们学习几种车系的里程数据的算法,其他的车系里程算法虽然略有不同,但是可以作为参考:+ M! q; b7 a R' f. J$ n3 q
1、大众车系调表算法
( ]! S* t* P7 {4 `2 s, q 首先我们介绍一种在汽车仪表中最常见的里程数据编码方式,这种编码方式的算法是为了解决存储器的读写次数而设计出来的。使用这种算法的车型包括:大部分的奥迪、大众、奔驰、宝马,以及小部分的国产车型,如奇瑞。并且其他的相当一部分车型的里程算法也是由这种算法演变或改进而来的。
" b" i, h3 S, q3 K) I' a# Z如果我们在仪表的存储数据中看到这样的数据:1 N* ?; l3 Q8 v' A: i5 q
3039 3039 3039 3039 3039 3039 3038 30383 f/ c6 w" }& S0 ?, W1 ?% I
一组数值很相近,连在一起〔有可能是8组,也有的是16组),这就是我们所要的里程数据。
; e; i, b+ r9 `5 S' q4 A/ e/ @现在我们假设数据的高低位及正反码的问题已解决,已经把数据统一转为正码、高位在前,并且只讨论八组数据的情况,我们看几个例子:2 O" C( u2 t# n- f) K8 K7 ~6 J
lkm:0001 0000 0000 0000 0000 0000 0000 0000
: G' E) X/ T( k) L2km:0001 0001 0000 0000 0000 0000 0000 0000* E3 V% b; w, i2 l
3km:0001 0001 0001 0000 0000 0000 0000 0000! T+ P d7 l8 w6 C4 H* C
8km:0001 0001 0001 0001 0001 0001 0001 0001
, ]" e+ M4 F& ^% @# _1 z9km: 0002 0001 0001 0001 0001 0001 0001 00015 a5 Q8 T9 H3 C6 C0 O, @; T% e
10km:0002 0002 0001 0001 0001 0001 0001 0001
0 D, s0 `+ W: W+ J7 ?. U. d* `1 ]大家很快就看出来,里程数就是把全部的数据都加起来的结果,但在大部分的车型中是每跑2km记录1次数据的,这时候我们得出的数据应该都乘以2才是实际的里程数,如上数据那就分别是:2km,4km,6km,16km,18km,20km。: t4 M& ]: s4 d. T" e/ @( U9 s/ q
2、丰田车系的调表算法
* y3 J& t) r6 [; N" |丰田车系的里程算法与大众的里程算法都是为了解决芯片擦写次数限制问题而产生的。
" F6 ?) ^0 h( J. i: F在分析丰田算法前我们先介绍两个名词:$ I* U' H, u4 x4 ]2 z# v
字节:在16进制的数据中我们把两个连着的字符称为“字节”,如:FF,00,12,34等。
& n" x+ H$ \$ W, g8 W0 @字:由连着的两个字节组成的数据称之为“双字节”或“字”,如:80FF,1032,7ABE等。$ w/ m9 c# L, h- O; I
在绝大部分的调表算法中都使用“字”作最小的计数单位。
( h7 y( L( x$ R* P, k* G8 {现在我们来看一组丰田车的里程数据:
* I1 Y- T5 f+ s3 V$ {8 ]97486km记录为:8OFF FFFF FFFF FFFF 7A8B F6FF7A8B F6FF 7A8B F6FF
f3 ?, ]* b: p3 u' [0 j0 T, O* Y* T这组数据为丰田车的里程记录数据,数据分为两部分。前一部分由4个字组成。即我们看到的:80FF FFFF FFFF FFFF,这组数据记录了从0一4的里程数。, G5 L4 Q4 C! j. R
如:0km FFFF FFFF FFFF FFFF
8 q, Y+ ]) D! `6 }# t, T- C- O如:lkm 80FF FFFF FFFF FFFF
& N* r+ x/ j; o Z如:2km 80FF 80FF FFFF FFFF
1 s2 `$ ~+ X3 Y4 N' w: u如:3km 80FF 80FF 80FF FFFF: j0 ? v- l/ ]( c% h
如:4km 80FF 80FF 80FF 80FF: T' w3 U9 }9 z9 l g Q
即是有几个80FF就为几km。% H& k% O( G1 M( \# D
那么超过了4km是怎么记录的呢?6 \9 l/ Z4 c# }. h i8 R/ y1 I* L
那就是后半部的数据了。在后半部的数据中我们看到了重复了3次的“7A8B F6FF”,这三组数据代表的数值都是一样的,只是为了提高数据的可靠性而重复记录了3次,在修改数据时我们必须把三组数据同时修改,且其数值都必须一样。; f6 } d) B8 c1 c
现在我们来分析一下这组数据的含义。首先我们先看一下下面的这个数据转换表:
2 V8 w2 M' I: c4 S6789ABCDEF
- x( X" N* g# `- K6 d5 n││││││││││ & L, i6 a+ T% `
9876543210
/ q2 Y" w. m: `$ I/ l( v m 对照上表我们可以把数据:7A8B F6FF转换为:8574 0900。
- {; r* N/ d3 u 在8574 0900这组数据中它们的排列方式为:[十位][个位][千位][百位][十万位][万
* U/ E" S% D {1 Z. b位][千万位][百万位]。6 i0 H; I& Z/ L1 z1 r
我们将它们按我们日常的记数顺序重新排列一下,可得到:00097485。5 _3 U) D- \0 W/ E
97485加上前面一个80FF代表的lkm,那么可得到公里数为97486km。3 \. X% Q4 l: s3 V$ X$ V
为了让大家加深印象,我再举例儿个里程数据:
; E5 g1 s: j' h6 w+ n" m 80FF FFFF FFFF FFFF EF78 FFFF EF78 FFFF EF78 FFFF:8710+1=8711km" w/ M7 W$ v5 v5 m; i* {
80FF 80FF FFFF FFFF FFFF EFFF FFFF FFFF FFFF FFFF:10+2=12km
! a0 F" V& }, A- n% @$ ~ FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF FFFF:0+0=0km5 j9 f9 W$ y" C$ v) O. J
80FF FFFF FFFF FFFF 669A E8FF 669A E8FF 669A E8FF:176599+1=176600km
2 K0 ^! j2 M* j5 O 80FF 80FF 80FF FFFF FFCF 69FF FFCF 69FF FFCF 69FF :963000+3=963003km0 f0 G, h. l9 ]' g# C, w8 Y
80FF 80FF 80FF 80FF CAFF FFFF CAFT FFFF CAFF FFFF :35+4=39km0 `" K! A: J3 e9 o4 x d$ ~
注:
2 s! ^! V! E, r. E) J, m ①在某些丰田车中以FF80代替80FF;
+ d% t2 p* d- `+ c& A; T ②在某些车中每个80FF代表2km;
9 C4 [4 f' p5 c1 h( t! m/ `9 _, C ③在调表时建议大家可以把前半部数据都改为FFFF,只需修改后半部三组数据,可以简化计算。
% M# e; |7 C: E3 l 此算法适用车型:1997至2000年款丰田佳美、1998款至2000年凌志LS400、1996至2000款凌志ES300、1997至2000年款Gs300,以及部分其他车型。
' C" O2 c" a1 } 3.别克轿车仪表算法8 H( B9 J4 Y) R/ J6 c# r! E) m, U
例:芯片型号:25010 里程数:157388 km
) m% V6 t7 y& j 00000000 02 FC FF FF FF FF 00 FF FF FF FF FF 02 FC FF FF……) h, f% D7 r6 d; A$ ]& {- z& U
00000010 FF FF 00 FF FF FF FF FF 02 FC FF FF FF FF 00 FF……
) V/ q. |- x2 G2 c7 r( b 00000020 FF FF FF FF 22 2D 22 00 16 16 06 00 F5 F5 22 00…"-"……".
* m8 f! x4 [. e; o( e 00000030 EA F5 22 55 00 75 78 89 04 07 24 3D 01 40 19 23.."U.ux...$=.@.#
' a( k5 C4 J4 s, j 00000040 00 00 91 00 00 00 00 00 00 00 00 00 00 00 00 00................
6 c4 Z: U: @4 e2 B9 E$ A 00000050 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00.................) d+ {* O) q/ J3 \" E t; F- q
00000060 00 00 00 00 00 00 00 00 00 00 00 00\'00 00 00 00.................5 A8 w4 Y8 B. G3 k" l" _
00000070 00 00 00 00 00 00 00 00 00 00 00 00 00 78 83 50.............x.P
- k9 j; h# ^* A5 k9 U; J( u 00000080 FF
- o2 e% [) l% ?* V 数据重复3次。
$ t- a8 z: E' p3 E9 ?! j$ \从地址0000开始到地址000B结束为第1次。
# R2 W& {/ ~+ ~4 a( ]. ^! @从地址000C开始到地址0017结束为第2次。
9 V4 r( s3 w1 l* E5 l5 J; z从地址0018开始到地址0023结束为第3次。 [6 \% J( g% U" A7 I; q k* [
其中02 FC×206为里程数:02FCH = 764D 764×206=157384 km。' ?1 j0 b: O4 w7 A( u1 l8 r8 k2 i( s" B
FF FF FF FF 00 FF FF FF FF FF必须有一个00字节。
; l7 [5 r% I7 C" p, P, n& M, @00字节数据位置的确定方法:公里数mod 206=XXX(第一个位置为0)
. V7 P6 o" A( C这里XXX就是00的位置。在这个例子中XXX=4=157388 mod 2060 Y) n+ N0 w1 [1 }4 y0 v" `5 g( B) u
(第一个位置为0)其他数据必须保持为FF' r" O+ R9 H F3 g' H
所以公里数为:157384+4=157388 km。 [9 e- g$ v0 U) \, g. ^
(说明:mod表示取余数操作。5 mod 3=2。100 mod 33=1) $ \9 u: k; Y& f7 F
+ u5 h0 q1 D+ ]- P
|