diff --git a/firedrake/bcs.py b/firedrake/bcs.py index 17a893328c..272b74ddbf 100644 --- a/firedrake/bcs.py +++ b/firedrake/bcs.py @@ -348,12 +348,12 @@ def function_arg(self, g): raise RuntimeError("%r is defined on incompatible FunctionSpace!" % g) self._function_arg = g elif isinstance(g, ufl.classes.Zero): - if g.ufl_shape and g.ufl_shape != V.ufl_element().value_shape(V.mesh()): + if g.ufl_shape and g.ufl_shape != V.value_shape: raise ValueError(f"Provided boundary value {g} does not match shape of space") # Special case. Scalar zero for direct Function.assign. self._function_arg = g elif isinstance(g, ufl.classes.Expr): - if g.ufl_shape != V.ufl_element().value_shape(V.mesh()): + if g.ufl_shape != V.value_shape: raise RuntimeError(f"Provided boundary value {g} does not match shape of space") try: self._function_arg = firedrake.Function(V) diff --git a/firedrake/checkpointing.py b/firedrake/checkpointing.py index 57f1b00abc..5070a96315 100644 --- a/firedrake/checkpointing.py +++ b/firedrake/checkpointing.py @@ -935,7 +935,7 @@ def save_function(self, f, idx=None, name=None, timestepping_info={}): self._update_function_name_function_space_name_map(tmesh.name, mesh.name, {f.name(): V_name}) # Embed if necessary element = V.ufl_element() - _element = get_embedding_element_for_checkpointing(element, element.value_shape(mesh)) + _element = get_embedding_element_for_checkpointing(element, V.value_shape) if _element != element: path = self._path_to_function_embedded(tmesh.name, mesh.name, V_name, f.name()) self.require_group(path) @@ -1337,7 +1337,7 @@ def load_function(self, mesh, name, idx=None): _name = self.get_attr(path, PREFIX_EMBEDDED + "_function") _f = self.load_function(mesh, _name, idx=idx) element = V.ufl_element() - _element = get_embedding_element_for_checkpointing(element, element.value_shape(mesh)) + _element = get_embedding_element_for_checkpointing(element, V.value_shape) method = get_embedding_method_for_checkpointing(element) assert _element == _f.function_space().ufl_element() f = Function(V, name=name) diff --git a/firedrake/external_operators/point_expr_operator.py b/firedrake/external_operators/point_expr_operator.py index b2cec6eac3..3aa40e1d5b 100644 --- a/firedrake/external_operators/point_expr_operator.py +++ b/firedrake/external_operators/point_expr_operator.py @@ -44,7 +44,7 @@ def __init__(self, *operands, function_space, derivatives=None, argument_slots=( if not isinstance(operator_data["func"], types.FunctionType): raise TypeError("Expecting a FunctionType pointwise expression") expr_shape = operator_data["func"](*operands).ufl_shape - if expr_shape != function_space.ufl_element().value_shape(function_space.mesh()): + if expr_shape != function_space.value_shape: raise ValueError("The dimension does not match with the dimension of the function space %s" % function_space) @property diff --git a/firedrake/formmanipulation.py b/firedrake/formmanipulation.py index 26612c7c9b..35a6789107 100644 --- a/firedrake/formmanipulation.py +++ b/firedrake/formmanipulation.py @@ -124,8 +124,7 @@ def argument(self, o): args += [a_[j] for j in numpy.ndindex(a_.ufl_shape)] else: args += [Zero() - for j in numpy.ndindex( - V_is[i].ufl_element().value_shape(V_is[i].mesh()))] + for j in numpy.ndindex(V_is[i].value_shape)] return self._arg_cache.setdefault(o, as_vector(args)) diff --git a/firedrake/functionspaceimpl.py b/firedrake/functionspaceimpl.py index 47b8647321..22bc4735ff 100644 --- a/firedrake/functionspaceimpl.py +++ b/firedrake/functionspaceimpl.py @@ -176,16 +176,13 @@ def split(self): def _components(self): if len(self) == 1: return tuple(type(self).create(self.topological.sub(i), self.mesh()) - for i in range(self.value_size)) + for i in range(numpy.prod(self.shape))) else: return self.subfunctions @PETSc.Log.EventDecorator() def sub(self, i): - if len(self) == 1: - bound = self.value_size - else: - bound = len(self) + bound = len(self._components) if i < 0 or i >= bound: raise IndexError("Invalid component %d, not in [0, %d)" % (i, bound)) return self._components[i] @@ -654,7 +651,7 @@ def __getitem__(self, i): @utils.cached_property def _components(self): - return tuple(ComponentFunctionSpace(self, i) for i in range(self.value_size)) + return tuple(ComponentFunctionSpace(self, i) for i in range(numpy.prod(self.shape))) def sub(self, i): r"""Return a view into the ith component.""" diff --git a/firedrake/interpolation.py b/firedrake/interpolation.py index c0b826f71c..2d1c6ef051 100644 --- a/firedrake/interpolation.py +++ b/firedrake/interpolation.py @@ -546,8 +546,7 @@ def __init__( # For a VectorElement or TensorElement the correct # VectorFunctionSpace equivalent is built from the scalar # sub-element. - ufl_scalar_element = ufl_scalar_element.sub_elements[0] - if ufl_scalar_element.value_shape(V_dest.mesh()) != (): + if V_dest.sub(0).value_shape != (): raise NotImplementedError( "Can't yet cross-mesh interpolate onto function spaces made from VectorElements or TensorElements made from sub elements with value shape other than ()." ) @@ -614,7 +613,7 @@ def __init__( # I first point evaluate my expression at these locations, giving a # P0DG function on the VOM. As described in the manual, this is an # interpolation operation. - shape = V_dest.ufl_element().value_shape(V_dest.mesh()) + shape = V_dest.value_shape if len(shape) == 0: fs_type = firedrake.FunctionSpace elif len(shape) == 1: @@ -988,7 +987,7 @@ def callable(): else: # Make sure we have an expression of the right length i.e. a value for # each component in the value shape of each function space - dims = [numpy.prod(fs.ufl_element().value_shape(fs.mesh()), dtype=int) + dims = [numpy.prod(fs.value_shape, dtype=int) for fs in V] loops = [] if numpy.prod(expr.ufl_shape, dtype=int) != sum(dims): @@ -1024,13 +1023,13 @@ def _interpolator(V, tensor, expr, subset, arguments, access, bcs=None): if access is op2.READ: raise ValueError("Can't have READ access for output function") - if len(expr.ufl_shape) != len(V.ufl_element().value_shape(V.mesh())): + if len(expr.ufl_shape) != len(V.value_shape): raise RuntimeError('Rank mismatch: Expression rank %d, FunctionSpace rank %d' - % (len(expr.ufl_shape), len(V.ufl_element().value_shape(V.mesh())))) + % (len(expr.ufl_shape), len(V.value_shape))) - if expr.ufl_shape != V.ufl_element().value_shape(V.mesh()): + if expr.ufl_shape != V.value_shape: raise RuntimeError('Shape mismatch: Expression shape %r, FunctionSpace shape %r' - % (expr.ufl_shape, V.ufl_element().value_shape(V.mesh()))) + % (expr.ufl_shape, V.value_shape)) # NOTE: The par_loop is always over the target mesh cells. target_mesh = as_domain(V) diff --git a/firedrake/mg/embedded.py b/firedrake/mg/embedded.py index a5b70d8a27..cb0e723a26 100644 --- a/firedrake/mg/embedded.py +++ b/firedrake/mg/embedded.py @@ -91,7 +91,7 @@ def cache(self, key): def get_cache_key(self, V): elem = V.ufl_element() - value_shape = elem.value_shape(V.mesh()) + value_shape = V.value_shape return elem, value_shape def V_dof_weights(self, V): diff --git a/firedrake/mg/kernels.py b/firedrake/mg/kernels.py index fdb8ae8a08..fc32f0c869 100644 --- a/firedrake/mg/kernels.py +++ b/firedrake/mg/kernels.py @@ -177,11 +177,10 @@ def compile_element(expression, dual_space=None, parameters=None, return_variable = gem.Indexed(gem.Variable('R', finat_elem.index_shape), argument_multiindex) result = gem.Indexed(result, tensor_indices) if dual_space: - elem = create_element(dual_space.ufl_element()) - if elem.value_shape: - var = gem.Indexed(gem.Variable("b", elem.value_shape), - tensor_indices) - b_arg = [lp.GlobalArg("b", dtype=ScalarType, shape=elem.value_shape)] + value_shape = dual_space.value_shape + if value_shape: + var = gem.Indexed(gem.Variable("b", value_shape), tensor_indices) + b_arg = [lp.GlobalArg("b", dtype=ScalarType, shape=value_shape)] else: var = gem.Indexed(gem.Variable("b", (1, )), (0, )) b_arg = [lp.GlobalArg("b", dtype=ScalarType, shape=(1,))] @@ -220,7 +219,7 @@ def prolong_kernel(expression): assert hierarchy._meshes[int(idx)].cell_set._extruded V = expression.function_space() key = (("prolong",) - + expression.ufl_element().value_shape(meshc) + + V.value_shape + entity_dofs_key(V.finat_element.complex.get_topology()) + entity_dofs_key(V.finat_element.entity_dofs()) + entity_dofs_key(coordinates.function_space().finat_element.entity_dofs())) @@ -284,7 +283,7 @@ def prolong_kernel(expression): "evaluate": eval_code, "spacedim": element.cell.get_spatial_dimension(), "ncandidate": hierarchy.fine_to_coarse_cells[levelf].shape[1], - "Rdim": numpy.prod(element.value_shape), + "Rdim": numpy.prod(V.value_shape), "inside_cell": inside_check(element.cell, eps=1e-8, X="Xref"), "celldist_l1_c_expr": celldist_l1_c_expr(element.cell, X="Xref"), "Xc_cell_inc": coords_element.space_dimension(), @@ -302,7 +301,7 @@ def restrict_kernel(Vf, Vc): if Vf.extruded: assert Vc.extruded key = (("restrict",) - + Vf.ufl_element().value_shape(Vf.mesh()) + + Vf.value_shape + entity_dofs_key(Vf.finat_element.complex.get_topology()) + entity_dofs_key(Vc.finat_element.complex.get_topology()) + entity_dofs_key(Vf.finat_element.entity_dofs()) @@ -390,7 +389,7 @@ def inject_kernel(Vf, Vc): else: level_ratio = 1 key = (("inject", level_ratio) - + Vf.ufl_element().value_shape(Vf.mesh()) + + Vf.value_shape + entity_dofs_key(Vc.finat_element.complex.get_topology()) + entity_dofs_key(Vf.finat_element.complex.get_topology()) + entity_dofs_key(Vc.finat_element.entity_dofs()) @@ -465,7 +464,7 @@ def inject_kernel(Vf, Vc): "celldist_l1_c_expr": celldist_l1_c_expr(Vc.finat_element.cell, X="Xref"), "tdim": Vc.mesh().topological_dimension(), "ncandidate": ncandidate, - "Rdim": numpy.prod(Vf_element.value_shape), + "Rdim": numpy.prod(Vf.value_shape), "Xf_cell_inc": coords_element.space_dimension(), "f_cell_inc": Vf_element.space_dimension() } diff --git a/firedrake/mg/utils.py b/firedrake/mg/utils.py index 2db5401c47..02f0700b2d 100644 --- a/firedrake/mg/utils.py +++ b/firedrake/mg/utils.py @@ -135,7 +135,7 @@ def coarse_cell_to_fine_node_map(Vc, Vf): def physical_node_locations(V): element = V.ufl_element() - if element.value_shape(V.mesh()): + if V.value_shape: assert isinstance(element, (finat.ufl.VectorElement, finat.ufl.TensorElement)) element = element.sub_elements[0] mesh = V.mesh() diff --git a/firedrake/preconditioners/hiptmair.py b/firedrake/preconditioners/hiptmair.py index ae2241b077..858a07d0d5 100644 --- a/firedrake/preconditioners/hiptmair.py +++ b/firedrake/preconditioners/hiptmair.py @@ -150,9 +150,9 @@ def coarsen(self, pc): element = V.ufl_element() formdegree = V.finat_element.formdegree if formdegree == 1: - celement = curl_to_grad(element, mesh) + celement = curl_to_grad(element) elif formdegree == 2: - celement = div_to_curl(element, mesh) + celement = div_to_curl(element) else: raise ValueError("Hiptmair decomposition not available for", element) @@ -211,15 +211,15 @@ def coarsen(self, pc): return coarse_operator, coarse_space_bcs, interp_petscmat -def curl_to_grad(ele, mesh): +def curl_to_grad(ele): if isinstance(ele, finat.ufl.VectorElement): - return type(ele)(curl_to_grad(ele._sub_element, mesh), dim=ele.num_sub_elements) + return type(ele)(curl_to_grad(ele._sub_element), dim=ele.num_sub_elements) elif isinstance(ele, finat.ufl.TensorElement): - return type(ele)(curl_to_grad(ele._sub_element, mesh), shape=ele.value_shape(mesh), symmetry=ele.symmetry()) + return type(ele)(curl_to_grad(ele._sub_element), shape=ele._shape, symmetry=ele.symmetry()) elif isinstance(ele, finat.ufl.MixedElement): - return type(ele)(*(curl_to_grad(e, mesh) for e in ele.sub_elements)) + return type(ele)(*(curl_to_grad(e) for e in ele.sub_elements)) elif isinstance(ele, finat.ufl.RestrictedElement): - return finat.ufl.RestrictedElement(curl_to_grad(ele._element, mesh), ele.restriction_domain()) + return finat.ufl.RestrictedElement(curl_to_grad(ele._element), ele.restriction_domain()) else: cell = ele.cell family = ele.family() @@ -238,25 +238,25 @@ def curl_to_grad(ele, mesh): return finat.ufl.FiniteElement(family, cell=cell, degree=degree, variant=variant) -def div_to_curl(ele, mesh): +def div_to_curl(ele): if isinstance(ele, finat.ufl.VectorElement): - return type(ele)(div_to_curl(ele._sub_element, mesh), dim=ele.num_sub_elements) + return type(ele)(div_to_curl(ele._sub_element), dim=ele.num_sub_elements) elif isinstance(ele, finat.ufl.TensorElement): - return type(ele)(div_to_curl(ele._sub_element, mesh), shape=ele.value_shape(mesh), symmetry=ele.symmetry()) + return type(ele)(div_to_curl(ele._sub_element), shape=ele._shape, symmetry=ele.symmetry()) elif isinstance(ele, finat.ufl.MixedElement): - return type(ele)(*(div_to_curl(e, mesh) for e in ele.sub_elements)) + return type(ele)(*(div_to_curl(e) for e in ele.sub_elements)) elif isinstance(ele, finat.ufl.RestrictedElement): - return finat.ufl.RestrictedElement(div_to_curl(ele._element, mesh), ele.restriction_domain()) + return finat.ufl.RestrictedElement(div_to_curl(ele._element), ele.restriction_domain()) elif isinstance(ele, finat.ufl.EnrichedElement): - return type(ele)(*(div_to_curl(e, mesh) for e in reversed(ele._elements))) + return type(ele)(*(div_to_curl(e) for e in reversed(ele._elements))) elif isinstance(ele, finat.ufl.TensorProductElement): - return type(ele)(*(div_to_curl(e, mesh) for e in ele.sub_elements), cell=ele.cell) + return type(ele)(*(div_to_curl(e) for e in ele.sub_elements), cell=ele.cell) elif isinstance(ele, finat.ufl.WithMapping): - return type(ele)(div_to_curl(ele.wrapee, mesh), ele.mapping()) + return type(ele)(div_to_curl(ele.wrapee), ele.mapping()) elif isinstance(ele, finat.ufl.BrokenElement): - return type(ele)(div_to_curl(ele._element, mesh)) + return type(ele)(div_to_curl(ele._element)) elif isinstance(ele, finat.ufl.HDivElement): - return finat.ufl.HCurlElement(div_to_curl(ele._element, mesh)) + return finat.ufl.HCurlElement(div_to_curl(ele._element)) elif isinstance(ele, finat.ufl.HCurlElement): raise ValueError("Expecting an H(div) element") else: diff --git a/firedrake/preconditioners/pmg.py b/firedrake/preconditioners/pmg.py index d7c11aed51..cebbb5f74a 100644 --- a/firedrake/preconditioners/pmg.py +++ b/firedrake/preconditioners/pmg.py @@ -131,9 +131,7 @@ def initialize(self, obj): elements = [ele] while True: try: - ele_ = self.coarsen_element(ele) - assert ele_.value_shape(V.mesh()) == ele.value_shape(V.mesh()) - ele = ele_ + ele = self.coarsen_element(ele) except ValueError: break elements.append(ele) @@ -1098,7 +1096,7 @@ def make_mapping_code(Q, cmapping, fmapping, t_in, t_out): if B: tensor = ufl.dot(B, tensor) if tensor else B if tensor is None: - tensor = ufl.Identity(Q.ufl_element().value_shape(Q.mesh())[0]) + tensor = ufl.Identity(Q.value_shape[0]) u = ufl.Coefficient(Q) expr = ufl.dot(tensor, u) @@ -1347,8 +1345,8 @@ def make_blas_kernels(self, Vf, Vc): in_place_mapping = True except Exception: qelem = finat.ufl.FiniteElement("DQ", cell=felem.cell, degree=PMGBase.max_degree(felem)) - if felem.value_shape(Vf.mesh()): - qelem = finat.ufl.TensorElement(qelem, shape=felem.value_shape(Vf.mesh()), symmetry=felem.symmetry()) + if Vf.value_shape: + qelem = finat.ufl.TensorElement(qelem, shape=Vf.value_shape, symmetry=felem.symmetry()) Qf = firedrake.FunctionSpace(Vf.mesh(), qelem) mapping_output = make_mapping_code(Qf, cmapping, fmapping, "t0", "t1") diff --git a/firedrake/pyplot/pgf.py b/firedrake/pyplot/pgf.py index 20fc566a82..6640454679 100644 --- a/firedrake/pyplot/pgf.py +++ b/firedrake/pyplot/pgf.py @@ -217,12 +217,12 @@ def pgfplot(f, filename, degree=1, complex_component='real', print_latex_example raise NotImplementedError(f"Not yet implemented for functions in spatial dimension {dim}") if mesh.extruded: raise NotImplementedError("Not yet implemented for functions on extruded meshes") - if elem.value_shape(mesh): + if V.value_shape: raise NotImplementedError("Currently only implemeted for scalar functions") coordelem = get_embedding_dg_element(mesh.coordinates.function_space().ufl_element(), (dim, )).reconstruct(degree=degree, variant="equispaced") coordV = FunctionSpace(mesh, coordelem) coords = Function(coordV).interpolate(SpatialCoordinate(mesh)) - elemdg = get_embedding_dg_element(elem, elem.value_shape(mesh)).reconstruct(degree=degree, variant="equispaced") + elemdg = get_embedding_dg_element(elem, V.value_shape).reconstruct(degree=degree, variant="equispaced") Vdg = FunctionSpace(mesh, elemdg) fdg = Function(Vdg) method = get_embedding_method_for_checkpointing(elem) diff --git a/firedrake/slate/static_condensation/hybridization.py b/firedrake/slate/static_condensation/hybridization.py index 14872f015a..997f969684 100644 --- a/firedrake/slate/static_condensation/hybridization.py +++ b/firedrake/slate/static_condensation/hybridization.py @@ -61,7 +61,7 @@ def initialize(self, pc): if len(V) != 2: raise ValueError("Expecting two function spaces.") - if all(Vi.ufl_element().value_shape(Vi.mesh()) for Vi in V): + if all(Vi.value_shape for Vi in V): raise ValueError("Expecting an H(div) x L2 pair of spaces.") # Automagically determine which spaces are vector and scalar diff --git a/firedrake/ufl_expr.py b/firedrake/ufl_expr.py index 910e5c0c1f..1f9a66df75 100644 --- a/firedrake/ufl_expr.py +++ b/firedrake/ufl_expr.py @@ -76,8 +76,7 @@ def reconstruct(self, function_space=None, return self if not isinstance(number, int): raise TypeError(f"Expecting an int, not {number}") - mesh = self.function_space().mesh() - if function_space.ufl_element().value_shape(mesh) != self.ufl_element().value_shape(mesh): + if function_space.value_shape != self.function_space().value_shape: raise ValueError("Cannot reconstruct an Argument with a different value shape.") return Argument(function_space, number, part=part) @@ -141,8 +140,7 @@ def reconstruct(self, function_space=None, return self if not isinstance(number, int): raise TypeError(f"Expecting an int, not {number}") - mesh = self.function_space().mesh() - if function_space.ufl_element().value_shape(mesh) != self.ufl_element().value_shape(mesh): + if function_space.value_shape != self.function_space().value_shape: raise ValueError("Cannot reconstruct an Coargument with a different value shape.") return Coargument(function_space, number, part=part) diff --git a/tests/output/test_io_function.py b/tests/output/test_io_function.py index e8b833afe1..64be091afe 100644 --- a/tests/output/test_io_function.py +++ b/tests/output/test_io_function.py @@ -67,7 +67,7 @@ def _get_mesh(cell_type, comm): def _get_expr(V): mesh = V.mesh() dim = mesh.geometric_dimension() - shape = V.ufl_element().value_shape(mesh) + shape = V.value_shape if dim == 2: x, y = SpatialCoordinate(mesh) z = x * y diff --git a/tests/output/test_io_timestepping.py b/tests/output/test_io_timestepping.py index 9a8c50c020..b2a66648bb 100644 --- a/tests/output/test_io_timestepping.py +++ b/tests/output/test_io_timestepping.py @@ -16,7 +16,7 @@ def _get_expr(V, i): mesh = V.mesh() element = V.ufl_element() x, y = SpatialCoordinate(mesh) - shape = element.value_shape(mesh) + shape = V.value_shape if element.family() == "Real": return 7. + i * i elif shape == (): diff --git a/tests/regression/test_ensembleparallelism.py b/tests/regression/test_ensembleparallelism.py index faa3db99dc..49db8e7d3f 100644 --- a/tests/regression/test_ensembleparallelism.py +++ b/tests/regression/test_ensembleparallelism.py @@ -205,13 +205,13 @@ def test_ensemble_reduce(ensemble, mesh, W, urank, urank_sum, root, blocking): parallel_assert( lambda: error < 1e-12, subset=root_ranks, - msg=f"{error = :.5f}" + msg=f"{error=:.5f}" ) error = errornorm(Function(W).assign(10), u_reduce) parallel_assert( lambda: error < 1e-12, subset={range(COMM_WORLD.size)} - root_ranks, - msg=f"{error = :.5f}" + msg=f"{error=:.5f}" ) # check that u_reduce dat vector is still synchronised @@ -347,7 +347,7 @@ def test_send_and_recv(ensemble, mesh, W, blocking): parallel_assert( lambda: error < 1e-12, subset=root_ranks, - msg=f"{error = :.5f}" + msg=f"{error=:.5f}" ) diff --git a/tests/regression/test_expressions.py b/tests/regression/test_expressions.py index f2584bd6e4..b1fd8feb64 100644 --- a/tests/regression/test_expressions.py +++ b/tests/regression/test_expressions.py @@ -295,7 +295,7 @@ def test_assign_with_different_meshes_fails(): def test_assign_vector_const_to_vfs(vcg1): f = Function(vcg1) - c = Constant(range(1, f.ufl_element().value_shape(vcg1.mesh())[0]+1)) + c = Constant(range(1, f.function_space().value_shape[0]+1)) f.assign(c) assert np.allclose(f.dat.data_ro, c.dat.data_ro) diff --git a/tests/regression/test_fas_snespatch.py b/tests/regression/test_fas_snespatch.py index d2f755eb5f..63deb3ab5d 100644 --- a/tests/regression/test_fas_snespatch.py +++ b/tests/regression/test_fas_snespatch.py @@ -170,8 +170,7 @@ def test_snespatch(mesh, CG1, solver_params): f = Constant(1, domain=mesh) F = inner(grad(u), grad(v))*dx - inner(f, v)*dx + inner(u**3 - u, v)*dx - z = zero(CG1.ufl_element().value_shape(mesh)) - bcs = DirichletBC(CG1, z, "on_boundary") + bcs = DirichletBC(CG1, 0, "on_boundary") nvproblem = NonlinearVariationalProblem(F, u, bcs=bcs) solver = NonlinearVariationalSolver(nvproblem, solver_parameters=solver_params) diff --git a/tests/regression/test_fdm.py b/tests/regression/test_fdm.py index b03a6fafb2..edd96acdb7 100644 --- a/tests/regression/test_fdm.py +++ b/tests/regression/test_fdm.py @@ -90,7 +90,7 @@ def build_riesz_map(V, d): x = SpatialCoordinate(V.mesh()) x -= Constant([0.5]*len(x)) - if V.ufl_element().value_shape(V.mesh()) == (): + if V.value_shape == (): u_exact = exp(-10*dot(x, x)) u_bc = u_exact else: @@ -195,7 +195,7 @@ def test_variable_coefficient(mesh): subs = ("on_boundary",) if mesh.cell_set._extruded: subs += ("top", "bottom") - bcs = [DirichletBC(V, zero(V.ufl_element().value_shape(mesh)), sub) for sub in subs] + bcs = [DirichletBC(V, 0, sub) for sub in subs] uh = Function(V) problem = LinearVariationalProblem(a, L, uh, bcs=bcs) diff --git a/tests/regression/test_function.py b/tests/regression/test_function.py index cdc72ae09c..b42b71762a 100644 --- a/tests/regression/test_function.py +++ b/tests/regression/test_function.py @@ -97,7 +97,7 @@ def test_mismatching_shape_interpolation(V): VV = VectorFunctionSpace(V.mesh(), 'CG', 1) f = Function(VV) with pytest.raises(RuntimeError): - f.interpolate(Constant([1] * (VV.ufl_element().value_shape(VV.mesh())[0] + 1))) + f.interpolate(Constant([1] * (VV.value_shape[0] + 1))) def test_function_val(V): diff --git a/tests/regression/test_function_spaces.py b/tests/regression/test_function_spaces.py index 220c02bfde..dbb81ec700 100644 --- a/tests/regression/test_function_spaces.py +++ b/tests/regression/test_function_spaces.py @@ -276,7 +276,7 @@ def test_reconstruct_component(space, dg0, rt1, mesh, mesh2, dual): Z = {"dg0": dg0, "rt1": rt1}[space] if dual: Z = Z.dual() - for component in range(Z.value_size): + for component in range(len(Z)): V1 = Z.sub(component) V2 = V1.reconstruct(mesh=mesh2) assert is_dual(V1) == is_dual(V2) == dual @@ -293,7 +293,7 @@ def test_reconstruct_sub_component(dg0, rt1, mesh, mesh2, dual): if dual: Z = Z.dual() for index, Vsub in enumerate(Z): - for component in range(Vsub.value_size): + for component in range(len(Vsub._components)): V1 = Z.sub(index).sub(component) V2 = V1.reconstruct(mesh=mesh2) assert is_dual(V1) == is_dual(V2) == dual diff --git a/tests/regression/test_interpolate.py b/tests/regression/test_interpolate.py index 4462c4dcb8..4a963aa36e 100644 --- a/tests/regression/test_interpolate.py +++ b/tests/regression/test_interpolate.py @@ -471,7 +471,7 @@ def test_interpolation_tensor_convergence(): V = TensorFunctionSpace(mesh, "RT", 1) x, y = SpatialCoordinate(mesh) - vs = V.ufl_element().value_shape(mesh) + vs = V.value_shape expr = as_tensor(np.asarray([ sin(2*pi*x*(i+1))*cos(4*pi*y*i) for i in range(np.prod(vs, dtype=int)) diff --git a/tests/regression/test_interpolate_cross_mesh.py b/tests/regression/test_interpolate_cross_mesh.py index b0a87bfa9b..94252c3df6 100644 --- a/tests/regression/test_interpolate_cross_mesh.py +++ b/tests/regression/test_interpolate_cross_mesh.py @@ -361,7 +361,7 @@ def test_interpolate_unitsquare_mixed(): # Can't go from non-mixed to mixed V_src_2 = VectorFunctionSpace(m_src, "CG", 1) - assert V_src_2.ufl_element().value_shape == V_src.ufl_element().value_shape(m_src) + assert V_src_2.value_shape == V_src.value_shape f_src_2 = Function(V_src_2) with pytest.raises(NotImplementedError): assemble(interpolate(f_src_2, V_dest)) diff --git a/tests/regression/test_interpolate_vs_project.py b/tests/regression/test_interpolate_vs_project.py index d943abeba3..84fabd6a45 100644 --- a/tests/regression/test_interpolate_vs_project.py +++ b/tests/regression/test_interpolate_vs_project.py @@ -37,7 +37,7 @@ def test_interpolate_vs_project(V): elif dim == 3: x, y, z = SpatialCoordinate(mesh) - shape = V.ufl_element().value_shape(mesh) + shape = V.value_shape if dim == 2: if len(shape) == 0: expression = x + y diff --git a/tests/regression/test_p1pc.py b/tests/regression/test_p1pc.py index 7c9bb6f195..7f1d27e2d2 100644 --- a/tests/regression/test_p1pc.py +++ b/tests/regression/test_p1pc.py @@ -36,7 +36,7 @@ def test_p_independence(mesh, expected): L = inner(Constant(1), v)*dx - bcs = DirichletBC(V, zero(V.ufl_element().value_shape(mesh)), "on_boundary") + bcs = DirichletBC(V, 0, "on_boundary") uh = Function(V) problem = LinearVariationalProblem(a, L, uh, bcs=bcs) diff --git a/tests/regression/test_patch_pc.py b/tests/regression/test_patch_pc.py index 9abe5e94bd..766da8b611 100644 --- a/tests/regression/test_patch_pc.py +++ b/tests/regression/test_patch_pc.py @@ -38,7 +38,7 @@ def test_jacobi_sor_equivalence(mesh, problem_type, multiplicative): R = TensorFunctionSpace(mesh, "CG", 1) V = P*Q*R - shape = V.ufl_element().value_shape(mesh) + shape = V.value_shape rhs = numpy.full(shape, 1, dtype=float) u = TrialFunction(V) @@ -48,16 +48,16 @@ def test_jacobi_sor_equivalence(mesh, problem_type, multiplicative): # We also test patch pc with kernel argument compression. i = 1 # only active index f = Function(V) - fval = numpy.full(V.sub(i).ufl_element().value_shape(mesh), 1.0, dtype=float) + fval = numpy.full(V.sub(i).value_shape, 1.0, dtype=float) f.sub(i).interpolate(Constant(fval)) a = (inner(f[i], f[i]) * inner(grad(u), grad(v)))*dx L = inner(Constant(rhs), v)*dx - bcs = [DirichletBC(Q, zero(Q.ufl_element().value_shape(mesh)), "on_boundary") + bcs = [DirichletBC(Q, 0, "on_boundary") for Q in V.subfunctions] else: a = inner(grad(u), grad(v))*dx L = inner(Constant(rhs), v)*dx - bcs = DirichletBC(V, zero(V.ufl_element().value_shape(mesh)), "on_boundary") + bcs = DirichletBC(V, 0, "on_boundary") uh = Function(V) problem = LinearVariationalProblem(a, L, uh, bcs=bcs) diff --git a/tests/regression/test_patch_precompute_element_tensors.py b/tests/regression/test_patch_precompute_element_tensors.py index a754f85e84..33bdf64c19 100644 --- a/tests/regression/test_patch_precompute_element_tensors.py +++ b/tests/regression/test_patch_precompute_element_tensors.py @@ -27,8 +27,7 @@ def test_patch_precompute_element_tensors(mesh, V): f = Constant((1, 1)) F = inner(grad(u), grad(v))*dx + gamma*inner(div(u), div(v))*dx - inner(f, v)*dx + avg(inner(u, v))*dS - z = zero(V.ufl_element().value_shape(mesh)) - bcs = DirichletBC(V, z, "on_boundary") + bcs = DirichletBC(V, 0, "on_boundary") sp = { "mat_type": "matfree",