Beispiel #1
0
def test_basic_replay(mesh, casedir):
    spacepool = SpacePool(mesh)
    Q = spacepool.get_space(1,0)
    V = spacepool.get_space(1,1)

    pp = PostProcessor(dict(casedir=casedir))
    pp.add_fields([
        MockFunctionField(Q, dict(save=True)),
        MockVectorFunctionField(V, dict(save=True))
    ])

    replay_fields = lambda save: [Norm("MockFunctionField", dict(save=save)),
                             Norm("MockVectorFunctionField", dict(save=save)),
                             TimeIntegral("Norm_MockFunctionField", dict(save=save)),]
    rf_names = [f.name for f in replay_fields(False)]

    # Add fields, but don't save (for testing)
    pp.add_fields(replay_fields(False))

    # Solutions to check against
    checks = {}
    pp.update_all({}, 0.0, 0)
    checks[0] = dict([(name, pp.get(name)) for name in rf_names])
    pp.update_all({}, 0.1, 1)
    checks[1] = dict([(name, pp.get(name)) for name in rf_names])
    pp.update_all({}, 0.2, 2)
    pp.finalize_all()
    checks[2] = dict([(name, pp.get(name)) for name in rf_names])

    # Make sure that nothing is saved yet
    for name in rf_names:
        assert not os.path.isfile(os.path.join(pp.get_savedir(name), name+".db"))
    # ----------- Replay -----------------
    pp = PostProcessor(dict(casedir=casedir))

    pp.add_fields([
        MockFunctionField(Q),
        MockVectorFunctionField(V),
    ])

    # This time, save the fields
    pp.add_fields(replay_fields(True))

    replayer = Replay(pp)
    replayer.replay()

    # Test that replayed solution is the same as computed in the original "solve"
    for name in rf_names:
        data = shelve.open(os.path.join(pp.get_savedir(name), name+".db"), 'r')

        for i in range(3):
            assert data.get(str(i), None) == checks[i][name] or abs(data.get(str(i), None) - checks[i][name]) < 1e-8
        data.close()
Beispiel #2
0
def test_get():
    pp = PostProcessor()
    velocity = MockVelocity()
    pp.add_field(velocity)

    # Check that compute is triggered
    assert velocity.touched == 0
    assert pp.get("MockVelocity") == "u"
    assert velocity.touched == 1

    # Check that get doesn't trigger second compute count
    pp.get("MockVelocity")
    assert velocity.touched == 1
Beispiel #3
0
def test_shelve_save(mesh, casedir):
    mtf = MockTupleField(dict(save=True, save_as="shelve"))
    msf = MockScalarField(dict(save=True, save_as="shelve"))

    pp = PostProcessor(dict(casedir=casedir))
    pp.add_fields([mtf, msf])

    pp.update_all({}, 0.0, 0)
    pp.update_all({}, 0.1, 1)
    pp.update_all({}, 0.2, 2)
    pp.finalize_all()

    for mf in [mtf, msf]:
        assert os.path.isdir(pp.get_savedir(mf.name))
        assert os.path.isfile(
            os.path.join(pp.get_savedir(mf.name), "metadata.db"))
        assert os.path.isfile(
            os.path.join(pp.get_savedir(mf.name), mf.name + ".db"))

        md = shelve.open(os.path.join(pp.get_savedir(mf.name), "metadata.db"),
                         'r')
        assert 'shelve' in md["0"]
        assert md['saveformats'] == ['shelve']
        md.close()

        # Read back
        data = shelve.open(
            os.path.join(pp.get_savedir(mf.name), mf.name + ".db"), 'r')
        for i in ["0", "1", "2"]:
            d = data[i]
        data.close()

        assert d == pp.get(mf.name)
