Struct ellalgo_rs::oracles::profit_oracle::ProfitOracleQ
source · pub struct ProfitOracleQ { /* private fields */ }
Expand description
The ProfitOracleQ struct is an oracle for the profit maximization problem in a discrete version.
Properties:
omega
: Theomega
property is an instance of theProfitOracle
struct. It is used to calculate the profit for a given input.yd
: The variableyd
is an array that represents the discrete version of y values
Implementations§
source§impl ProfitOracleQ
impl ProfitOracleQ
sourcepub fn new(
p: f64,
scale: f64,
k: f64,
a: Array1<f64>,
price_out: Array1<f64>
) -> Self
pub fn new( p: f64, scale: f64, k: f64, a: Array1<f64>, price_out: Array1<f64> ) -> Self
The function new
constructs a new ProfitOracleQ
object with given parameters.
Arguments:
p
: The parameterp
represents the market price per unit. It is a floating-point number (f64) that indicates the price at which a unit of the product is sold in the market.scale
: The “scale” parameter represents the scale of production, which refers to the level of output or production of a particular good or service. It indicates the quantity of goods or services produced within a given time period.k
: A given constant that restricts the quantity of x1. It is used to limit the quantity of a particular input (x1) in the production process.a
: The parametera
represents the output elasticities. Output elasticity measures the responsiveness of the quantity of output to a change in the input quantity. It indicates how much the quantity of output changes in response to a change in the quantity of input.price_out
: The parameterprice_out
represents the output price. It is an array that contains the prices of the outputs.
Returns:
The new
function is returning an instance of the ProfitOracleQ
struct.
Trait Implementations§
source§impl OracleOptimQ<ArrayBase<OwnedRepr<f64>, Dim<[usize; 1]>>> for ProfitOracleQ
impl OracleOptimQ<ArrayBase<OwnedRepr<f64>, Dim<[usize; 1]>>> for ProfitOracleQ
source§fn assess_optim_q(
&mut self,
y: &Array1<f64>,
tea: &mut f64,
retry: bool
) -> ((Array1<f64>, f64), bool, Array1<f64>, bool)
fn assess_optim_q( &mut self, y: &Array1<f64>, tea: &mut f64, retry: bool ) -> ((Array1<f64>, f64), bool, Array1<f64>, bool)
The assess_optim_q
function takes in an input quantity y
in log scale, updates the best-so-far
optimal value tea
, and returns a cut and the updated best-so-far value.
Arguments:
y
: The parametery
is an input quantity in log scale. It is of typeArr
, which is likely an array or vector type.tea
: The parametertea
represents the best-so-far optimal value. It is a mutable reference to af64
value, which means it can be modified within the function.retry
: A boolean value indicating whether it is a retry or not.
type CutChoices = f64
Auto Trait Implementations§
impl RefUnwindSafe for ProfitOracleQ
impl Send for ProfitOracleQ
impl Sync for ProfitOracleQ
impl Unpin for ProfitOracleQ
impl UnwindSafe for ProfitOracleQ
Blanket Implementations§
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
Mutably borrows from an owned value. Read more