n=12、m=3
n=2、m=13
n=1、m=14
とか変なデータがある。そこで、小数点位置を任意に指定できる10進変換関数はないかと探すが、ないみたい。
Decimalという関数の説明ページにたどり着いて、穴が開くほど読んでいたが、解決に至らない。
Python で小数点対応の N 進数から 10 進数に変換するプログラムを書いた
というページを見つけた。汎用関数になっているので、2進数を10進に変換するだけなので、小数部分の変換を書いてみた。from decimal import *
data ='110'
sum0 =Decimal(0)
for (i,x) in enumerate(data) :
sum0 += Decimal(x)*Decimal(2**(-(i+1)))
print (data,sum0)
内包表現にしてみた。
fractional =sum([(float(Decimal(x)*Decimal(2**(-(i+1))))) for (i,x) in enumerate(data)])
これ1行見たら、翌日にはどうやって変換しているかわからない.
- 小数点第1位を取り出し、2^-1すると0.5が得られる。それにその数字を乗じる。1なら0.5、0なら0。
- 小数点第2位を取り出し、2^-2すると0.25が得られる。それにその数字を乗じる。1なら0.25、0なら0。
それを桁数分繰り返す。
floatで実数として取り出す。取り出したのはリスト形式。なのでsumで合計を求める。
永久に1を超えられない数値が求まる。
関数にした。16ビット限定だと。16進のデータdatahex(ex。0xb3f9)と、整数部分のビット数integer(ex。12)を引数に呼び出す。
def kotei(datahex,integer) : if (datahex & 0b1000000000000000 ) : I1=(~datahex ^ 0xffff) I0=bin(datahex)[3:(3+integer)] Integer=-(int(I0,2) ^ int(("1"*integer),2)) F0= bin(I1)[(2+integer):] Fractional =-sum([(float(Decimal(x)*Decimal(2**(-(i+1))))) for (i,x) in enumerate(F0)]) else: Integer=(datahex & 0b0111111111111111 )>> (15-integer) fdata3=str(bin((datahex & 0b0111111111111111 ) & int( '1' * (15-integer),2)))[2:] Fractional =sum([(float(Decimal(x)*Decimal(2**(-(i+1))))) for (i,x) in enumerate(fdata3)]) #print Integer,Fractional,(Integer+Fractional) return(Integer+Fractional)Integerは整数部分。負のときは反転し、LSBに1ビット足す。正のときは小数部分の桁分右にシフトするだけ。
fdata3は小数部の1,0を文字列で切り出す。
Fractionalは、小数点の演算。
整数部と小数部を加算して終了。
0 件のコメント:
コメントを投稿