Beispiel #4
0
def test_compute_calls():
    pressure = MockPressure()
    velocity = MockVelocity()
    Du = MockVelocityGradient()
    epsilon = MockStrain()
    sigma = MockStress()

    # Add fields to postprocessor
    pp = PostProcessor()
    pp.add_fields([pressure, velocity, Du, epsilon, sigma])

    # Nothing has been computed yet
    assert velocity.touched == 0
    assert Du.touched == 0
    assert epsilon.touched == 0
    assert pressure.touched == 0
    assert sigma.touched == 0

    # Get strain twice
    for i in range(2):
        strain = pp.get("MockStrain")
        # Check value
        assert strain == "epsilon(grad(u))"
        # Check the right things are computed but only the first time
        assert velocity.touched == 1  # Only increased first iteration!
        assert Du.touched == 1  # ...
        assert epsilon.touched == 1  # ...
        assert pressure.touched == 0  # Not computed!
        assert sigma.touched == 0  # ...

    # Get stress twice
    for i in range(2):
        stress = pp.get("MockStress")
        # Check value
        assert stress == "sigma(epsilon(grad(u)), p)"
        # Check the right things are computed but only the first time
        assert velocity.touched == 1  # Not recomputed!
        assert Du.touched == 1  # ...
        assert epsilon.touched == 1  # ...
        assert pressure.touched == 1  # Only increased first iteration!
        assert sigma.touched == 1  # ...
Beispiel #5
0
def test_finalize_all(casedir):
    pp = PostProcessor(dict(casedir=casedir))

    velocity = MockVelocity(dict(finalize=True))
    pressure = MockPressure()
    pp.add_fields([velocity, pressure])

    pp.get("MockVelocity")
    pp.get("MockPressure")

    # Nothing finalized yet
    assert pp._finalized == {}
    assert velocity.finalized is False

    # finalize_all should finalize velocity only
    pp.finalize_all()
    assert pp._finalized == {"MockVelocity": "u"}
    assert velocity.finalized is True

    # Still able to get it
    assert pp.get("MockVelocity") == "u"
Beispiel #6
0
def test_xmlgz_save(mesh, casedir):
    spacepool = SpacePool(mesh)
    Q = spacepool.get_space(1, 0)
    V = spacepool.get_space(1, 1)

    mff = MockFunctionField(Q, dict(save=True, save_as="xml.gz"))
    mvff = MockVectorFunctionField(V, dict(save=True, save_as="xml.gz"))

    pp = PostProcessor(dict(casedir=casedir))
    pp.add_fields([mff, mvff])

    pp.update_all({}, 0.0, 0)
    pp.update_all({}, 0.1, 1)
    pp.update_all({}, 0.2, 2)
    pp.finalize_all()

    for mf, FS in [(mff, Q), (mvff, V)]:
        assert os.path.isdir(pp.get_savedir(mf.name))
        assert os.path.isfile(
            os.path.join(pp.get_savedir(mf.name), "metadata.db"))
        assert os.path.isfile(
            os.path.join(pp.get_savedir(mf.name), "mesh.hdf5"))
        assert os.path.isfile(
            os.path.join(pp.get_savedir(mf.name), mf.name + "0.xml.gz"))
        assert os.path.isfile(
            os.path.join(pp.get_savedir(mf.name), mf.name + "1.xml.gz"))
        assert os.path.isfile(
            os.path.join(pp.get_savedir(mf.name), mf.name + "2.xml.gz"))

        md = shelve.open(os.path.join(pp.get_savedir(mf.name), "metadata.db"),
                         'r')
        assert 'xml.gz' in md["0"]
        assert 'xml.gz' in md["1"]
        assert 'xml.gz' in md["2"]
        assert 'xml.gz' in md['saveformats']

        assert md['saveformats'] == ['xml.gz']
        md.close()

        assert len(os.listdir(pp.get_savedir(mf.name))) == 1 + 1 + 3

        # Read back
        for i in ["0", "1", "2"]:
            f = Function(
                FS,
                os.path.join(pp.get_savedir(mf.name), mf.name + i + ".xml.gz"))

        assert norm(f) == norm(pp.get(mf.name))
