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

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

?? hnsrtreefileobj.hh

?? SR-tree is an index structure for high-dimensional nearest neighbor queries
?? HH
?? 第 1 頁 / 共 2 頁
字號:
/*
 * HnSRTreeFileObj.hh
 * Copyright (C) 1997 Norio Katayama
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Library General Public
 * License as published by the Free Software Foundation; either
 * version 2 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Library General Public License for more details.
 *
 * You should have received a copy of the GNU Library General Public
 * License along with this library; if not, write to the Free
 * Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
 * MA 02111-1307, USA
 *
 * 03/20/96 katayama@rd.nacsis.ac.jp
 * $Id: HnSRTreeFileObj.hh,v 1.15 2002/09/13 17:21:25 katayama Exp $
 */

#ifndef _HnSRTreeFileObj_hh
#define _HnSRTreeFileObj_hh

#include "HnSRTree/HnObject.hh"
#include "HnSRTree/HnStatistics.hh"
#include "HnSRTree/HnBlockFile.hh"
#include "HnSRTree/HnSRTreeInfo.hh"
#include "HnSRTree/HnSRTreeBlock.hh"
#include "HnSRTree/HnSRTreeNode.hh"
#include "HnSRTree/HnSRTreeLeaf.hh"
#include "HnSRTree/HnSRTreeStack.hh"
#include "HnSRTree/HnSRTreeReinsert.hh"
#include "HnSRTree/HnSRTreeNeighbor.hh"
#include "HnSRTree/HnFTlongArray.hh"

/*{
#include "HnSRTree/HnPoint.hh"
#include "HnSRTree/HnDataItem.hh"
#include "HnSRTree/HnProperties.hh"
#include "HnSRTree/HnSphere.hh"
#include "HnSRTree/HnRect.hh"
#include "HnSRTree/HnSRTreeProto.h"
#include "HnSRTree/HnSRTreeProfileSt.h"
}*/

class HnSRTreeQueryRegion {
public:
    virtual HnBool overlaps(const HnSRTreeCluster &cluster) const = 0;
    virtual HnBool includes(const HnPoint &point) const = 0;
    virtual ~HnSRTreeQueryRegion(void) {};
};

class HnSRTreeFileObj: public HnObject {
private:
    /* split flag */
    enum SplitFlag { LEFT, RIGHT, SPLIT_NONE };

    /* reinsert flag */
    enum ReinsertFlag { REINSERT, STAY, REINSERT_NONE };

    struct REntry {
	HnSRTreeBlock::Type type;
	HnSRTreeNode node;
	HnSRTreeLeaf leaf;
	int level;

	REntry() {
	    type = HnSRTreeBlock::FREE;
	    node = HnSRTreeNode::null;
	    leaf = HnSRTreeLeaf::null;
	    level = -1;
	}
	REntry(const REntry &entry) {
	    type = entry.type;
	    node = entry.node;
	    leaf = entry.leaf;
	    level = entry.level;
	}
	REntry &operator=(const REntry &entry) {
	    type = entry.type;
	    node = entry.node;
	    leaf = entry.leaf;
	    level = entry.level;
	    return *this;
	}
    };

private:
    HnBlockFile blockFile;

    HnSRTreeInfo info;

    struct context_s {
	HnSRTreeStack stack;
	HnSRTreeQueryRegion *queryRegion;
    } context;

    HnSRTreeReinsertVector reinsertList;
    HnFTlongVector reinsertedBlocks;

    HnSRTreeProfileSt *profile;

    /* initialize */
    void initialize(void) {
	context.queryRegion = NULL;
	profile = HnSRTreeProfileSt_allocate();
    }
    void dispose(void) {
	HnSRTreeProfileSt_free(profile);
    }

    /* properties */
    HnProperties getOverriddenProperties(const HnProperties &properties) const;
    void parseProperties(const HnProperties &properties,
			 int dimension,
			 int *blockSize_return,
			 int *splitFactor_return,
			 int *reinsertFactor_return,
			 HnSRTreeInfo::StaticAlgorithm *staticAlgorithm_return,
			 HnSRTreeInfo::NonLeafFloatType *
			 nonLeafFloatType_return,
			 HnSRTreeInfo::NeighborAlgorithm *
			 neighborAlgorithm_return);

    static HnSRTreeInfo::StaticAlgorithm
        stringToStaticAlgorithm(const HnString &value);
    static HnString
        staticAlgorithmToString(HnSRTreeInfo::StaticAlgorithm value);

    static HnSRTreeInfo::NonLeafFloatType
        stringToNonLeafFloatType(const HnString &value);
    static HnString
        nonLeafFloatTypeToString(HnSRTreeInfo::NonLeafFloatType value);

    static HnSRTreeInfo::NeighborAlgorithm
        stringToNeighborAlgorithm(const HnString &value);
    static HnString
        neighborAlgorithmToString(HnSRTreeInfo::NeighborAlgorithm value);

    /* super block */
    void writeSuperBlock(void);
    void readSuperBlock(void);

