Dcf

Struct Dcf 

Source
pub struct Dcf { /* private fields */ }
Expand description

DCF and Valuation API endpoints

Implementations§

Source§

impl Dcf

Source

pub async fn get_dcf(&self, symbol: &str) -> Result<Vec<DcfModel>>

Get current DCF valuation for a symbol

Returns the discounted cash flow (DCF) valuation which estimates the intrinsic value of a stock based on its future cash flows.

§Arguments
  • symbol - Stock symbol (e.g., “AAPL”)
§Example
let client = FmpClient::new()?;
let dcf = client.dcf().get_dcf("AAPL").await?;
for valuation in dcf {
    println!("Symbol: {}, DCF: ${:.2}, Stock Price: ${:.2}",
        valuation.symbol,
        valuation.dcf.unwrap_or(0.0),
        valuation.stock_price.unwrap_or(0.0));
}
Source

pub async fn get_historical_dcf( &self, symbol: &str, ) -> Result<Vec<HistoricalDcf>>

Get historical DCF valuations for a symbol

Returns DCF valuations over time, allowing comparison of historical intrinsic values vs. actual stock prices.

§Arguments
  • symbol - Stock symbol (e.g., “AAPL”)
§Example
let client = FmpClient::new()?;
let history = client.dcf().get_historical_dcf("AAPL").await?;
for record in history.iter().take(5) {
    println!("{}: DCF ${:.2} vs Stock ${:.2}",
        record.date,
        record.dcf.unwrap_or(0.0),
        record.stock_price.unwrap_or(0.0));
}
Source

pub async fn get_advanced_dcf(&self, symbol: &str) -> Result<Vec<AdvancedDcf>>

Get advanced DCF with detailed assumptions

Returns DCF valuation with detailed modeling assumptions including revenue growth, margins, tax rates, WACC, and projected cash flows.

§Arguments
  • symbol - Stock symbol (e.g., “AAPL”)
§Example
let client = FmpClient::new()?;
let dcf = client.dcf().get_advanced_dcf("AAPL").await?;
for valuation in dcf {
    println!("DCF: ${:.2}", valuation.dcf.unwrap_or(0.0));
    println!("Revenue Growth: {:.2}%", valuation.revenue_growth.unwrap_or(0.0) * 100.0);
    println!("WACC: {:.2}%", valuation.wacc.unwrap_or(0.0) * 100.0);
}
Source

pub async fn get_levered_dcf(&self, symbol: &str) -> Result<Vec<LeveredDcf>>

Get levered DCF (equity value after debt)

Returns DCF valuation accounting for debt, providing equity value rather than enterprise value.

§Arguments
  • symbol - Stock symbol (e.g., “AAPL”)
§Example
let client = FmpClient::new()?;
let dcf = client.dcf().get_levered_dcf("AAPL").await?;
for valuation in dcf {
    println!("Levered DCF: ${:.2}", valuation.levered_dcf.unwrap_or(0.0));
    println!("Enterprise Value: ${:.2}B", valuation.enterprise_value.unwrap_or(0.0) / 1_000_000_000.0);
    println!("Total Debt: ${:.2}B", valuation.total_debt.unwrap_or(0.0) / 1_000_000_000.0);
}
Source

pub async fn get_enterprise_value( &self, symbol: &str, ) -> Result<Vec<EnterpriseValue>>

Get company enterprise value

Returns the enterprise value calculation, which represents the total value of a company (market cap + debt - cash).

§Arguments
  • symbol - Stock symbol (e.g., “AAPL”)
§Example
let client = FmpClient::new()?;
let ev = client.dcf().get_enterprise_value("AAPL").await?;
for value in ev {
    println!("Market Cap: ${:.2}B", value.market_capitalization.unwrap_or(0.0) / 1_000_000_000.0);
    println!("+ Debt: ${:.2}B", value.add_total_debt.unwrap_or(0.0) / 1_000_000_000.0);
    println!("- Cash: ${:.2}B", value.minus_cash_and_cash_equivalents.unwrap_or(0.0) / 1_000_000_000.0);
    println!("= Enterprise Value: ${:.2}B", value.enterprise_value.unwrap_or(0.0) / 1_000_000_000.0);
}

Auto Trait Implementations§

§

impl Freeze for Dcf

§

impl !RefUnwindSafe for Dcf

§

impl Send for Dcf

§

impl Sync for Dcf

§

impl Unpin for Dcf

§

impl !UnwindSafe for Dcf

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,