Beispiel #7
0
def test_hdf5_save(mesh, casedir):
    spacepool = SpacePool(mesh)
    Q = spacepool.get_space(1, 0)
    V = spacepool.get_space(1, 1)

    mff = MockFunctionField(Q, dict(save=True, save_as="hdf5"))
    mvff = MockVectorFunctionField(V, dict(save=True, save_as="hdf5"))

    pp = PostProcessor(dict(casedir=casedir))
    pp.add_fields([mff, mvff])

    pp.update_all({}, 0.0, 0)
    pp.update_all({}, 0.1, 1)
    pp.update_all({}, 0.2, 2)
    pp.finalize_all()

    for mf, FS in [(mff, Q), (mvff, V)]:
        assert os.path.isdir(pp.get_savedir(mf.name))
        assert os.path.isfile(
            os.path.join(pp.get_savedir(mf.name), "metadata.db"))
        assert os.path.isfile(
            os.path.join(pp.get_savedir(mf.name), mf.name + ".hdf5"))

        md = shelve.open(os.path.join(pp.get_savedir(mf.name), "metadata.db"),
                         'r')
        assert 'hdf5' in md["0"]
        assert 'hdf5' in md["1"]
        assert 'hdf5' in md["2"]
        assert 'hdf5' in md['saveformats']

        assert md['saveformats'] == ['hdf5']
        md.close()

        assert len(os.listdir(pp.get_savedir(mf.name))) == 2

        # Read back
        hdf5file = HDF5File(
            mpi_comm_world(),
            os.path.join(pp.get_savedir(mf.name), mf.name + ".hdf5"), 'r')
        f = Function(FS)
        for i in ["0", "1", "2"]:
            hdf5file.read(f, mf.name + i)

        assert norm(f) == norm(pp.get(mf.name))
def test_run_problem(problem_factory, scheme_factory, refinement_level, dt):

    problem = problem_factory(refinement_level, dt)
    scheme = scheme_factory()

    print
    print "."*100
    print "** Problem: %16s ** Solver: %16s" % (problem.shortname(), scheme.shortname())
    print "** Refinement level: %2d ** dt: %.8f" % (refinement_level, dt)
    print "**"

    pp = PostProcessor({"casedir": "test"})
    test_fields = problem.test_fields()
    pp.add_fields(test_fields)

    solver = NSSolver(problem, scheme, pp)

    # Define variables
    values = {f.name: 1e16 for f in test_fields}
    num_dofs = 0
    T = 0

    # Disable printing from solve
    # TODO: Move to NSSolver/set option
    original_stdout = sys.stdout
    sys.stdout = NoOutput()

    try:
        t1 = time.time()
        ns = solver.solve()
        t2 = time.time()
        T = t2-t1

        spaces = ns["spaces"]
        t = float(ns["t"])
        num_dofs = spaces.V.dim()+spaces.Q.dim()

        references = problem.test_references(spaces, t)
        if references:
            assert len(references) == len(test_fields)
            for field, ref in zip(test_fields, references):
                value = pp.get(field.name)
                values[field.name] = l2norm(value, ref)
        else:
            for field in test_fields:
                value = float(pp.get(field.name)) # Only support scalar values in reference data
                values[field.name] = value

    except RuntimeError as re:
        print re.message

    # Enable printing again, and print values
    sys.stdout = original_stdout

    print "** dofs: %d Time spent: %f" % (num_dofs , T)

    #assert values, "No values calculated. Solver most likely failed."
    if all([v==1e16 for v in values.values()]):
        print "No values calculated. Solver most likely failed."

    for tfname, err in values.items():
        print "**** Fieldname: %20s ** Error: %.8e" % (tfname, err)

    # Store solve metadata
    metadata = {}
    metadata["scheme"] = {}
    metadata["scheme"]["name"] = scheme.shortname()
    metadata["scheme"]["params"] = scheme.params

    metadata["problem"] = {}
    metadata["problem"]["name"] = problem.shortname()
    metadata["problem"]["params"] = problem.params

    metadata["num_dofs"] = num_dofs
    metadata["time"] = T

    # Find hash from problem and scheme name+parameters
    hash = sha1()
    hash.update(str(metadata["scheme"]))
    hash.update(str(metadata["problem"]))
    filename = hash.hexdigest() + ".db"

    # Always write to output
    write_output_data(filename, metadata, values)

    # Read reference data values
    ref_metadata, ref_values = read_reference_data(filename)
    if ref_values == {}:
        print "WARNING: Found no reference data"
        return
    assert ref_values != {}, "Found no reference data!"

    # Check each value against reference
    for key in values:
        if key in ref_values:

            # Compute absolute and relative errors
            abs_err = abs(values[key] - ref_values[key])
            if abs(ref_values[key]) > 1e-12:
                err = abs_err / abs(ref_values[key])
            else:
                err = abs_err

            # TODO: Find necessary condition of this check!

            # This one should be chosen such that it always passes when nothing has changed
            strict_tolerance = 1e-8
            if err > strict_tolerance:
                msg = "Error not matching reference with tolerance %e:\n    key=%s,  error=%e,  ref_error=%e  diff=%e,  relative=%e" % (
                    strict_tolerance, key, values[key], ref_values[key], abs_err, err)
                print msg

            # This one should be chosen so that it passes when we're happy
            loose_tolerance = 1e-3
            assert err < loose_tolerance

    # After comparing what we can, check that we have references for everything we computed
    assert set(values.keys()) == set(ref_values.keys()), "Value keys computed and in references are different."