    /* block */
    HnSRTreeBlock readBlock(long offset);
    void writeBlock(const HnSRTreeBlock &block);
    long allocateBlock(void);
    void releaseBlock(long offset);

    /* leaf */
    void writeLeaf(const HnSRTreeLeaf &leaf);
    HnSRTreeLeaf allocateLeaf(void);

    /* node */
    void writeNode(const HnSRTreeNode &node);
    HnSRTreeNode allocateNode(void);

    /* store */
    void insertPoint(const HnPoint &point, const HnDataItem &dataItem);
    void insertBlock(long offset, int level);
    HnSRTreeStack chooseLeaf(const HnPoint &point);
    int chooseSubtree(const HnSRTreeNode &node, const HnPoint &point);
    HnSRTreeStack chooseNode(const HnPoint &centroid, int level);
    void updateCluster(HnSRTreeStack stack);

    void reinsertLeaf(HnSRTreeStack &stack,
		      const HnPoint &newPoint, const HnDataItem &newDataItem);
    void selectPoints(const HnPointArray &points, ReinsertFlag **flags_return);
    void reinsertNode(HnSRTreeStack &stack,
		      const HnSRTreeCluster &newCluster, long newOffset);
    void selectClusters(const HnSRTreeClusterArray &clusters,
			ReinsertFlag **flags_return);

    void splitLeaf(HnSRTreeStack &stack,
		   const HnPoint &newPoint, const HnDataItem &newDataItem);
    void splitNode(HnSRTreeStack &stack,
		   const HnSRTreeCluster &newCluster, long newOffset);

    void updateNode(HnSRTreeStack &stack,
		    const HnSRTreeCluster &leftCluster, long leftOffset,
		    const HnSRTreeCluster &rightCluster, long rightOffset);
    void extendTree(const HnSRTreeCluster &leftCluster, long leftOffset,
		    const HnSRTreeCluster &rightCluster, long rightOffset);

    /* split */
    void splitPoints(const HnPointArray &points, SplitFlag **flags_return);
    void splitClusters(const HnSRTreeClusterArray &clusters,
		       SplitFlag **flags_return);

    /* construction */
    void searchPoint(const HnPointVector &points, int offset, int count,
		     double keyCoord, int axis, int order,
		     HnBool *found_return, int *index_return);
    void searchCluster(const HnSRTreeClusterVector &clusters,
		       int offset, int count,
		       double keyCoord, int axis, int order,
		       HnBool *found_return, int *index_return);
    void selectPoint(HnPointVector &points, HnDataItemVector &dataItems,
		     int offset, int count, int axis, int index);
    void selectCluster(HnSRTreeClusterVector &clusters,
		       HnFTlongVector &offsets,
		       int offset, int count, int axis, int index);
    void sortPoints(HnPointVector &points, HnDataItemVector &dataItems,
		    int offset, int count, int sortDimension);
    void sortClusters(HnSRTreeClusterVector &clusters, HnFTlongVector &offsets,
		      int offset, int count, int sortDimension);
    int getMaxVarianceAxis(HnPointVector &points, int offset, int count);
    int getMaxVarianceAxis(HnSRTreeClusterVector &clusters,
			   int offset, int count);

