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


Java AxesMetadata.setAxis方法代碼示例

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


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

示例1: testAxesMetadataReshape

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
@Test
public void testAxesMetadataReshape() throws MetadataException {
	final int[] shape = new int[] { 1, 2, 3, 1 };
	final int[] reshape = new int[] { 1, 1, 2, 3, 1 };

	int r = shape.length;
	int[] nShape = new int[r];
	AxesMetadata amd = MetadataFactory.createMetadata(AxesMetadata.class, r);
	for (int i = 0; i < r; i++) {
		Arrays.fill(nShape, 1);
		nShape[i] = shape[i];
		DoubleDataset array = Random.randn(nShape);
		amd.setAxis(i, array);
	}
	ILazyDataset dataset = Random.lazyRand(Dataset.INT32, "Main", shape);
	dataset.addMetadata(amd);
	dataset.setShape(reshape);
}
 
開發者ID:eclipse,項目名稱:january,代碼行數:19,代碼來源:AxesMetadataTest.java

示例2: testAxesMetadataTranspose

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
@Test
public void testAxesMetadataTranspose() throws Exception {
	final int[] shape = new int[] { 1, 2, 3, 4 };
	int r = shape.length;
	int[] nShape = new int[r];
	AxesMetadata amd = MetadataFactory.createMetadata(AxesMetadata.class, r);
	for (int i = 0; i < r; i++) {
		Arrays.fill(nShape, 1);
		nShape[i] = shape[i];
		DoubleDataset array = Random.randn(nShape);
		amd.setAxis(i, array);
	}

	Dataset dataset = Random.rand(shape);
	dataset.addMetadata(amd);

	int[] map = new int[] {3, 1, 2, 0};
	Dataset t = dataset.getTransposedView(map);
	assertArrayEquals(new int[]{4, 2, 3, 1}, t.getShape());
	amd = t.getMetadata(AxesMetadata.class).get(0);

	for (int i = 0; i < r; i++) {
		ILazyDataset a = amd.getAxis(i)[0];
		assertEquals(shape[map[i]], a.getSize());
	}
}
 
開發者ID:eclipse,項目名稱:january,代碼行數:27,代碼來源:AxesMetadataTest.java

示例3: testSliceFromView

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
@Test
public void testSliceFromView() throws DatasetException {
	final int[] shape = new int[] { 3, 10, 11};
	final int[] ashape = new int[] {3};
	
	ILazyDataset dataset = Random.lazyRand(Dataset.INT32, "Main", shape);
	ILazyDataset ax = Random.lazyRand(Dataset.INT32, "Axis", ashape);
	
	AxesMetadata amd = MetadataFactory.createMetadata(AxesMetadata.class, shape.length);
    amd.setAxis(0, ax);
    dataset.setMetadata(amd); 
    
    ILazyDataset view = dataset.getSliceView(new Slice(1,2),null,null);
    IDataset slice = view.getSlice();
    assertTrue(slice != null);
}
 
開發者ID:eclipse,項目名稱:january,代碼行數:17,代碼來源:AxesMetadataTest.java

示例4: getOperation

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
@Override
protected IOperationPerformer getOperation()
{
  return new InterpolatedMaths.IOperationPerformer()
  {
    @Override
    public Dataset
        perform(final Dataset a, final Dataset b, final Dataset o)
    {
      // ok, we're going to use dataset a as the new index units,
      // so we've just got to set them in a copy of b
      final Dataset output = b.clone();

      // clear any existing metadata
      output.clearMetadata(AxesMetadata.class);

      // now store the new metadata
      final AxesMetadata am = new AxesMetadataImpl();
      am.initialize(1);
      am.setAxis(0, a);
      output.addMetadata(am);

      return output;
    }
  };
}
 
開發者ID:debrief,項目名稱:limpet,代碼行數:27,代碼來源:CreateNewIndexedDatafileOperation.java

示例5: testLoader

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
@Test
public void testLoader() throws Exception {
	
	Dataset range = DatasetFactory.createRange(LongDataset.class, 10*13*20*20);
	range.setShape(new int[]{10,13,20,20} );
	
	LazyDynamicDataset dataset = getDataset(range,2,"data");
	
	AxesMetadata ax = MetadataFactory.createMetadata(AxesMetadata.class, 4);
	ax.setAxis(0, DatasetFactory.createRange(LongDataset.class, 10));
	ax.setAxis(1, DatasetFactory.createRange(LongDataset.class, 13));
	dataset.addMetadata(ax);
	
	int max = 399;
	
	for (int i = 0 ; i < (10*13); i++) {
		SliceND slice = new SliceND(dataset.getShape());
		int[] shape = dataset.getShape();
		slice.setSlice(0, shape[0]-1, shape[0], 1);
		slice.setSlice(1, shape[1]-1, shape[1], 1);
		IDataset s = dataset.getSlice(slice);
		Assert.assertEquals(max, s.max().intValue());
		max+=400;
		
		AxesMetadata axm = s.getFirstMetadata(AxesMetadata.class);
		
		Assert.assertEquals(axm.getAxis(0)[0].getSlice().getInt(0, 0, 0, 0), shape[0]-1);
		Assert.assertEquals(axm.getAxis(1)[0].getSlice().getInt(0, 0, 0, 0), shape[1]-1);
		
		dataset.refreshShape();
	}
	
	Assert.assertArrayEquals(new int[]{10,13,20,20},dataset.getShape());
	
}
 
開發者ID:eclipse,項目名稱:january,代碼行數:36,代碼來源:LazyDynamicLoaderTest.java

示例6: testAxesMetadataRecursion

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
@Test
public void testAxesMetadataRecursion() throws MetadataException {
	final int[] shape = new int[] { 1, 2, 3, 1 };

	int r = shape.length;

	ILazyDataset axis = Random.lazyRand(Dataset.INT32, "axis", 2);
	AxesMetadata amd = MetadataFactory.createMetadata(AxesMetadata.class, 1);
	amd.setAxis(0, Random.lazyRand(Dataset.INT32, "axis2", 2));
	axis.addMetadata(amd);

	amd = MetadataFactory.createMetadata(AxesMetadata.class, r);
	amd.setAxis(1, axis);
	ILazyDataset dataset = Random.lazyRand(Dataset.INT32, "Main", shape);
	dataset.addMetadata(amd);

	dataset.setShape(2,3,1,1);

	ErrorMetadata emd = MetadataFactory.createMetadata(ErrorMetadata.class);
	ILazyDataset axisErr = Random.lazyRand(Dataset.INT32, "axis2_err", 2);
	emd.setError(axisErr);
	axis.addMetadata(emd);

	amd = MetadataFactory.createMetadata(AxesMetadata.class, 1);
	amd.setAxis(0, axis);
	axisErr.addMetadata(amd);

	axisErr.setShape(2,1);
	axisErr.getSliceView(new Slice(1));
	axisErr.getTransposedView();
}
 
開發者ID:eclipse,項目名稱:january,代碼行數:32,代碼來源:AxesMetadataTest.java

示例7: testAxesMetadataError

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
@Test
public void testAxesMetadataError() throws DatasetException {
       final int[] shape = new int[] { 1, 2, 3, 1 };

       int r = shape.length;

       ILazyDataset axis = Random.lazyRand(Dataset.INT32, "axis", 2);
       AxesMetadata amd = MetadataFactory.createMetadata(AxesMetadata.class, 1);
       amd.setAxis(0, Random.lazyRand(Dataset.INT32, "axis2", 2));
       axis.addMetadata(amd);

       amd = MetadataFactory.createMetadata(AxesMetadata.class, r);
       amd.setAxis(1, axis);
       ILazyDataset dataset = Random.lazyRand(Dataset.INT32, "Main", shape);
       dataset.addMetadata(amd);
       ILazyDataset datasetErr = Random.lazyRand(Dataset.INT32, "dataset_err", 1, 2, 1, 1);
       dataset.setErrors(datasetErr);

       dataset.setShape(2,3,1,1);


       ILazyDataset axisErr = Random.lazyRand(Dataset.INT32, "axis2_err", 2);

       amd = MetadataFactory.createMetadata(AxesMetadata.class, 1);
       amd.setAxis(0, axis);
       axisErr.addMetadata(amd);
       axis.setErrors(axisErr);

       ILazyDataset d = dataset.getSliceView();
       d.squeezeEnds();
       IDataset slice = d.getSlice();
       
       assertTrue(slice != null);
}
 
開發者ID:eclipse,項目名稱:january,代碼行數:35,代碼來源:AxesMetadataTest.java

示例8: assignOutputIndices

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
protected void assignOutputIndices(final IDataset output,
    final Dataset outputIndices)
{
  if (outputIndices != null)
  {
    // now insert the new one
    final AxesMetadata am = new AxesMetadataImpl();
    am.initialize(1);
    am.setAxis(0, outputIndices);
    output.addMetadata(am);
  }
}
 
開發者ID:debrief,項目名稱:limpet,代碼行數:13,代碼來源:CoreQuantityCommand.java

示例9: storeMetadata

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
private static void storeMetadata(final Dataset indicesTrimmed,
    final Dataset datasetA, final Dataset datasetB)
{
  final AxesMetadata newAxis = new AxesMetadataImpl();
  newAxis.initialize(1);
  newAxis.setAxis(0, indicesTrimmed);
  datasetA.addMetadata(newAxis);
  datasetB.addMetadata(newAxis);
}
 
開發者ID:debrief,項目名稱:limpet,代碼行數:10,代碼來源:InterpolatedMaths.java

示例10: testDynamicAxesMetadata

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
@Test
public void testDynamicAxesMetadata() throws Exception {
	
	int[] maxShape = new int[]{10,13,20,20};
	
	Dataset range = DatasetFactory.createRange(LongDataset.class, 10*13*20*20);
	range.setShape(maxShape);
	
	LazyDynamicDataset dataset = getDataset(range,2,"data");
	LazyDynamicDataset ax1 = getDataset(DatasetFactory.createRange(LongDataset.class, 10),0,"ax0");
	LazyDynamicDataset ax2 = getDataset(DatasetFactory.createRange(LongDataset.class, 13),0,"ax1");
	
	AxesMetadata ax = MetadataFactory.createMetadata(AxesMetadata.class, 4);
	ax.setAxis(0, ax1);
	ax.setAxis(1, ax2);
	dataset.addMetadata(ax);
	
	int max = 399;
	
	SliceND slice = new SliceND(dataset.getShape(),maxShape);
	int[] axShape = new int[]{1,1,1,1};
	
	for (int i = 0 ; i < (10*13); i++) {
		int[] shape = dataset.getShape();
		@SuppressWarnings("unused")
		int[] so = DynamicMetadataUtils.refreshDynamicAxesMetadata(dataset.getMetadata(AxesMetadata.class), shape);
		slice.setSlice(0, shape[0]-1, shape[0], 1);
		slice.setSlice(1, shape[1]-1, shape[1], 1);
		IDataset s = dataset.getSlice(slice);
		Assert.assertEquals((long) max, s.max().longValue());
		max+=400;
		
		AxesMetadata axm = s.getFirstMetadata(AxesMetadata.class);

		IDataset s0 = axm.getAxis(0)[0].getSlice();
		Assert.assertArrayEquals(axShape, s0.getShape());
		Assert.assertEquals(s0.getInt(0, 0, 0, 0), shape[0]-1);
		s0 = axm.getAxis(1)[0].getSlice();
		Assert.assertArrayEquals(axShape, s0.getShape());
		Assert.assertEquals(axm.getAxis(1)[0].getSlice().getInt(0, 0, 0, 0), shape[1]-1);

		dataset.refreshShape();
	}
	
	Assert.assertArrayEquals(new int[]{10,13,20,20},dataset.getShape());
	
}
 
開發者ID:eclipse,項目名稱:january,代碼行數:48,代碼來源:LazyDynamicLoaderTest.java

示例11: testAxisReverseInterpolation

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
@Test
public void testAxisReverseInterpolation()
{
	// configure Dataset A
	final Dataset elevationA_m =
			DatasetFactory
					.createFromList(Arrays.asList(150d, 125d, 100d, 75d, 50d));
	elevationA_m.setName("A elevation (m)");
	Dataset temperatureA_C =
			DatasetFactory.createFromList(Arrays.asList(5d, 10d, 15d, 20d, 25d));
	final AxesMetadata axesMetadataA = new AxesMetadataImpl();
	axesMetadataA.initialize(1);
	axesMetadataA.setAxis(0, elevationA_m);
	temperatureA_C.addMetadata(axesMetadataA);
	temperatureA_C.setName("A temperature (deg C)");

	// configure Dataset B
	final Dataset elevationB_m =
			DatasetFactory
					.createFromList(Arrays.asList(130d, 125d, 100d, 70d, 40d));
	elevationB_m.setName("B elevation (m)");
	final Dataset temperatureB_C =
			DatasetFactory.createFromList(Arrays
					.asList(15d, 17.5d, 20d, 22.5d, 25d));
	final AxesMetadata axesMetadataB = new AxesMetadataImpl();
	axesMetadataB.initialize(1);
	axesMetadataB.setAxis(0, elevationB_m);
	temperatureB_C.addMetadata(axesMetadataB);
	temperatureB_C.setName("B temperature (deg C)");

	// wrap mathematical operation
	final IOperationPerformer doAdd = new IOperationPerformer()
	{
		@Override
		public Dataset perform(Dataset a, Dataset b, Dataset o)
		{
			return Maths.add(a, b, o).idivide(2d);
		}
	};
	final Dataset meanTemperature =
			NewMaths.performWithInterpolation(temperatureA_C, temperatureB_C, null,
					doAdd);
	assertNotNull(meanTemperature);
	meanTemperature.setName("Interpolated sum of dataset A and dataset B");

	// check that the resulting dataset has the correctly intersecting times
	printIndexedDataset(temperatureA_C);
	printIndexedDataset(temperatureB_C);
	Dataset interElevations =
			(Dataset) meanTemperature.getFirstMetadata(AxesMetadata.class).getAxis(
					0)[0];
	assertEquals("first elevation correct", 130d, interElevations.getDouble(0),
			0.001);
	assertEquals("last elevation correct", 70d, interElevations
			.getDouble(interElevations.getSize() - 1), 0.001);

	printIndexedDataset(meanTemperature);
}
 
開發者ID:eclipse,項目名稱:january,代碼行數:59,代碼來源:AxesMetadataExample.java

示例12: testNonSyncedContainedAxesOperation

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
/**
 * test we interpolate data when one set of axis measurements spans the region covered by the
 * other
 */
@Test
public void testNonSyncedContainedAxesOperation()
{
	// configure Dataset A
	final Dataset elevationA_m =
			DatasetFactory.createFromList(Arrays.asList(50d, 100d, 150d));
	elevationA_m.setName("A elevation (m)");
	Dataset temperatureA_C =
			DatasetFactory.createFromList(Arrays.asList(5d, 10d, 15d));
	final AxesMetadata axesMetadataA = new AxesMetadataImpl();
	axesMetadataA.initialize(1);
	axesMetadataA.setAxis(0, elevationA_m);
	temperatureA_C.addMetadata(axesMetadataA);
	temperatureA_C
			.setName("A temperature (deg C), with elevations (t = e / 10)");

	// configure Dataset B
	final Dataset elevationB_m =
			DatasetFactory
					.createFromList(Arrays.asList(50d, 75d, 100d, 125d, 150d));
	elevationB_m.setName("B elevation (m)");
	final Dataset temperatureB_C =
			DatasetFactory.createFromList(Arrays
					.asList(15d, 17.5d, 20d, 22.5d, 25d));
	final AxesMetadata axesMetadataB = new AxesMetadataImpl();
	axesMetadataB.initialize(1);
	axesMetadataB.setAxis(0, elevationB_m);
	temperatureB_C.addMetadata(axesMetadataB);
	temperatureB_C
			.setName("B temperature (deg C), with elevations (t = e / 10 + 10)");

	// show initial values
	printIndexedDataset(temperatureA_C);
	printIndexedDataset(temperatureB_C);

	// wrap mathematical operation
	final IOperationPerformer doAdd = new IOperationPerformer()
	{
		@Override
		public Dataset perform(Dataset a, Dataset b, Dataset o)
		{
			return Maths.add(a, b, o).idivide(2d);
		}
	};

	// apply our operation to the two datasets
	final Dataset meanTemperature =
			NewMaths.performWithInterpolation(temperatureA_C, temperatureB_C, null,
					doAdd);
	meanTemperature
			.setName("Mean of A and B, taken at B elevations (should be t = e / 10 + 5)");

	printIndexedDataset(meanTemperature);

	final AxesMetadata elevations =
			meanTemperature.getFirstMetadata(AxesMetadata.class);
	assertNotNull("elevations present in results", elevations);
	assertEquals("correct elevations", elevationB_m, elevations.getAxis(0)[0]);

	// check results, via sampling
	assertEquals("correct value", 12.5d, meanTemperature.getDouble(1), 0.001); // mean temp at 75m
	assertEquals("correct value", 17.5d, meanTemperature.getDouble(3), 0.001); // mean temp at 125m

}
 
開發者ID:eclipse,項目名稱:january,代碼行數:69,代碼來源:AxesMetadataExample.java

示例13: testNonSyncedOverlappingAxesOperation

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
/**
 * test we interpolate data when the two sets of axis measurements overlap
 * 
 * @throws DatasetException
 */
