All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.rdf4j.rio.hdt.HDTTriplesSectionBitmap Maven / Gradle / Ivy

/*******************************************************************************
 * Copyright (c) 2020 Eclipse RDF4J contributors.
 *
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Distribution License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 *******************************************************************************/
package org.eclipse.rdf4j.rio.hdt;

import java.io.IOException;
import java.io.InputStream;

/**
 * HDT Triples section.
 * 

* This part contains two levels of bitmaps and arrays. *

* Typically (in SPO order), the Y-level corresponds to the predicates and the Z-level to the objects. *

* The X (subjects) is implicit since triples are already ordered by X, and bitmap Y is used to notify when there is a * new X: X will be used until a 1 is found in bitmap Y, which indicates that the next triple uses X+1. *

* The array contains numeric references to the predicates and objects in the HDT dictionaries, starting with the * entries in the "shared" {@link org.eclipse.rdf4j.rio.hdt.HDTDictionary Dictionary} These positions are counted * starting with 1, not 0. *

* E.g. Y-bitmap 0 1 1 and Y-array 1 2 3 results in S1-P1 S1-P2 S2-P3 *

*

* Structure: * *

 * +----------+----------+---------+---------+
 * | Bitmap Y | Bitmap Z | Array Y | Array Z |
 * +----------+----------+---------+---------+
 * 
* * @author Bart Hanssens */ class HDTTriplesSectionBitmap extends HDTTriplesSection { private HDTBitmap bitmapY; private HDTBitmap bitmapZ; private HDTArray arrY; private HDTArray arrZ; private int sizeY = 0; private int sizeZ = 0; private int posX = 1; private int posY = 0; private int posZ = 0; @Override public boolean hasNext() { // we only need to check if we've reach the end of the "lowest" level return posZ < sizeZ; } @Override public int[] next() { int z = arrZ.get(posZ); int y = arrY.get(posY); int x = posX; if (bitmapZ.get(posZ) == 1 && posZ < sizeZ) { // move to next Y position (predicate) when there is no Z (predicate) left if (bitmapY.get(posY) == 1 && posY < sizeY) { // move to next X position (subject) when there is no Y (predicate) left posX++; } posY++; } posZ++; return new int[] { x, y, z }; } @Override void parse(InputStream is) throws IOException { parse(is, HDTTriples.Order.SPO); } @Override void parse(InputStream is, HDTTriples.Order order) throws IOException { bitmapY = new HDTBitmap(); bitmapY.parse(is); sizeY = bitmapY.size(); bitmapZ = new HDTBitmap(); bitmapZ.parse(is); sizeZ = bitmapZ.size(); arrY = HDTArrayFactory.parse(is); arrY.parse(is); arrZ = HDTArrayFactory.parse(is); arrZ.parse(is); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy