pub struct PBEProblem {
pub logic: String,
pub synthfuns: Vec<SynthFun>,
pub problem_index: usize,
pub examples: IOExamples,
}
Expand description
A struct representing a synthesis problem to be solved.
This structure contains four fields: logic
, a string specifying the logic or domain in which the synthesis problem is defined; synthfuns
, a vector of SynthFun
instances representing the functions to be synthesized as part of solving the problem; problem_index
, a usize value denoting the particular index or identifier of this problem within a broader set of problems; and examples
, an IOExamples
instance that holds input-output exemplars relevant to the synthesis task, to ground the problem solution in practical demonstrations of expected behavior.
Fields§
§logic: String
§synthfuns: Vec<SynthFun>
§problem_index: usize
§examples: IOExamples
Implementations§
Source§impl PBEProblem
impl PBEProblem
Sourcepub fn synthfun(&self) -> &SynthFun
pub fn synthfun(&self) -> &SynthFun
Provides access to a specific SynthFun
based on the current problem_index
.
This function retrieves a reference to the SynthFun
within the synthfuns
vector of the PBEProblem
instance.
The problem_index
specifies which SynthFun
to access, allowing direct retrieval of the active synthesis function’s details, such as its signature and configuration, from the list of available functions.
Sourcepub fn parse(input: &str) -> Result<PBEProblem, Error>
pub fn parse(input: &str) -> Result<PBEProblem, Error>
Parses a string input to create an instance of PBEProblem
.
This method uses the ProblemParser
to initially parse the input string according to predefined grammar rules, extracting relevant components for logic, synthesis functions, examples, and checks.
It specifically targets obtaining the logic definition, synthesizing problem configurations, and IO examples used in problem-solving.
The method processes these components to extract the inner details of logic and synthesis, where synthesis functions are parsed individually.
A verification step ensures that only one main synthesis function (synth-fun
) is designated as the primary problem by filtering out those marked as subproblems.
The synthesis examples are parsed to ensure they match the signature of the main synthesis function.
It constructs and returns a PBEProblem
comprising the logic, a vector of synthesis functions, the index of the main problem, and the parsed examples.
The method will fail if the input does not conform to expected structures or logic, returning an error.
Trait Implementations§
Auto Trait Implementations§
impl Freeze for PBEProblem
impl RefUnwindSafe for PBEProblem
impl Send for PBEProblem
impl Sync for PBEProblem
impl Unpin for PBEProblem
impl UnwindSafe for PBEProblem
Blanket Implementations§
Source§impl<T> AllocForAny<T> for T
impl<T> AllocForAny<T> for T
Source§fn galloc(self) -> &'static T
fn galloc(self) -> &'static T
Provides a method to allocate an instance of T
on the heap with a static lifetime.
This implementation of galloc
takes ownership of the T
instance and uses the alloc
function to place it in a location with a static lifetime, presumably managing it in a way that ensures its persistence for the duration of the program.
This can be particularly useful for scenarios where a static lifetime is required, such as when interfacing with systems or patterns that necessitate global state or long-lived data.
Source§fn galloc_mut(self) -> &'static T
fn galloc_mut(self) -> &'static T
Provides a method that moves the instance and returns a reference to it allocated with a static lifetime.
This method utilizes alloc_mut
to perform the allocation, likely involving allocating the resource in a manner that ensures it lives for the entire duration of the application.
These semantics allow the user to safely assume that the reference will not expire during the program’s execution, making it suitable for long-lived data structures or operations that require such guarantees.
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more