@Test
public void testNonSyncedOverlappingAxesOperation() throws DatasetException
{
	// configure Dataset A
	final Dataset elevationA_m =
			DatasetFactory.createFromList(Arrays.asList(50d, 100d, 150d));
	elevationA_m.setName("A elevation (m)");
	Dataset temperatureA_C =
			DatasetFactory.createFromList(Arrays.asList(5d, 10d, 15d));
	final AxesMetadata axesMetadataA = new AxesMetadataImpl();
	axesMetadataA.initialize(1);
	axesMetadataA.setAxis(0, elevationA_m);
	temperatureA_C.addMetadata(axesMetadataA);
	temperatureA_C
			.setName("A temperature (deg C), with elevations (t = e / 10)");

	// configure Dataset B
	final Dataset elevationB_m =
			DatasetFactory
					.createFromList(Arrays.asList(40d, 75d, 100d, 125d, 140d));
	elevationB_m.setName("B elevation (m)");
	final Dataset temperatureB_C =
			DatasetFactory.createFromList(Arrays
					.asList(14d, 17.5d, 20d, 22.5d, 24d));
	final AxesMetadata axesMetadataB = new AxesMetadataImpl();
	axesMetadataB.initialize(1);
	axesMetadataB.setAxis(0, elevationB_m);
	temperatureB_C.addMetadata(axesMetadataB);
	temperatureB_C
			.setName("B temperature (deg C), with elevations (t = e / 10 + 10)");

	// show initial values
	printIndexedDataset(temperatureA_C);
	printIndexedDataset(temperatureB_C);

	// wrap mathematical operation
	final IOperationPerformer doAdd = new IOperationPerformer()
	{
		@Override
		public Dataset perform(Dataset a, Dataset b, Dataset o)
		{
			return Maths.add(a, b, o).idivide(2d);
		}
	};

	// apply our operation to the two datasets
	final Dataset meanTemperature =
			NewMaths.performWithInterpolation(temperatureA_C, temperatureB_C, null,
					doAdd);
	meanTemperature
			.setName("Mean of A and B, taken at intersecting elevations (should be t = e / 10 + 5)");

	printIndexedDataset(meanTemperature);

	final AxesMetadata elevations =
			meanTemperature.getFirstMetadata(AxesMetadata.class);
	assertNotNull("elevations present in results", elevations);
	assertEquals("correct elevations", 4, elevations.getAxis(0)[0].getSize());

	Dataset elevationValues =
			DatasetUtils.sliceAndConvertLazyDataset(elevations.getAxis(0)[0]);
	assertEquals("correct start elevation", 75, elevationValues.getDouble(0),
			0.001);

	// check results, via sampling
	assertEquals("correct value", 12.5, meanTemperature.getDouble(0), 0.001); // mean temp at 75m
	assertEquals("correct value", 17.5, meanTemperature.getDouble(2), 0.001); // mean temp at 125m
	assertEquals("correct value", 19.0, meanTemperature.getDouble(3), 0.001); // mean temp at 140m

}
 
開發者ID:eclipse,項目名稱:january,代碼行數:76,代碼來源:AxesMetadataExample.java

示例14: toDocument

import org.eclipse.january.metadata.AxesMetadata; //導入方法依賴的package包/類
@Override
public D toDocument()
{
  final D res;
  if (_values.size() > 0)
  {
    // ok, start with the dataset
    final IDataset dataset = getDataset(_values);
    dataset.setName(_name);

    // do we have any indices to add?
    if (_indices != null)
    {
      // yes, store them
      final DoubleDataset indexData =
          (DoubleDataset) DatasetFactory.createFromObject(_indices);
      final AxesMetadata index = new AxesMetadataImpl();
      index.initialize(1);
      index.setAxis(0, indexData);
      dataset.addMetadata(index);
    }

    // get the output document
    res = getDocument(dataset, _predecessor);

    // do we indices?
    if (_indices != null)
    {
      if (_indexUnits == null)
      {
        System.err.println("Setting index, but do not have units");
      }

      // ok, set the index units
      res.setIndexUnits(_indexUnits);
    }
    else
    {
      if (_indexUnits != null)
      {
        throw new IllegalArgumentException("Have index units, but no index");
      }
    }

    // ok, any last minute tidying
    finishOff(res);
  }
  else
  {
    res = null;
  }
  return res;
}
 
開發者ID:debrief,項目名稱:limpet,代碼行數:54,代碼來源:CoreDocumentBuilder.java


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