當前位置: 首頁>>代碼示例>>Java>>正文


Java MMapDirectory.open方法代碼示例

本文整理匯總了Java中org.apache.lucene.store.MMapDirectory.open方法的典型用法代碼示例。如果您正苦於以下問題:Java MMapDirectory.open方法的具體用法?Java MMapDirectory.open怎麽用?Java MMapDirectory.open使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.lucene.store.MMapDirectory的用法示例。


在下文中一共展示了MMapDirectory.open方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: main

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
/**
	 * @param args
	 * @throws IOException
	 */
	public static void main(String[] args) throws IOException {
		if (args.length != 2) {
			System.err
					.println("Incorrect number of arguments; expected <index_dir> <query_number>");
		}
		String indexDir = args[0];
		int i = Integer.parseInt(args[1]);
		Queries queries = new Queries();
		Directory directory = MMapDirectory.open(new File(indexDir));
		DirectoryReader reader = DirectoryReader.open(directory);
		TermFreqAnalyzer termFreqAnalyzer = new TermFreqAnalyzer(reader,
				queries.getQuery(i));
		termFreqAnalyzer.printAvgTf();
		termFreqAnalyzer.printAvgTfInDocsWithAllTerms();
		reader.close();
//		directory.close();
	}
 
開發者ID:arne-cl,項目名稱:fangorn,代碼行數:22,代碼來源:TermFreqAnalyzer.java

示例2: advancedTest

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
@Test
public void advancedTest() throws IOException {
	File indexFile = new File("data", "test3");
	FSDirectory directory = MMapDirectory.open(indexFile.toPath());

	LuceneObjectKVS<Integer, Sample> kvs = new LuceneObjectKVS<>(directory, indexFile, true);

	Sample sample = new Sample();
	sample.name = "hoge";
	sample.age = 10;

	kvs.put(1, sample);
	kvs.put(2, sample);

	// get object
	Sample actual = kvs.get(1);
	assertEquals(sample.name, actual.name);

	// iterator
	Iterator<Entry<Integer, Sample>> ite = kvs.iterator();
	while(ite.hasNext()) {
		ite.next();
	}

	kvs.close();
}
 
開發者ID:ksgwr,項目名稱:LuceneDB,代碼行數:27,代碼來源:LuceneObjectKVSTest.java

示例3: getTaxoWriter

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
public DirectoryTaxonomyWriter getTaxoWriter(int segmentNumber) throws IOException {

		Directory d;

		if (indexConfig.getIndexSettings().getStoreIndexOnDisk()) {
			d = MMapDirectory.open(getPathForFacetsIndex(segmentNumber));
		}
		else {
			String indexSegmentDbName = getIndexSegmentDbName(segmentNumber);
			String indexSegmentCollectionName = getIndexSegmentCollectionName(segmentNumber) + "_facets";
			MongoDirectory mongoDirectory = new MongoDirectory(mongo, indexSegmentDbName, indexSegmentCollectionName, clusterConfig.isSharded(),
					clusterConfig.getIndexBlockSize());
			d = new DistributedDirectory(mongoDirectory);
		}

		NRTCachingDirectory nrtCachingDirectory = new NRTCachingDirectory(d, 2, 10);

		return new DirectoryTaxonomyWriter(nrtCachingDirectory);
	}
 
開發者ID:lumongo,項目名稱:lumongo,代碼行數:20,代碼來源:LumongoIndex.java

示例4: SpokendocBaseline

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
/**
 *  
 * @param propatiesPath 設定ファイル.propertiesのパス
 * @throws IOException
 */
