亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? rtentry.h

?? FastDb是高效的內存數據庫系統
?? H
字號:
// -*- Mode: C++ -*-

//           RTentry.h
//
// Copyright (c) 1996, Regents of the University of California
// $Header: /cvsroot/fastdb/fastdb/GiST/RTree/RTentry.h,v 1.1 2007/07/18 20:45:47 knizhnik Exp $

#ifndef RTENTRY_H
#define RTENTRY_H

#include <string.h>
#include <stdio.h>
#include <math.h>
#include <iostream.h>

#include "GiSTdefs.h"
#include "GiSTentry.h"

#ifndef MIN
#define MIN(x, y) ((x < y) ? (x) : (y))
#define MAX(x, y) ((x > y) ? (x) : (y))
#endif

class RTpredicate;
class RTnode;
class RTentry;

// RTkey is a rectangle represented as 4 doubles:
//   xlow, xhigh, ylow and yhigh
// We also throw in some standard geo operators to support various 
// query predicates, etc.

class RTkey : GiSTobject
{
public:
  friend RTentry;
  // constructors, destructors, assignment, etc.
  RTkey() {
    xl = yl = xh = yh = 0;
  }
  RTkey(const RTkey& k) {
    xl = k.xl;
    xh = k.xh;
    yl = k.yl;
    yh = k.yh;
  }
  RTkey(const double xl, const double xh, const double yl, const double yh):
    xl(xl), xh(xh), yl(yl), yh(yh) {
    }
  RTkey(char *s);
  GiSTobject *Copy() const { return new RTkey(*this); }

  ~RTkey() {
  }
  GiSTobjid IsA() { return RTKEY_CLASS; }
  
  RTkey& operator = (const RTkey& k) {
    xl = k.xl;
    xh = k.xh;
    yl = k.yl;
    yh = k.yh;
    return *this;
  }

  // bounding-box property and comparison methods
  int operator == (const RTkey& k) {
    return (xl == k.xl && xh == k.xh && yl == k.yl && yh == k.yh);
  }

  int overlap (const RTkey& k) {
    return(((xh >= k.xh && xl <= k.xh) ||
            (k.xh >= xh && k.xl <= xh)) &&
           ((yh >= k.yh && yl <= k.yh) ||
            (k.yh >= yh && k.yl <= yh)) );
  }

  int contained (const RTkey& k) {
    return((xh <= k.xh && xl >= k.xl &&
            yh <= k.yh && yl >= k.yl));
  }

  int contain(const RTkey& k) {
    return((xh >= k.xh && xl <= k.xl &&
            yh >= k.yh && yl <= k.yl));
  }

  double area() { return((xh-xl)*(yh-yl)); }

  // distance between the centers of two bounding boxes
  double dist(const RTkey& b) {
    return(sqrt(pow(fabs(((b.xh + b.xl)/2)-((xh + xl)/2)), 2) 
		+ pow(fabs(((b.yh + b.yl) - 2)-((yh + yl)/2)),2)));
  }

  // methods to form new bounding boxes out of existing ones
  RTkey *intersect(const RTkey& k) {
    RTkey *result;
    
    if (!overlap(k))
      return((RTkey *)NULL);  
    result = new RTkey(MAX(xl,k.xl), MIN(xh,k.xh), MAX(yl,k.yl), 
                       MIN(yh,k.yh));
      
    return(result);
  }

  // expand this bounding box to contain k
  RTkey *expand(const RTkey& k) {
    RTkey *result;

    result = new RTkey(MIN(xl, k.xl), MAX(xh, k.xh), MIN(yl, k.yl),
                       MAX(yh, k.yh));
    return(result);
  }

  // I/O methods
  void Print(ostream& os) const {
    os << '"';
    os << "(" << xl << "," << xh << "," << yl << "," << yh << ")";
    os << '"';
  }

  double xl; // x coordinate of left edge
  double xh; // x coordinate of right edge
  double yl; // y coordinate of bottom edge
  double yh; // y coordinate of top edge
};

inline ostream& operator<< (ostream& os, const RTkey& k) {
    k.Print(os);
    return os;
}

class GiSTpredicate;

