# Erlang E1 Channel Calculator
This Rust library provides functionality to calculate the number of E1 voice channels required to meet a specific blocking probability using the Erlang B formula. It is commonly used in telecommunications to determine the number of channels needed based on system traffic and user load.
## Features
- **Erlang B Calculation**: Calculate the blocking probability based on traffic (in Erlangs) and the number of available communication channels.
- **E1 Channel Calculation**: Compute the number of E1 voice channels required to meet a desired blocking probability.
- **Helper Functions**: Convert high-level user inputs such as the number of users, average call duration, and concurrent calls into Erlangs and perform the channel calculation.
Then import the library into your project:
```rust
extern crate erlang_e1;
```
Usage
Calculating Blocking Probability
You can calculate the blocking probability for a given traffic load and number of channels using the Erlang B formula:
```rust
use erlang_e1::erlang_b;
fn main() {
let traffic = 15.0; // in Erlangs
let channels = 10;
let blocking_probability = erlang_b(traffic, channels);
println!("Blocking Probability: {:.5}", blocking_probability);
}
```
Calculating Required E1 Channels
If you already have the traffic (in Erlangs), you can calculate the number of E1 channels needed for a desired blocking probability:
```rust
use erlang_e1::calculate_e1_channels;
fn main() {
let traffic = 20.0; // in Erlangs
let blocking_probability = 0.05; // 5% blocking probability
let max_channels = 10000; // optional upper limit for search
match calculate_e1_channels(traffic, blocking_probability, max_channels) {
Some(channels) => println!("Required channels: {}", channels),
None => println!("No suitable number of channels found within the limit."),
}
}
```
High-Level Calculation with User Inputs
If you have high-level inputs like the number of users and average call duration, you can use the required_e1_channels
function to calculate the number of channels:
```rust
use erlang_e1::required_e1_channels;
fn main() {
let users = 100;
let average_call_duration = 3.0; // in minutes
let concurrent_calls = 10;
let blocking_probability = 0.05;
match required_e1_channels(users, average_call_duration, concurrent_calls, blocking_probability) {
Some(channels) => println!("Required channels: {}", channels),
None => println!("No suitable number of channels found within the limit."),
}
}
```
Explanation
Erlang B Formula: This formula is used to calculate the probability of all channels being occupied (blocking probability) in a system with N channels and a given traffic load in Erlangs.
E1 Channels: In telecommunications, an E1 line consists of 30 voice channels. This library helps calculate the number of E1 lines required to satisfy the traffic and blocking probability requirements.