Beispiel #9
0
def test_run_problem(problem_factory, scheme_factory, refinement_level, dt):

    problem = problem_factory(refinement_level, dt)
    scheme = scheme_factory()

    print
    print "." * 100
    print "** Problem: %16s ** Solver: %16s" % (problem.shortname(),
                                                scheme.shortname())
    print "** Refinement level: %2d ** dt: %.8f" % (refinement_level, dt)
    print "**"

    pp = PostProcessor({"casedir": "test"})
    test_fields = problem.test_fields()
    pp.add_fields(test_fields)

    solver = NSSolver(problem, scheme, pp)

    # Define variables
    values = {f.name: 1e16 for f in test_fields}
    num_dofs = 0
    T = 0

    # Disable printing from solve
    # TODO: Move to NSSolver/set option
    original_stdout = sys.stdout
    sys.stdout = NoOutput()

    try:
        t1 = time.time()
        ns = solver.solve()
        t2 = time.time()
        T = t2 - t1

        spaces = ns["spaces"]
        t = float(ns["t"])
        num_dofs = spaces.V.dim() + spaces.Q.dim()

        references = problem.test_references(spaces, t)
        if references:
            assert len(references) == len(test_fields)
            for field, ref in zip(test_fields, references):
                value = pp.get(field.name)
                values[field.name] = l2norm(value, ref)
        else:
            for field in test_fields:
                value = float(pp.get(field.name)
                              )  # Only support scalar values in reference data
                values[field.name] = value

    except RuntimeError as re:
        print re.message

    # Enable printing again, and print values
    sys.stdout = original_stdout

    print "** dofs: %d Time spent: %f" % (num_dofs, T)

    #assert values, "No values calculated. Solver most likely failed."
    if all([v == 1e16 for v in values.values()]):
        print "No values calculated. Solver most likely failed."

    for tfname, err in values.items():
        print "**** Fieldname: %20s ** Error: %.8e" % (tfname, err)

    # Store solve metadata
    metadata = {}
    metadata["scheme"] = {}
    metadata["scheme"]["name"] = scheme.shortname()
    metadata["scheme"]["params"] = scheme.params

    metadata["problem"] = {}
    metadata["problem"]["name"] = problem.shortname()
    metadata["problem"]["params"] = problem.params

    metadata["num_dofs"] = num_dofs
    metadata["time"] = T

    # Find hash from problem and scheme name+parameters
    hash = sha1()
    hash.update(str(metadata["scheme"]))
    hash.update(str(metadata["problem"]))
    filename = hash.hexdigest() + ".db"

    # Always write to output
    write_output_data(filename, metadata, values)

    # Read reference data values
    ref_metadata, ref_values = read_reference_data(filename)
    if ref_values == {}:
        print "WARNING: Found no reference data"
        return
    assert ref_values != {}, "Found no reference data!"

    # Check each value against reference
    for key in values:
        if key in ref_values:

            # Compute absolute and relative errors
            abs_err = abs(values[key] - ref_values[key])
            if abs(ref_values[key]) > 1e-12:
                err = abs_err / abs(ref_values[key])
            else:
                err = abs_err

            # TODO: Find necessary condition of this check!

            # This one should be chosen such that it always passes when nothing has changed
            strict_tolerance = 1e-8
            if err > strict_tolerance:
                msg = "Error not matching reference with tolerance %e:\n    key=%s,  error=%e,  ref_error=%e  diff=%e,  relative=%e" % (
                    strict_tolerance, key, values[key], ref_values[key],
                    abs_err, err)
                print msg

            # This one should be chosen so that it passes when we're happy
            loose_tolerance = 1e-3
            assert err < loose_tolerance

    # After comparing what we can, check that we have references for everything we computed
    assert set(values.keys()) == set(ref_values.keys(
    )), "Value keys computed and in references are different."