1

私の目的のために、オブジェクトを保持するクラスを作成しました。

そのオブジェクトの実際の長さは、整数ではなく浮動小数点数です。異なる 2 つのオブジェクトが存在する可能性があります -- たとえば .00001 で、最短のオブジェクトが最適です。

便宜上、__len__len(obj) を呼び出せるようにクラス内にメソッドを定義しました。

ただし、Python では__len__浮動小数点数を返すことはできず、整数のみを返すことができます。

与えられた K に対して、int(real_length * 10**K) を返すことを考えました。

クラスオブジェクトの浮動小数点長を扱うためのより良い解決策はありますか?

編集:

私のクラスでは、n 次元空間に点があり、整数ではなく実数である点間の距離を考慮しています。

どうにかしてlen関数を利用できますか?

4

1 に答える 1

1

これにより、「文字列の長さ」機能が浮動小数点数に追加されます。オブジェクトの len() は、数値が文字列であるかのように数値の長さを返します

   class mynumber(float):
        def __len__(self):
            return len(self.__str__())
        pass    


    a=mynumber(13.7)
    b=mynumber(13.7000001)

    print len(a)
    print len(b)

Python 2.7 でテスト済み。お役に立てれば

あなたのコメントに基づいて、別の答えがあります。2 つの座標ペアを取り、haversine ( Haversine Formula in Python (Bearing and Distance between two GPS points) ) 式を使用して、それらの間の距離を求めるオブジェクトを設定します。

from math import radians, cos, sin, asin, sqrt

class mypointpair(object):
    def __init__(self):
        self.coord=[]
        pass
    def add_coords(self,a,b):
        self.coord.append((a,b)) 
    def __len__(self):
        return self.haversine(self.coord[0][0], self.coord[0][1], self.coord[1][0], self.coord[1][1])


    def haversine(self,lon1, lat1, lon2, lat2):
        """
        Calculate the great circle distance between two points 
        on the earth (specified in decimal degrees)
        """
        # convert decimal degrees to radians 
        lon1, lat1, lon2, lat2 = map(radians, [lon1, lat1, lon2, lat2])
        # haversine formula 
        dlon = lon2 - lon1 
        dlat = lat2 - lat1 
        a = sin(dlat/2)**2 + cos(lat1) * cos(lat2) * sin(dlon/2)**2
        c = 2 * asin(sqrt(a)) 
        km = 6367 * c
        return km 


pp1=mypointpair()
pp1.add_coords(53.32055555555556 , -1.7297222222222221 )
pp1.add_coords(53.31861111111111, -1.6997222222222223 )

print len(pp1)
于 2013-07-27T10:59:15.147 に答える