    /* construction (VAM) */
    void constructTree_VAM(HnPointVector &points, HnDataItemVector &dataItems);
    REntry CreateVAMSRTree(HnPointVector &points, HnDataItemVector &dataItems);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久亚洲欧洲日产国码αv| 欧美国产精品久久| 日韩欧美在线一区二区三区| 久久女同性恋中文字幕| 一区二区三区久久| 久久电影国产免费久久电影| 色94色欧美sute亚洲线路二| 日韩一区二区精品在线观看| 日本一区二区久久| 亚洲国产精品国自产拍av| 亚洲欧美精品午睡沙发| 视频一区二区三区中文字幕| 国产精品一区二区三区乱码 | 99久久久久久| 欧美人与禽zozo性伦| xnxx国产精品| 亚洲午夜免费电影| 国产高清成人在线| 欧美日韩免费一区二区三区视频| 久久这里只精品最新地址| 亚洲三级久久久| 国产一区二区三区在线观看精品| 色域天天综合网| 精品福利二区三区| 亚洲成人av一区| av亚洲精华国产精华| 欧美成人r级一区二区三区| 亚洲激情五月婷婷| 成人午夜大片免费观看| 91 com成人网| 亚洲午夜电影在线| 99久久精品免费看| 久久久久成人黄色影片| 日韩av在线发布| 91黄色免费看| 中文字幕亚洲精品在线观看| 国产一区二区精品久久91| 欧美日韩一区二区不卡| 亚洲精品国产高清久久伦理二区 | 久久精品在这里| 婷婷成人激情在线网| 99精品久久只有精品| 中文字幕免费一区| 国产高清亚洲一区| 日韩欧美中文字幕一区| 日韩av午夜在线观看| 欧美美女bb生活片| 亚洲一区在线免费观看| 91啪九色porn原创视频在线观看| 国产欧美日韩精品a在线观看| 蜜桃视频一区二区三区在线观看| 欧美日韩成人综合| 天天亚洲美女在线视频| 欧美性大战久久久久久久蜜臀| 亚洲色图.com| 97成人超碰视| 亚洲欧美日韩综合aⅴ视频| 99久久精品国产一区| 亚洲丝袜精品丝袜在线| 91亚洲精品久久久蜜桃网站| 亚洲欧美视频在线观看| 一本久道中文字幕精品亚洲嫩| 综合色天天鬼久久鬼色| 99免费精品视频| 综合久久国产九一剧情麻豆| 91蜜桃网址入口| 亚洲精品乱码久久久久久日本蜜臀| 91在线国产福利| 亚洲蜜桃精久久久久久久| 欧美怡红院视频| 日韩极品在线观看| 精品处破学生在线二十三| 国模娜娜一区二区三区| 日本一区二区三区四区在线视频| 蜜桃视频一区二区| 91精品国产手机| 伦理电影国产精品| 日韩欧美精品在线| 国产99久久久精品| 一区二区三区精品在线观看| 欧美日韩国产高清一区二区| 麻豆中文一区二区| 中文av一区二区| 色噜噜狠狠成人网p站| 日本亚洲三级在线| 国产视频一区在线播放| 91视频观看视频| 日韩av一区二区三区| 欧美激情一区二区三区不卡 | 欧美成人一区二区| 粗大黑人巨茎大战欧美成人| 亚洲国产乱码最新视频| 日韩限制级电影在线观看| 喷白浆一区二区| 国产精品国产成人国产三级| 欧美精品xxxxbbbb| 成人美女视频在线观看18| 亚洲chinese男男1069| 久久综合久久99| 成人激情午夜影院| 蜜桃av噜噜一区| 亚洲品质自拍视频网站| 久久久久久免费网| 欧美日韩中文字幕一区| 成人午夜视频在线观看| 日本欧美在线看| 中文字幕综合网| 精品国产凹凸成av人导航| 色欧美片视频在线观看在线视频| 麻豆精品久久久| 亚洲精品一二三区| 久久亚洲综合av| 欧美精品久久久久久久多人混战| 成人听书哪个软件好| 久久99国产精品免费| 一区二区三区日韩精品| 国产免费成人在线视频| 日韩一二三区视频| 欧美性色综合网| 94-欧美-setu| 国产精品一二三| 免费精品99久久国产综合精品| 亚洲午夜一区二区| 中文字幕在线视频一区| 亚洲精品在线免费播放| 日韩一区二区三免费高清| 在线中文字幕一区二区| 99久久99久久精品国产片果冻| 国产成人一级电影| 国产一区二区成人久久免费影院| 日韩专区中文字幕一区二区| 亚洲午夜在线电影| 亚洲一区二区视频在线观看| 国产精品传媒视频| 亚洲欧洲韩国日本视频| 亚洲欧洲三级电影| 国产精品色婷婷久久58| 国产亚洲1区2区3区| 久久久久99精品一区| 精品国产91九色蝌蚪| 久久久久久一级片| 国产精品三级电影| 国产精品剧情在线亚洲| 国产精品国产三级国产aⅴ中文| 国产欧美中文在线| 日本一区免费视频| 国产精品久久久久久久岛一牛影视| 国产欧美va欧美不卡在线| 国产精品每日更新在线播放网址| 国产精品国产a| 一区二区三区四区av| 天堂在线亚洲视频| 六月婷婷色综合| 国产福利不卡视频| av中文字幕在线不卡| 色香蕉成人二区免费| 欧美视频第二页| 日韩视频一区二区| 日本一区二区综合亚洲| 日韩美女视频19| 亚洲无人区一区| 久久国产精品色| 国产99一区视频免费| 色综合久久久网| 欧美日本精品一区二区三区| 日韩一级二级三级| 欧美国产国产综合| 亚洲精品乱码久久久久久日本蜜臀| 午夜精品视频在线观看| 韩国一区二区在线观看| 国产福利一区二区| 91一区二区在线观看| 欧美色老头old∨ideo| 国产亚洲欧美一区在线观看| 欧美国产丝袜视频| 亚洲成人免费观看| 国产精品羞羞答答xxdd| 日本乱人伦aⅴ精品| 欧美一区二区久久| 亚洲欧美在线aaa| 青椒成人免费视频| 成人av网址在线观看| 在线播放91灌醉迷j高跟美女 | 韩国av一区二区三区在线观看 | 欧美精彩视频一区二区三区| 一区二区三区日韩欧美| 精彩视频一区二区| 欧美亚男人的天堂| 精品奇米国产一区二区三区| 亚洲国产精品激情在线观看| 日韩电影在线看| 色8久久精品久久久久久蜜| wwww国产精品欧美| 亚洲一二三四区| 成人晚上爱看视频| 日韩欧美一区二区视频| 一区二区三区四区激情| 国产精品资源网站| 欧美一卡在线观看| 一区二区三区欧美日韩|