# Bank Interest Calculation System - Development Process Description

## Project Overview

The requirement for this project is to write an interest calculation function based on the cpp library BankAccount.hpp and save it to the InterestCalculator.cpp file

## Interest Calculation Formula

The system uses the simple interest calculation formula:
Interest = Principal × Annual Interest Rate × Days / 365

## File Structure

Project Root/
├── BankAccount.hpp # C++ BankAccount class header file
├── bank_account_module.cpp # Pybind11 binding module
├── BankAccount.py # Translated Python version
├── InterestCalculator.py # Translation method interest calculation
├── InterestCalculator-pybind11.py # Pybind11 method interest calculation
├── InterestCalculator.cpp # Final C++ interest calculation function
├── testcase.json # Test case file
└── README.md # This documentation file

### Pybind11 Installation

- Python 3.12 or higher
- C++ 17
- pip install pybind11

## Technical Approaches Explanation

### Approach 1: Translation Method

#### Process Steps:

1. **Generate Test Case Input**

   - Create `testcase.json` file
   - Contains fields:
     - `account_id`: Account ID, used to create BankAccount objects
     - `current_balance`: Current balance, used to initialize BankAccount objects
     - `annual_rate`: Annual interest rate, used for interest calculation
     - `days`: Number of interest days, used for interest calculation
2. **C++ to Python Translation**

   - Translate `BankAccount.cpp` to `BankAccount.py`
   - Maintain the same class structure and interfaces
3. **Generate Python Interest Calculation Function**

   - Implement interest calculation logic in `InterestCalculator.py`
   - Run test cases to calculate expected outputs:
     - `expected_interest`: Expected interest
     - `expected_total`: Expected total amount
   - Save results back to `testcase.json`
4. **Generate C++ Interest Calculation Function**

   - Generate multiple implementation versions
   - Select the optimal version and output as `InterestCalculator.cpp` based on test cases

### Approach 2: Pybind11 Binding Approach

#### Process Steps:

1. **Generate Test Case Input**

   - Create `testcase.json` file with same fields as Approach 1
2. **Expose C++ Class Using Pybind11**

   - Use Pybind11 to expose C++ class to Python
   - Compilation command:
     ```bash
     c++ -O3 -Wall -shared -std=c++11 -fPIC `python3 -m pybind11 --includes` bank_account_module.cpp -o bank_account`python3-config --extension-suffix`
     ```
3. **Generate Python Interest Calculation Function**

   - Create `InterestCalculator-pybind11.py`
   - Directly call C++ BankAccount class
   - Run test cases, calculate and save expected outputs to `testcase.json`
4. **Generate C++ Interest Calculation Function**

   - Generate multiple implementation versions
   - Select the optimal version and output as `InterestCalculator.cpp` based on test cases
