aws-samples / amazon-transcribe-live-call-analytics
Conditional Complexity

The distribution of complexity of units (measured with McCabe index).

Intro
  • Conditional complexity (also called cyclomatic complexity) is a term used to measure the complexity of software. The term refers to the number of possible paths through a program function. A higher value ofter means higher maintenance and testing costs (infosecinstitute.com).
  • Conditional complexity is calculated by counting all conditions in the program that can affect the execution path (e.g. if statement, loops, switches, and/or operators, try and catch blocks...).
  • Conditional complexity is measured at the unit level (methods, functions...).
  • Units are classified in four categories based on the measured McCabe index: 1-5 (simple units), 6-10 (medium complex units), 11-25 (complex units), 26+ (very complex units).
Learn more...
Conditional Complexity Overall
  • There are 195 units with 1,677 lines of code in units (18.3% of code).
    • 0 very complex units (0 lines of code)
    • 0 complex units (0 lines of code)
    • 2 medium complex units (106 lines of code)
    • 11 simple units (288 lines of code)
    • 182 very simple units (1,283 lines of code)
0% | 0% | 6% | 17% | 76%
Legend:
51+
26-50
11-25
6-10
1-5
Alternative Visuals
Conditional Complexity per Extension
51+
26-50
11-25
6-10
1-5
py0% | 0% | 18% | 31% | 50%
java0% | 0% | 0% | 11% | 88%
js0% | 0% | 0% | 0% | 100%
Conditional Complexity per Logical Component
primary logical decomposition
51+
26-50
11-25
6-10
1-5
lca-ai-stack/source/lambda_functions0% | 0% | 18% | 31% | 50%
lca-ai-stack/source/kvs_transcribe_streaming0% | 0% | 0% | 11% | 88%
lca-ai-stack/source/ui0% | 0% | 0% | 0% | 100%
lca-ai-stack/deployment/manifest-generator0% | 0% | 0% | 0% | 100%
Most Complex Units
Top 20 most complex units
Unit# linesMcCabe index# params
def lambda_handler()
in lca-ai-stack/source/lambda_functions/merge_recording_audio/merge_recording_audio.py
82 12 2
def _prune_state()
in lca-ai-stack/source/lambda_functions/call_event_stream_processor/tumbling_window_state/call_state_manager.py
24 11 1
private boolean startStreaming()
in lca-ai-stack/source/kvs_transcribe_streaming/src/main/java/com/amazonaws/kvstranscribestreaming/KVSRecordingTask.java
41 10 7
def _get_persisted_state_items_generator()
in lca-ai-stack/source/lambda_functions/call_event_stream_processor/tumbling_window_state/state_manager.py
31 10 1
public void validate()
in lca-ai-stack/source/kvs_transcribe_streaming/src/main/java/com/amazonaws/kvstranscribestreaming/RecordingRequest.java
11 7 0
public void validate()
in lca-ai-stack/source/kvs_transcribe_streaming/src/main/java/com/amazonaws/kvstranscribestreaming/TranscriptionRequest.java
11 7 0
def _should_ignore_gql_exception()
in lca-ai-stack/source/lambda_functions/call_event_stream_processor/call_event_handler.py
10 7 1
public void writeToDynamoDB()
in lca-ai-stack/source/kvs_transcribe_streaming/src/main/java/com/amazonaws/kvstranscribestreaming/TranscribedSegmentWriter.java
18 6 3
public static ByteBuffer getByteBufferFromStream()
in lca-ai-stack/source/kvs_transcribe_streaming/src/main/java/com/amazonaws/kvstranscribestreaming/KVSUtils.java
29 6 6
def poll_create_or_update()
in lca-ai-stack/source/lambda_functions/start_codebuild/lambda_start_codebuild.py
25 6 2
def _update_state_aggregations()
in lca-ai-stack/source/lambda_functions/call_event_stream_processor/tumbling_window_state/call_state_manager.py
29 6 1
def _update_call_state()
in lca-ai-stack/source/lambda_functions/call_event_stream_processor/tumbling_window_state/call_state_manager.py
32 6 3
def lambda_handler()
in lca-ai-stack/source/lambda_functions/transcribing_fargate_trigger/lambda_transcribing_fargate_trigger.py
51 6 2
public static void uploadRawAudio()
in lca-ai-stack/source/kvs_transcribe_streaming/src/main/java/com/amazonaws/kvstranscribestreaming/AudioUtils.java
33 5 8
public void process()
in lca-ai-stack/source/kvs_transcribe_streaming/src/main/java/com/amazonaws/kvstranscribestreaming/KVSContactTagProcessor.java
19 5 2
public static ByteBuffer getByteBufferFromStream()
in lca-ai-stack/source/kvs_transcribe_streaming/src/main/java/com/amazonaws/kvstranscribestreaming/KVSUtils.java
20 5 3
private void recursiveStartStream()
in lca-ai-stack/source/kvs_transcribe_streaming/src/main/java/com/amazonaws/transcribestreaming/TranscribeStreamingRetryClient.java
33 5 6
public void request()
in lca-ai-stack/source/kvs_transcribe_streaming/src/main/java/com/amazonaws/transcribestreaming/FileByteToAudioEventSubscription.java
23 5 1
public void request()
in lca-ai-stack/source/kvs_transcribe_streaming/src/main/java/com/amazonaws/transcribestreaming/KVSByteToAudioEventSubscription.java
26 5 1
next: async()
in lca-ai-stack/source/ui/src/hooks/use-calls-graphql-api.js
15 5 2