public SpokendocBaseline(String propatiesPath) throws IOException {
	Properties conf = new Properties();
	FileInputStream fis = new FileInputStream(new File(propatiesPath));
	conf.load(fis);
	this.analyzer = new WhitespaceAnalyzer(Version.LUCENE_46);
	this.task = conf.getProperty("task");
	this.freqfilePath = conf.getProperty("freqfile");
	this.tokenizerPath = conf.getProperty("tokenizer");
	this.resultPath = conf.getProperty("result");
	this.normalization = new Boolean(conf.getProperty("normalization"));
	//メモリにインデックス保存する。テスト用
	//this.directory = new RAMDirectory();
	//MMapDirectory: 読み込みはメモリ、書き出しはファイルシステムらしい
	String indexPath = conf.getProperty("index");
	this.indexDirectory = MMapDirectory.open(new File(indexPath));

	String selectedSimilarity = conf.getProperty("similarity");
	if (selectedSimilarity.equals("LMDirichlet")) {
		float mu = Float.valueOf(conf.getProperty("mu"));
	    this.similarity = new LMDirichletSimilarity(mu);
	}
	else if (selectedSimilarity.equals("BM25")) {
		float k1 = Float.valueOf(conf.getProperty("k1"));
		float b = Float.valueOf(conf.getProperty("b"));
	    this.similarity = new BM25Similarity(k1, b);
	}
	else {
	    this.similarity = new DefaultSimilarity();	
	}
	fis.close();
}
 
開發者ID:Kesin11,項目名稱:Spokendoc-Baseline,代碼行數:37,代碼來源:SpokendocBaseline.java

示例5: convert

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
/**
 * Transform the index at source to the destination, adjusting DocValues for the given adjustFields underway.
 * @param source       the location of an existing index.
 * @param destination  where the adjusted index should be stored.
 * @param dvConfigs the fields to adjust. Use {@link #getDVConfigs(java.io.File)} to obtain the
 *                         original setup.
 */
public static void convert(
        File source, File destination, Collection<DVConfig> dvConfigs) throws IOException {
    log.info("Converting index at " + source + " to " + destination + " with " + dvConfigs.size()
             + " DocValues adjustment fields");
    final long startTime = System.nanoTime();

    DirectoryReader inner = DirectoryReader.open(MMapDirectory.open(source));
    final long afterInner = System.nanoTime();
    log.info("Opened standard reader(" + source + ") in " + (afterInner-startTime)/M + "ms");

    IndexReader dvReader = new DVDirectoryReader(inner, new HashSet<>(dvConfigs));
    final long afterWrapper = System.nanoTime();
    log.info("Opened DVWrapper(" + source + ") in " + (afterWrapper-afterInner)/M + "ms");

    Analyzer analyzer = new StandardAnalyzer(LUCENE_VERSION);
    IndexWriter writer = new IndexWriter(
            MMapDirectory.open(destination), new IndexWriterConfig(LUCENE_VERSION, analyzer));
    final long afterWriterCreation = System.nanoTime();
    log.info("Created writer(" + destination + ") in " + (afterWriterCreation-afterWrapper)/M + "ms");

    writer.addIndexes(dvReader);
    final long afterConversion = System.nanoTime();
    log.info("Converted index(" + destination + ") in " + (afterConversion-afterWriterCreation)/M + "ms");

    writer.commit();
    final long afterCommit = System.nanoTime();
    log.info("Finished commit(" + destination + ") in " + (afterCommit - afterCommit) / M + "ms");

    // No need for optimize as the addIndexes + commit ensures transformation
    writer.close();
    dvReader.close();
    log.info("All done. Total time " + (System.nanoTime() - startTime) / M + "ms");
}
 
開發者ID:netarchivesuite,項目名稱:dvenabler,代碼行數:41,代碼來源:IndexUtils.java

示例6: testCreateAndReadWrappedIndex

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
public void testCreateAndReadWrappedIndex() throws IOException, ParseException {
    log.info("testCreateAndReadPlainIndex started");
    final File INDEX = generateIndex();

    try {
        Directory directory = MMapDirectory.open(INDEX);
        IndexReader reader = new DVDirectoryReader(
                DirectoryReader.open(directory), createDVFieldDescriptions(INDEX));
        IndexSearcher searcher = new IndexSearcher(reader);

        assertIndexValues(reader, searcher, true);
    } finally {
        delete(INDEX);
    }
}
 
開發者ID:netarchivesuite,項目名稱:dvenabler,代碼行數:16,代碼來源:DVReaderTest.java

示例7: CorrectnessTest

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
public CorrectnessTest() throws IOException {
	Directory directory = MMapDirectory.open(new File(INDEX_DIR));
	reader = DirectoryReader.open(directory);
}
 
開發者ID:arne-cl,項目名稱:fangorn,代碼行數:5,代碼來源:CorrectnessTest.java

示例8: DocIterPerformanceTest

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
public DocIterPerformanceTest(String indexDir) throws IOException {
	Directory directory = MMapDirectory.open(new File(indexDir));
	reader = DirectoryReader.open(directory);
}
 
