Foreign Exchange Risk Management Analysis using Python in Google Colab
Description
This project aims to equip data analysts and finance professionals with the necessary skills to manage foreign exchange risks by leveraging Python's capabilities within a Google Colab environment. We will create a detailed and hands-on data analysis workflow, ranging from data loading and preprocessing to advanced risk analytics and visualization. The dataset, although fabricated for educational purposes, will simulate real-world complexities encountered by multinational companies.
The original prompt:
Let's work through a detailed example of analyzing a foreign exchange risk management dataset for a large multinational company in a Google Collab data notebook using Python.
The dataset is something you can make up but make it comprehensive. Let's work through a variety of different types of real-world analysis we can complete, and you can show the code we can use.
Imagine you are directly supporting work in the data notebook so be as detailed as possible and make sure the code actually will work on the first go.
Foreign Exchange Risk (also known as FX risk, exchange rate risk, or currency risk) is the financial risk that exists when a financial transaction is denominated in a currency other than the domestic currency of the company. This risk arises due to fluctuations in the exchange rates between the domestic currency and the foreign currency.
Setup Instructions for Google Colab Notebook
In this section, we'll set up the necessary environment within a Google Colab notebook to begin analyzing and managing foreign exchange risk using Python.
1. Install Necessary Libraries
First, ensure you have all the necessary Python libraries installed. The primary libraries we'll be using are pandas, numpy, matplotlib, and yfinance for data acquisition.
# Install yfinance library for financial data
!pip install yfinance
# Import necessary libraries
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import yfinance as yf
2. Fetch Historical Exchange Rate Data
For our analysis, we need historical exchange rate data. We will use Yahoo Finance API to get this data.
# Function to fetch exchange rate data
def get_exchange_rate_data(base_currency, target_currency, start_date, end_date):
pair = f'{base_currency}{target_currency}=X'
data = yf.download(pair, start=start_date, end=end_date)
return data
# Example - Fetching data for USD to EUR exchange rates from 2020-01-01 to 2023-01-01
base_currency = "USD"
target_currency = "EUR"
start_date = "2020-01-01"
end_date = "2023-01-01"
exchange_rate_data = get_exchange_rate_data(base_currency, target_currency, start_date, end_date)
exchange_rate_data.head()
3. Basic Data Exploration
Performing some basic exploration on the fetched exchange rate data to understand its structure and characteristics.
# Display the first few rows of the data
print(exchange_rate_data.head())
# Plotting the exchange rate over time
plt.figure(figsize=(12, 6))
plt.plot(exchange_rate_data['Close'], label=f'{base_currency}/{target_currency} Exchange Rate')
plt.title(f'{base_currency} to {target_currency} Exchange Rate Over Time')
plt.xlabel('Date')
plt.ylabel('Exchange Rate')
plt.legend()
plt.show()
4. Calculating Returns
Calculate the returns to understand the volatility and potential risks involved with the currency pair.
# Calculate daily returns
exchange_rate_data['Returns'] = exchange_rate_data['Close'].pct_change()
# Plotting the returns over time
plt.figure(figsize=(12, 6))
plt.plot(exchange_rate_data['Returns'], label=f'{base_currency}/{target_currency} Returns')
plt.title(f'Returns for {base_currency} to {target_currency} Exchange Rate Over Time')
plt.xlabel('Date')
plt.ylabel('Returns')
plt.legend()
plt.show()
Summary
By following the steps above, you have set up the environment and performed basic data fetching and exploration for analyzing foreign exchange risk. Continue building upon this foundation to develop more advanced analyses and risk management strategies tailored to your specific multinational company needs.
In subsequent parts of the project, we will delve deeper into methodologies for quantifying and managing FX risk, using advanced statistical and machine learning techniques.
Setting Up Google Colab and Python Environment
Introduction
As part of our project on analyzing and managing foreign exchange risk for a large multinational company, we will leverage Google Colab to set up and manage our Python environment. This guide provides a practical implementation of the steps to get started with Google Colab.
Step-by-Step Implementation
Step 1: Access Google Colab
Open your web browser and navigate to Google Colab.
Sign in with your Google account.
Step 2: Create a New Notebook
In the top left corner, click on the File menu.
Select New Notebook.
Step 3: Rename the Notebook
Click on the notebook name, typically Untitled.ipynb, at the top.
Rename it to something meaningful, e.g., Forex_Risk_Analysis.
Step 4: Install Necessary Packages
You'll need various Python packages to help analyze foreign exchange risks. Install them by running the following command in a cell:
After installing the necessary packages, import them with the following Python code:
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import seaborn as sns
import statsmodels.api as sm
import yfinance as yf
Step 6: Set Up Data Sources
Use yfinance to download foreign exchange rate data. For example, to get historical exchange rates for USD to EUR:
# Download historical FX data for USD to EUR
fx_data = yf.download('EURUSD=X', start='2020-01-01', end='2023-01-01')
Step 7: Display a Sample of the Data
Verify that the data is correctly downloaded by displaying a sample:
# Display the first few rows of the dataset
fx_data.head()
Step 8: Basic Data Exploration
Perform basic exploratory data analysis (EDA) to understand the structure and characteristics of the data:
# Display basic summary statistics
fx_data.describe()
# Plot closing prices over time
plt.figure(figsize=(10, 5))
plt.plot(fx_data['Close'])
plt.title('USD to EUR Exchange Rate')
plt.xlabel('Date')
plt.ylabel('Close Price')
plt.grid(True)
plt.show()
Step 9: Save Your Work
Save your notebook frequently to avoid losing any progress.
Click on the File menu.
Select Save.
Alternatively, use the shortcut Ctrl+S (or Cmd+S on a Mac).
Step 10: Collaborate and Share
Invite collaborators or share your notebook:
Click on the Share button in the top right corner.
Enter the email addresses of your collaborators and set permissions.
Conclusion
This concludes the setup of our Google Colab environment for analyzing and managing foreign exchange risk. By following these steps, you can ensure that your Python environment is ready for the subsequent analysis steps.
Ensure that you proceed with thorough data analysis, visualization, and modeling in the subsequent sections of your project, referencing the data and tools set up here.
Loading and Exploring the Dataset
In this section, we will demonstrate how to load and explore the dataset using Python in a Google Colab notebook. Given that the previous sections have already set up the environment, we can directly move to the practical implementation.
1. Importing Libraries
First, we will import the necessary libraries for data manipulation and visualization.
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import seaborn as sns
2. Loading the Dataset
Assume that the dataset is stored in a CSV file named forex_data.csv and is available in the Google Drive. We will use Google Colab's built-in support for Google Drive.
from google.colab import drive
drive.mount('/content/drive')
# Load the dataset
file_path = '/content/drive/My Drive/forex_data.csv'
df = pd.read_csv(file_path)
3. Basic Exploration
3.1. Checking the First Few Rows
To understand the structure of the dataset, we will display the first few rows.
df.head()
3.2. Dataset Overview
Get a quick overview of the dataset, including the number of rows and columns, column names, and data types.
df.info()
3.3. Summary Statistics
Generate descriptive statistics to get an idea of the central tendency and distribution of numerical features.
df.describe()
4. Null Values and Data Types
4.1. Checking for Null Values
It's crucial to know if there are any missing values in the dataset.
df.isnull().sum()
4.2. Data Types and Conversion
Ensure that columns have appropriate data types (e.g., dates should be in datetime format).
df['date'] = pd.to_datetime(df['date'])
df.dtypes
5. Visual Exploration
5.1. Correlation Matrix
Visualizing the correlation across different currency pairs to identify any linear relationships.
This section provided practical steps to load and explore the dataset in a Google Colab notebook. Steps included importing necessary libraries, loading the dataset, basic exploratory data analysis (EDA), checking for null values, and visualizing the data. This foundational exploration helps to understand the dataset better before moving on to more complex analysis and modeling.
By following these steps, you can ensure that your dataset is clean, well-understood, and ready for further analysis in your foreign exchange risk management project.
Data Cleaning and Preprocessing
Here’s how to perform data cleaning and preprocessing for your foreign exchange risk analysis project. We’ll use Python as our programming language, and these steps will assume that you have already loaded your dataset in a Google Colab notebook.
Handling Missing Values
Identify Missing Values:
# Check for missing values in dataset
missing_values = dataset.isnull().sum()
print(missing_values)
Remove or Impute Missing Values:
Remove:
# Remove rows with missing values
dataset_cleaned = dataset.dropna()
Impute:
# Impute missing values with mean for numeric columns
dataset_filled = dataset.fillna(dataset.mean())
# Or, if you want to fill with a specific value
dataset_filled = dataset.fillna(0) # Example: filling with 0
Handling Duplicates
Identify Duplicates:
# Check for duplicates in the dataset
duplicates = dataset.duplicated().sum()
print(f'Total duplicates: {duplicates}')
# Assume 'Target' is the name of the target variable column
X = dataset_scaled.drop(columns='Target')
y = dataset_scaled['Target']
Your dataset X is now prepared and cleaned, ready for analysis or feeding into a model for further processing as part of your foreign exchange risk analysis project.
Following the above steps should ensure your data is clean, consistent, and ready for analytical or predictive modeling tasks.
Part 5: Visualizing Exchange Rate Trends
Importing Necessary Libraries
import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns
Load the Preprocessed Dataset
Make sure you load the preprocessed dataset that you worked on in the previous steps. Assuming it is stored as exchange_rates_clean.csv:
# Load the data
exchange_rates = pd.read_csv('exchange_rates_clean.csv', parse_dates=['Date'])
exchange_rates.set_index('Date', inplace=True)
Choosing Currencies to Visualize
Let's assume you want to visualize the exchange rates between USD, EUR, and GBP.
Adding a rolling average to smooth out the trends and help identify overall patterns.
# Calculate the rolling average
rolling_window = 30 # 30-day rolling average
exchange_rates_rolling = exchange_rates.rolling(window=rolling_window).mean()
# Plot with rolling average
plt.figure(figsize=(14, 7))
sns.lineplot(data=exchange_rates_rolling)
plt.title('Exchange Rate Trends with Rolling Average')
plt.xlabel('Date')
plt.ylabel('Exchange Rate')
plt.legend(currencies)
plt.show()
Adding Annotations
Annotations help to highlight significant trends or events in the exchange rate data. Suppose we want to annotate specific points of USD exchange rate:
plt.figure(figsize=(14, 7))
sns.lineplot(data=exchange_rates)
plt.title('Exchange Rate Trends Over Time with Annotations')
plt.xlabel('Date')
plt.ylabel('Exchange Rate')
# Highlight specific events (as example)
special_dates = ['2020-03-01', '2020-09-01']
special_values = exchange_rates.loc[special_dates, 'USD']
for date, value in zip(special_dates, special_values):
plt.annotate(f'{date}: {value:.2f}',
xy=(date, value),
xytext=(date, value+0.05),
arrowprops=dict(facecolor='black', shrink=0.05))
plt.legend(currencies)
plt.show()
This completes the practical implementation for visualizing exchange rate trends. These visualizations will help in better understanding the behavior of foreign exchange rates over time and make informed decisions to manage foreign exchange risk effectively.
Calculating Exchange Rate Volatility
Step 6: Calculating Exchange Rate Volatility
Below is a practical implementation to calculate exchange rate volatility using Python in a Google Colab notebook.
Import Required Libraries
import pandas as pd
import numpy as np
Load Dataset
Assume the dataset has already been loaded and cleaned in previous steps and is stored in a DataFrame named exchange_rates_df.
Volatility is typically measured by the standard deviation of the returns.
# Calculate the annualized volatility
trading_days = 252 # Workdays in a year assuming financial market working days
exchange_rates_df['volatility'] = exchange_rates_df['returns'].rolling(window=trading_days).std() * np.sqrt(trading_days)
Handle Missing Values
Volatility cannot be computed for the first trading_days-1 days as the rolling window is not full. Handle this appropriately.
# Drop rows with NA values in volatility column
exchange_rates_df.dropna(subset=['volatility'], inplace=True)
Visualize Volatility
Visualizing the volatility can help understand trends over time.
import matplotlib.pyplot as plt
# Plotting the exchange rate volatility
plt.figure(figsize=(14, 7))
plt.plot(exchange_rates_df['date'], exchange_rates_df['volatility'], label='Exchange Rate Volatility')
plt.title('Exchange Rate Volatility Over Time')
plt.xlabel('Date')
plt.ylabel('Volatility')
plt.legend()
plt.show()
By following these steps, you'll calculate and visualize the volatility of exchange rates using Python in Google Colab. This functionality assists in understanding and managing foreign exchange risk for a multinational company.
Hedging Strategies and Simulations
Introduction
Hedging is a risk management strategy employed to offset potential losses or gains that may be incurred by a companion investment. Here, we will focus on practical implementation of hedging strategies, modeling them using Python, and running simulations to evaluate their effectiveness.
Key Components:
Importing necessary packages
Define Hedging Strategies
Running Simulations
1. Importing Necessary Packages
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from scipy.stats import norm
2. Define Hedging Strategies
We'll implement two common hedging strategies: Forward Contracts and Options.
Forward Contract Strategy
In this strategy, we lock in the current exchange rate by entering into a forward contract to purchase or sell the foreign currency at a specific future date.
We'll simulate the hedging strategies over a defined period to assess their effectiveness.
Simulation Setup
# Parameters
notional = 1000000 # Amount of currency to hedge
rate_now = 1.1 # Current exchange rate
volatility = 0.1 # Exchange rate volatility
maturity = 1 # Time to maturity in years
n_simulations = 10000 # Number of simulations
# DataFrame to store simulation results
results = pd.DataFrame()
This implementation covers the fundamental aspects of hedging using Forward Contracts and Options. The simulation framework allows for robust analysis and comparison of hedging strategies under different scenarios. You can further enhance this by integrating real exchange rate data and adjusting parameters based on specific business requirements.
Correlation Analysis between Currencies
Here, we'll perform a correlation analysis between multiple currency exchange rates. The correlation matrix will help us understand the relationships and dependencies between different currencies.
Step 1: Load Required Libraries
We'll use the pandas and seaborn libraries for data manipulation and visualization, respectively.
import pandas as pd
import seaborn as sns
import matplotlib.pyplot as plt
Step 2: Load Data
Assume exchange_rates.csv contains the historical exchange rates with columns: Date, Currency1, Currency2, Rate.
# Load the dataset
data = pd.read_csv('exchange_rates.csv', parse_dates=['Date'])
# Pivot the dataframe to have currencies as columns and dates as index
data_pivoted = data.pivot(index='Date', columns=['Currency1', 'Currency2'], values='Rate')
data_pivoted.columns = [f'{col[0]}_{col[1]}' for col in data_pivoted.columns]
Step 3: Handle Missing Values
Ensure the dataset has no missing values.
# Fill missing values (e.g., forward-fill)
data_pivoted.ffill(inplace=True)
data_pivoted.bfill(inplace=True)
Step 4: Calculate Correlation Matrix
Calculate the Pearson correlation of the exchange rates.
# Calculate the correlation matrix
correlation_matrix = data_pivoted.corr()
Step 5: Visualize the Correlation Matrix
Using a heatmap to visualize the correlation matrix.
# Plot the heatmap
plt.figure(figsize=(16, 12))
sns.heatmap(correlation_matrix, annot=True, fmt=".2f", cmap='coolwarm', linewidths=0.5)
plt.title('Correlation Matrix of Currency Exchange Rates')
plt.show()
Practical Explanation
Load the Libraries and Data: Import necessary libraries and load your dataset containing historical exchange rates. The data should include dates and exchange rates between various currencies.
Data Structuring: Pivot the dataset so that each currency pair becomes a column. The dates become the index, and each cell in the column represents the exchange rate for that date.
Missing Data Handling: Ensure there are no missing values by applying forward and backward filling techniques.
Correlation Calculation: Compute the Pearson correlation matrix for all the currency pairs.
Visualization: Use Seaborn’s heatmap function to visualize the correlation matrix. This will help in understanding how the exchange rates move relative to each other.
Real Life Appliation
The output from the correlation matrix will provide insights into which currencies have strong positive or negative correlations, guiding strategies for hedging and risk management in currency trading and financial planning.
By following this practical implementation, you can now incorporate correlation analysis into your comprehensive guide on foreign exchange risk management.
Value at Risk (VaR) Calculation in Python using Google Colab
Introduction
In this section, we will calculate the Value at Risk (VaR) of a foreign exchange portfolio. VaR measures the potential loss in value of a portfolio over a defined period for a given confidence interval.
Implementation Steps
1. Load necessary libraries
We'll assume the necessary packages like pandas, numpy, and scipy are already installed.
import pandas as pd
import numpy as np
from scipy.stats import norm
import matplotlib.pyplot as plt
2. Load the FX data
Assume you have a cleaned dataset in a pandas DataFrame fx_data with columns Date and exchange rate columns for different currencies.
# Example: Load data
fx_data = pd.read_csv('path_to_cleaned_fx_data.csv', parse_dates=['Date'], index_col='Date')
portfolio = fx_data[['Currency1', 'Currency2', 'Currency3']] # Example currencies
3. Calculate daily returns
returns = portfolio.pct_change().dropna()
4. Calculate mean and standard deviation of returns
Here is the complete code for the VaR calculation:
import pandas as pd
import numpy as np
from scipy.stats import norm
import matplotlib.pyplot as plt
# Load data
fx_data = pd.read_csv('path_to_cleaned_fx_data.csv', parse_dates=['Date'], index_col='Date')
portfolio = fx_data[['Currency1', 'Currency2', 'Currency3']] # Replace with actual columns
# Calculate daily returns
returns = portfolio.pct_change().dropna()
# Calculate mean and standard deviation of returns
mean_returns = returns.mean()
std_returns = returns.std()
# Define portfolio weights (equal weight in this example)
weights = np.array([1/len(portfolio.columns)] * len(portfolio.columns))
# Calculate portfolio returns and standard deviation
portfolio_mean_return = np.dot(weights, mean_returns)
portfolio_std = np.sqrt(np.dot(weights.T, np.dot(returns.cov(), weights)))
# Calculate VaR at 95% confidence level
confidence_level = 0.95
z_score = norm.ppf(confidence_level)
VaR = portfolio_mean_return - z_score * portfolio_std
# Annualize the VaR
VaR_annual = VaR * np.sqrt(252)
print(f'Portfolio VaR (95% confidence level): {VaR_annual:.2f}')
Conclusion
You have successfully calculated the VaR for your FX portfolio. This metric will help you understand the risk associated with your foreign exchange exposure. Adjust confidence_level and weights as per your requirements.
Stress Testing for FX Risk
Stress testing is crucial for evaluating how extreme market scenarios would impact foreign exchange (FX) positions. In this section, we'll create and execute stress test scenarios for various FX pairs.
10. Stress Testing FX Risk
Step 1: Load the Necessary Libraries and Dataset
import pandas as pd
import numpy as np
# Assuming the dataset has already been imported and cleaned in previous steps
# For demonstration, let's assume we have a DataFrame `fx_data` with columns ['Date', 'USDEUR', 'USDJPY', ...]
Step 2: Define Stress Test Scenarios
Create various scenarios to simulate extreme market conditions, such as significant currency devaluation or appreciation.
Calculate the new exchange rates and assess the impact on the portfolio or positions.
# Original FX positions: assume a dictionary where keys are currency pairs and values are positions in USD
positions = {
'USDEUR': 1000000,
'USDJPY': 500000,
# Add more positions as required
}
def apply_stress_test(positions, stress_scenario):
stressed_positions = {}
for pair, position in positions.items():
if pair in stress_scenario:
stress_factor = stress_scenario[pair]
stressed_positions[pair] = position * stress_factor
else:
stressed_positions[pair] = position
return stressed_positions
# Stress test results
results = {}
for scenario_name, scenario in stress_scenarios.items():
results[scenario_name] = apply_stress_test(positions, scenario)
# Convert results to DataFrame for better visualization
results_df = pd.DataFrame(results)
print(results_df)
Step 4: Summarize the Impact
Summarize the impact of each stress test scenario on the overall portfolio.
# Summarize the total impact in USD
summary = {}
for scenario, stressed_positions in results.items():
total_impact = sum(stressed_positions.values())
summary[scenario] = total_impact
# Convert summary to DataFrame
summary_df = pd.DataFrame(list(summary.items()), columns=['Scenario', 'Total Impact in USD'])
print(summary_df)
The above code provides a practical implementation of stress testing FX risk in Python.
Conclusion
In this section, we created different stress test scenarios and applied them to assess the impact on FX positions. By simulating extreme market conditions, we can better understand potential risks and prepare accordingly.
Machine Learning for Forecasting Exchange Rates
Overview
In this section, we will use a machine learning model to forecast exchange rates. We'll leverage historical data to predict future values. The Random Forest Regressor will be used for its robustness and ability to handle time series data.
# Importing necessary libraries
import pandas as pd
import numpy as np
from sklearn.model_selection import train_test_split
from sklearn.ensemble import RandomForestRegressor
from sklearn.metrics import mean_squared_error
import matplotlib.pyplot as plt
# Load dataset
# Assuming the dataset is already loaded and cleaned in previous steps
# df should have at least 'Date' and 'Exchange_Rate' columns
df = pd.read_csv('cleaned_exchange_rate.csv')
# Preparing the data for modeling
df['Date'] = pd.to_datetime(df['Date'])
df.set_index('Date', inplace=True)
# Creating lag features
# Shifting values to create features and targets
lags = 5
for lag in range(1, lags + 1):
df[f'lag_{lag}'] = df['Exchange_Rate'].shift(lag)
# Drop rows with NaN values that resulted from shifting
df.dropna(inplace=True)
# Define features (X) and target (y)
X = df.drop('Exchange_Rate', axis=1)
y = df['Exchange_Rate']
# Split data into training and testing sets
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, shuffle=False)
# Initialize and train the Random Forest Regressor
model = RandomForestRegressor(n_estimators=100, random_state=42)
model.fit(X_train, y_train)
# Make predictions
y_pred = model.predict(X_test)
# Evaluate the model
mse = mean_squared_error(y_test, y_pred)
print(f'Mean Squared Error: {mse}')
# Plotting the results
plt.figure(figsize=(14, 7))
plt.plot(y_test.index, y_test, label='Actual Exchange Rate')
plt.plot(y_test.index, y_pred, label='Predicted Exchange Rate', alpha=0.7)
plt.legend()
plt.show()
Explanation
Import Libraries: We import necessary libraries including pandas, numpy, sklearn, and matplotlib.
Data Preparation: Convert Date to datetime, set it as the index, and create lag features.
Feature and Target Definition: Separate features (X) and target (y).
Train-Test Split: Split the data into training and testing sets, ensuring proper time series validation by not shuffling.
Model Training: A Random Forest Regressor is initialized and trained using the training set.
Prediction and Evaluation: Predictions are made on the test set and performance is evaluated using Mean Squared Error.
Visualization: Plot the actual vs predicted values for better understanding.
Reporting and Dashboard Creation
In this section, we'll create an interactive dashboard to effectively report and visualize foreign exchange (FX) risk metrics and analytics. Given that we are using Python in a Google Colab notebook, we can leverage the Dash framework by Plotly to create a web-based interactive dashboard.
Prerequisites
Make sure you have installed dash and plotly packages. You can install these packages using the following commands:
!pip install dash
!pip install plotly
Step-by-Step Implementation
1. Import Necessary Libraries
import dash
import dash_core_components as dcc
import dash_html_components as html
from dash.dependencies import Input, Output
import plotly.graph_objs as go
import pandas as pd
2. Load Your Data
Load the preprocessed FX data that you have from the previous steps. Here, we assume the data is in a DataFrame named fx_data.
# Assuming fx_data is preprocessed and available
# Sample columns: Date, CurrencyPair, ExchangeRate, Volatility, VaR
fx_data = pd.read_csv('processed_fx_data.csv')
3. Initialize the Dash App
app = dash.Dash(__name__)
4. Define Layout
Set up the layout of the dashboard including dropdowns, graphs, and other UI elements.
Finally, run the app. Note that this will not directly run in Google Colab's cell in the traditional sense, but you can use ngrok to create a public URL for local running Dash apps in Google Colab.
if __name__ == '__main__':
app.run_server(debug=True)
Use the following script in Google Colab to start ngrok and obtain the public URL:
!pip install pyngrok
from pyngrok import ngrok
# Run this in a separate cell in your notebook
public_url = ngrok.connect(8050)
public_url
Now, you can navigate to the provided public_url in a web browser to view your interactive dashboard.
You have now implemented a real-time FX risk management dashboard using Python and Dash, viewable directly via a public URL generated by ngrok. This will allow you to interactively explore the FX data and visualize critical risk metrics.