class RTentry : public GiSTentry
{
friend RTpredicate;
  private:
    // cast key member to class RTkey *.  Prevents compiler warnings.
    RTkey &Key() const { return *(RTkey *)key; }
  public:
  // constructors, destructors, etc.
    RTentry() { }
    RTentry(const RTkey& k, const GiSTpage p) {
      key = (GiSTobject *)new RTkey(k);
      ptr = p;
    }
    RTentry(const RTentry& e) : GiSTentry(e) {
      key = (GiSTobject *)new RTkey(*(RTkey *)(e.key));
    }
    GiSTobjid IsA() const { return RTENTRY_CLASS; }
    GiSTobject *Copy() const { return new RTentry(*this); }
    void InitKey() { key = new RTkey; }
    int IsEqual(const GiSTobject& obj) const {
        if (obj.IsA() != RTENTRY_CLASS)
            return 0;
        const RTentry& rte = (const RTentry&) obj;
        return ((*((RTkey *)key) == (*((RTkey *)(rte.key)))));
    }

    // basic GiST methods
    GiSTpenalty *Penalty(const GiSTentry &newEntry) const;

    // Other methods we're required to supply
    int CompressedLength() const {
      return sizeof(RTkey);
    }

    // I/O methods
#ifdef PRINTING_OBJECTS
    void Print(ostream& os) const {
        key->Print(os);
        os << "->" << Ptr() << endl;
    }
#endif
    // access to private members
    const RTkey& bbox() const { return Key(); }
    double xlower() { return Key().xl; }
    double xupper() { return Key().xh; }
    double ylower() { return Key().yl; }
    double yupper() { return Key().yh; }
    void setxlower(double d) { Key().xl = d; }
    void setxupper(double d) { Key().xh = d; }
    void setylower(double d) { Key().yl = d; }
    void setyupper(double d) { Key().yh = d; }

};

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
26uuu久久综合| 依依成人精品视频| 1024精品合集| 久草中文综合在线| 欧美在线不卡一区| 国产欧美视频一区二区三区| 亚洲成av人片在线| 93久久精品日日躁夜夜躁欧美| 欧美v亚洲v综合ⅴ国产v| 亚洲综合男人的天堂| av中文一区二区三区| 久久青草国产手机看片福利盒子| 日本一区中文字幕| 欧美狂野另类xxxxoooo| 亚洲欧洲综合另类| 不卡高清视频专区| 欧美国产精品中文字幕| 国产一区二区在线免费观看| 3d动漫精品啪啪1区2区免费| 一区二区三区av电影| av资源网一区| 亚洲青青青在线视频| av中文字幕一区| 中文字幕亚洲一区二区av在线| 韩国中文字幕2020精品| 欧美不卡一区二区三区| 日本麻豆一区二区三区视频| 欧美日韩欧美一区二区| 亚洲国产一区在线观看| 欧美四级电影网| 午夜视黄欧洲亚洲| 欧美精品日韩一区| 蜜桃av一区二区| 日韩免费福利电影在线观看| 美女网站色91| 26uuu国产电影一区二区| 国产一区二区视频在线| 国产亲近乱来精品视频| 不卡视频在线看| 夜夜爽夜夜爽精品视频| 欧美日韩激情在线| 美女网站视频久久| 欧美激情一区二区三区在线| 不卡一卡二卡三乱码免费网站| 国产精品国产三级国产普通话蜜臀 | 成人精品亚洲人成在线| 国产精品萝li| 欧美做爰猛烈大尺度电影无法无天| 亚洲欧美另类久久久精品2019| 日本道色综合久久| 日韩高清电影一区| 久久综合色之久久综合| 97精品久久久午夜一区二区三区| 亚洲精品国产精华液| 欧美日韩国产片| 国产一区二区三区四区五区入口| 国产精品青草综合久久久久99| 色综合久久中文字幕| 日本午夜一本久久久综合| 日韩欧美资源站| 成人动漫一区二区三区| 亚洲综合免费观看高清完整版在线 | 天堂va蜜桃一区二区三区| 日韩欧美你懂的| 成人18精品视频| 青娱乐精品在线视频| 欧美激情中文不卡| 欧美日韩成人综合在线一区二区 | 日韩精品一区二区在线| 处破女av一区二区| 亚洲第一av色| 国产精品视频一区二区三区不卡| 欧美日韩久久久久久| 国产在线精品一区二区不卡了| 亚洲图片欧美激情| 欧美xxxxx裸体时装秀| 色94色欧美sute亚洲线路一久| 紧缚奴在线一区二区三区| 亚洲男人电影天堂| 欧美精品一区二区精品网| 欧美视频一区二区三区四区 | 一本到不卡免费一区二区| 美女mm1313爽爽久久久蜜臀| 专区另类欧美日韩| 久久综合九色综合97婷婷| 在线免费亚洲电影| 成人免费毛片片v| 另类小说图片综合网| 一区二区久久久| 国产精品电影一区二区| 欧美va亚洲va| 制服.丝袜.亚洲.另类.中文| 99久久精品免费精品国产| 激情偷乱视频一区二区三区| 午夜精品123| 夜夜爽夜夜爽精品视频| 亚洲视频你懂的| 国产精品色在线观看| 久久蜜桃av一区二区天堂| 日韩一卡二卡三卡四卡| 欧美午夜片在线看| 色狠狠色狠狠综合| 99精品国产热久久91蜜凸| 不卡av在线网| 成人做爰69片免费看网站| 国产精品996| 国产精品系列在线观看| 国产伦理精品不卡| 韩国成人精品a∨在线观看| 麻豆精品视频在线观看视频| 日韩在线观看一区二区| 日韩va欧美va亚洲va久久| 婷婷开心激情综合| 视频一区二区三区入口| 天天影视涩香欲综合网| 日韩电影免费在线| 免费亚洲电影在线| 久久 天天综合| 国产精品一线二线三线精华| 国产一区二区不卡老阿姨| 国产风韵犹存在线视精品| 国产大陆a不卡| 成年人午夜久久久| 91福利在线播放| 欧美日韩国产精选| 日韩免费高清视频| 国产日韩欧美精品一区| 国产精品久久久久久福利一牛影视| 国产日产亚洲精品系列| 亚洲欧美日韩国产综合在线| 一区二区三区在线观看网站| 三级欧美韩日大片在线看| 久久电影网站中文字幕| 国产成人激情av| 91啪亚洲精品| 69堂国产成人免费视频| 欧美成人精品二区三区99精品| 国产日韩欧美电影| 亚洲欧洲国产日本综合| 亚洲成国产人片在线观看| 麻豆成人91精品二区三区| 国产美女一区二区| 91福利在线播放| 精品乱码亚洲一区二区不卡| 国产精品久久久久久久浪潮网站 | 国产精品色一区二区三区| 一区二区三区美女| 免费看日韩精品| 风间由美一区二区三区在线观看 | 久久福利视频一区二区| 国产高清成人在线| 欧美在线短视频| 国产日韩在线不卡| 午夜视频在线观看一区二区三区| 国产一区二区三区黄视频| 色女孩综合影院| xfplay精品久久| 亚洲国产三级在线| 粉嫩av亚洲一区二区图片| 欧美午夜片在线观看| 欧美激情一区不卡| 日韩av一二三| 99国产欧美久久久精品| 欧美r级电影在线观看| 一区二区三区在线观看动漫| 国内精品视频666| 欧美唯美清纯偷拍| 国产精品二三区| 狠狠色丁香婷婷综合久久片| 在线观看精品一区| 亚洲国产经典视频| 黄色小说综合网站| 在线不卡一区二区| 亚洲一区免费在线观看| 成人免费看视频| 久久久www免费人成精品| 日韩精品电影一区亚洲| 欧美性大战久久久久久久| 成人免费视频在线观看| 国产精品一区久久久久| 日韩午夜激情电影| 婷婷六月综合网| 欧美午夜寂寞影院| 亚洲综合自拍偷拍| 色94色欧美sute亚洲线路一ni| 国产精品美女久久久久久久网站| 国精产品一区一区三区mba桃花 | 欧美伊人精品成人久久综合97| 日本一区二区三区免费乱视频| 蜜桃av一区二区| 欧美成va人片在线观看| 裸体一区二区三区| 欧美一级生活片| 美国三级日本三级久久99| 欧美日本一区二区三区四区| 亚洲一区在线观看网站| 欧美亚洲国产怡红院影院| 亚洲精品中文在线影院| 91免费国产视频网站| 亚洲精品v日韩精品|