開發者ID:arne-cl,項目名稱:fangorn,代碼行數:5,代碼來源:DocIterPerformanceTest.java

示例9: DocPosIterPerformanceTest

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
public DocPosIterPerformanceTest(String indexDir, LRDP lrdp)
		throws IOException {
	this.lrdp = lrdp;
	Directory directory = MMapDirectory.open(new File(indexDir));
	reader = DirectoryReader.open(directory);
}
 
開發者ID:arne-cl,項目名稱:fangorn,代碼行數:7,代碼來源:DocPosIterPerformanceTest.java

示例10: NumComparisonsTest

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
public NumComparisonsTest(String indexDir) throws IOException {
	Directory directory = MMapDirectory.open(new File(indexDir));
	reader = DirectoryReader.open(directory);
}
 
開發者ID:arne-cl,項目名稱:fangorn,代碼行數:5,代碼來源:NumComparisonsTest.java

示例11: CacheEffectTest

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
public CacheEffectTest(String indexDir, PhysicalPayloadFormat ppf) throws IOException {
	lrdp = new LRDP(ppf);
	Directory directory = MMapDirectory.open(new File(indexDir));
	reader = DirectoryReader.open(directory);
}
 
開發者ID:arne-cl,項目名稱:fangorn,代碼行數:6,代碼來源:CacheEffectTest.java

示例12: generateIndex

import org.apache.lucene.store.MMapDirectory; //導入方法依賴的package包/類
private static File generateIndex(int documents) throws IOException {
    final File INDEX = new File("target/testindex.deletefreely." + documents);
    final long seed = new Random().nextLong();
    Random random = new Random(seed);
    log.info("Testing with random seed" + seed);
    Analyzer analyzer = new StandardAnalyzer(LUCENE_VERSION);

    final FieldType SINGLE_F = new FieldType();
    SINGLE_F.setIndexed(true);
    SINGLE_F.setStored(true);

    final FieldType MULTI_F = new FieldType();
    MULTI_F.setIndexed(true);
    MULTI_F.setStored(true);

    final FieldType SEARCH_F = new FieldType();
    SEARCH_F.setIndexed(true);

    final FieldType LONG_F = new FieldType();
    LONG_F.setIndexed(true);
    LONG_F.setStored(true);
    LONG_F.setNumericType(FieldType.NumericType.LONG);

    final FieldType DOUBLE_F = new FieldType();
    DOUBLE_F.setIndexed(true);
    DOUBLE_F.setStored(true);
    DOUBLE_F.setNumericType(FieldType.NumericType.DOUBLE);

    IndexWriter indexWriter = new IndexWriter(
            MMapDirectory.open(INDEX), new IndexWriterConfig(LUCENE_VERSION, analyzer));
    for (int docID = 0 ; docID < documents ; docID++) {
        Document document = new Document();
        document.add(new Field(ID, Integer.toString(docID), SINGLE_F));
        document.add(new Field(SEARCH, SEARCH_CONTENT + "_" + docID, SEARCH_F));
        if (random.nextInt(5) > 0) {
            document.add(new Field(SINGLE, SINGLE_CONTENT + "_r" + random.nextInt(), SINGLE_F));
        }
        if (random.nextInt(5) > 0) {
            document.add(new Field(MULTI, MULTI_CONTENT_1 + "_" + docID, MULTI_F));
            if (random.nextInt(3) > 0) {
                document.add(new Field(MULTI, MULTI_CONTENT_2 + "_random" + random.nextInt(5), MULTI_F));
            }
        }
        if (random.nextInt(5) > 0) {
            document.add(new LongField(LONG, random.nextLong(), LONG_F));
        }
        if (random.nextInt(5) > 0) {
            document.add(new DoubleField(DOUBLE, random.nextDouble(), DOUBLE_F));
        }
        indexWriter.addDocument(document);
        if (docID == documents / 3) {
            indexWriter.commit(); // Ensure multi-segment
        }
    }
    indexWriter.commit();
    indexWriter.close();
    return INDEX;
}
 
開發者ID:netarchivesuite,項目名稱:dvenabler,代碼行數:59,代碼來源:DVReaderTest.java


注:本文中的org.apache.lucene.store.MMapDirectory.open方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。