Read this in other languages: 中文.
In today’s dynamic market environment, a 360-degree view of a client is a key factor for risk mitigation for investment prepositions. Knowing your client is an essential best practice because it acts as a basis to decide whether or not to invest in a particular client. For a customer relationship manager to be successful in taking the right decision, they must operate on pertinent, accurate, and timely information.
What if we can build a tool that can help you gather all the required information about your clients. To help you make an informed decision on whether or not to invest in a client?
This code pattern is a data science driven solution that uses machine learning to build a knowledge graph of the client associations network and related events from data available as open source and performs multidimensional correlation on these to gain insights.
Suppose, there is an investor who wants advice on which customer to invest in or even to understand an existing client’s situation. This application provides real-time trending information pertaining to an organization, from popular news sites, extracts the clients affected by it with the help of Watson Natural Language Understanding. It is achieved with the help of the following code pattern:
The information extracted is in compliance with the most important events impacting any organization. The events demonstrated are-
- Management Change
- Management Default
- Credit Rating
- Strike
- Share Price Deviation
Finally, a flask application connects the algorithm to a UI and enables all such information to be collated in a single place. Thus, helping a relationship manager to understand the current client-network and provide the right advice to the investor.
- The user interacts with the app UI to request relevant information corresponding to an event or a client.
- The web app UI interacts with the Python-Flask server to receive the required information from the appropriate API.
- The flask APIs scrape real-time news from popular online news portals.
- The scraped data is sent to Watson Natural Language Understanding to extract important entities.
- A configuration JSON file is sent into the flask app, to further prune on the results obtained on Watson Natural Language Understanding.
- Finally, all the collected information is pushed back into the interactive UI.
- Watson Natural Language Understanding: An IBM Cloud service that can analyze text to extract meta-data from content such as concepts, entities, keywords, categories, sentiment, emotion, relations, semantic roles, using natural language understanding.
- Python Runtime: IBM Cloud powers a python runtime by the
python_buildpack
. Thepython_buildpack
provides a complete runtime environment for both Python 2 and Python 3 apps.
- Natural Language Processing: Natural Language Processing is a field that covers computer understanding and manipulation of human language, and it’s ripe with possibilities for news gathering.
- Cloud: Accessing computer and information technology resources through the Internet.
- Python: Python is a programming language that lets you work more quickly and integrate your systems more effectively.
- Artificial Intelligence: Artificial intelligence is intelligence demonstrated by machines, in contrast to the natural intelligence displayed by humans and other animals.
If the below are not already installed on your system, please follow the links and install according to your system specifications-
- Python: The application is built on Python 3.6, to run the application python 3.x version is preferred.
- Git: To clone the repo, alternatively you could use the
Clone or Download
button. - IBM Cloud account: To access IBM Cloud and Watson Services.
- IBM Cloud CLI: To push the python application on your IBM Cloud Organization.
There are two ways to run this application, depending on your requirement, you may choose to run in any one of the following ways:
- Run Application on IBM Cloud: This will let you make the desired changes in the code and then push the application onto your IBM Cloud Foundry Organisation.
- Run Application locally: This will show you how to run the application locally, on your laptop/desktop, using the provided Flask Server.
- Clone the repo
- Create IBM Cloud service
- Setup the Application on IBM Cloud
- Setup the Application on your Localhost
- Running the Python Application
Now you're ready to start working with the app. Clone the repo and change to the directory where the sample app is located.
git clone [email protected]:IBM/banking-risk-mitigation-nlu-studio.git
cd banking-risk-mitigation-nlu-studio
-
Create the following IBM Cloud service. Select your desired region, organization and space:
Note: Keep Note of the NLU Service Instance- region, organization and space.
-
Click on the
Manage
tab and click onDownload
to get theibm-credentials.env
file. Save this file in the same folder as your cloned repo.
You can push the app to IBM Cloud using IBM Cloud CLI. This will use the services and application name in the manifest.yml
file. From the root directory of the cloned git repository, login into IBM Cloud using CLI:
ibmcloud login
NOTE: Ensure you are in the same Region, Organization and Space as the Watson Natural Language Understanding service created above.
To target Cloud Foundry org/space interactively.
ibmcloud target --cf
Finally, push the app to IBM Cloud:
ibmcloud cf push Client_Network_Banking_V1
NOTE: If you wish to change the name of this application- Navigate to the 'manifest.yml' file and update the 'name' field.
This step may take a few minutes to complete.
Once it is completed, go to your IBM Cloud Dashboard
Click on your application, this will take you to a page as shown below:
Click on Visit app URL
, to view the application.
To understand how to use the application, directly navigate to Step 5
Ensure Step 1 and Step 2 are completed first.
Open the Watson Natural Language Understanding service in your IBM Cloud Dashboard and click on your Natural Language Understanding service.
Once it opens up in the UI, view the credentials
menu. Copy apikey
and url
key values that appear on the UI.
- Navigate to the cloned repo and open the file
app.py
. - Update the
apikey
andurl
key values in the code line 30.
natural_language_understanding = NaturalLanguageUnderstandingV1(
version='2018-08-14',
iam_apikey='',
url=''
)
Install the dependencies listed in the requirements.txt file to be able to run the app locally.
pip install -r requirements.txt
You can optionally use a virtual environment and then run the above command, to avoid having these dependencies clash with those of other Python projects or your operating system.
Install the nltk
package dependencies by running the command.
python nltk_download.py
Start the app.
python app.py
View your app at http://localhost:8000
To understand how to use the application, check the next Step
This application provides two methods to gather information:
- Event Options
- Client Options
A user can click on any of the event triggers, upon clicking one, it provides a list of news items and the clients involved in the same. Suppose, we click on Share Price Deviation
, a table with the all the information is given, as shown in the below figure:
If we click on the Clients, now it will be filtered as only those who have a Share Price Deviation:
As shown in the above image, if we click on any one client. We will get a news item, filtered on both the levels, in this case-
- Share Price Deviation
- Bharath Electronics
Thus, the built application enables a banking relationship manager to get relevant client ecosystem news in a faster, convenient and a consolidated manner.
- An explanation of Risk Mitigation can be found in the RISK MITIGATION IN THE BANKING SYSTEM
See Troubleshooting.md.
This code pattern is licensed under the Apache Software License, Version 2. Separate third party code objects invoked within this code pattern are licensed by their respective providers pursuant to their own separate licenses. Contributions are subject to the Developer Certificate of Origin, Version 1.1 (DCO) and the Apache Software License, Version 2.