/* * Copyright (c) 2012 Diamond Light Source Ltd. * * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html */ package uk.ac.diamond.scisoft.analysis.crystallography; import javax.vecmath.Vector3d; import org.junit.Assert; import org.junit.Test; public class UnitCellTest { @Test public void testUnitCell() { Vector3d a = new Vector3d(1, 0, 0); Vector3d b = new Vector3d(0, 1, 0); Vector3d c = new Vector3d(0, 0, 1); UnitCell uc = new UnitCell(1); Assert.assertEquals(a, uc.getA()); Assert.assertEquals(b, uc.getB()); Assert.assertEquals(c, uc.getC()); Assert.assertEquals(1.0, uc.volume(), 1e-14); Assert.assertEquals(1.0, uc.getLengths()[0], 1e-14); Assert.assertEquals(1.0, uc.getLengths()[1], 1e-14); Assert.assertEquals(1.0, uc.getLengths()[2], 1e-14); Assert.assertEquals(90.0, uc.getAngles()[0], 1e-14); Assert.assertEquals(90.0, uc.getAngles()[1], 1e-14); Assert.assertEquals(90.0, uc.getAngles()[2], 1e-14); Vector3d d = new Vector3d(1, Math.sqrt(3), 0); uc.setB(d); Assert.assertEquals(d, uc.getB()); Assert.assertEquals(Math.sqrt(3), uc.volume(), 1e-14); Assert.assertEquals(1.0, uc.getLengths()[0], 1e-14); Assert.assertEquals(2.0, uc.getLengths()[1], 1e-14); Assert.assertEquals(1.0, uc.getLengths()[2], 1e-14); Assert.assertEquals(90.0, uc.getAngles()[0], 1e-14); Assert.assertEquals(90.0, uc.getAngles()[1], 1e-14); Assert.assertEquals(60.0, uc.getAngles()[2], 1e-14); } }