Graphs and Neo4j - from Hydropower Plants to PCBs
data:image/s3,"s3://crabby-images/6ac08/6ac08c2f3d0af0395e06debd0034fd61560f79be" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Hi!
- Computer Engineering
- Programming
- Electronics
- Mathematics
- Physics
- Lego
- Meetups
- Coffee
- GIFs
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Disclaimer
This content represents the speaker's personal overview.
Feedback (positive or not) accepted here: hannelita@gmail.com
Not all numeric data or names are true, aiming not to harm company secrets.
Modelling cases are real; apologises for technical terms flood.
Structure - Cases
- Use case context
- Modelling with relational databases (and fails)
- Graph modelling
- Evolving the model
- Epic fails
Final Considerations
- Main benefits
- Support tools
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Title Text
Have you ever been into the darkness?
Running out of electrical energy
Candle lights <3
data:image/s3,"s3://crabby-images/913e5/913e50bb6fdcd6cf48f85f8e39cc743f176722b1" alt=""
Brazil is a huge producer of electrical energy.
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Specially from hydropower plants
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Case 1 - Context
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
data:image/s3,"s3://crabby-images/85b81/85b815ce171025718d046413bf32c90790306b1a" alt=""
How do we distribute electrical energy? How are the power plants distributed?
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
http://sigel.aneel.gov.br/sigel.html
data:image/s3,"s3://crabby-images/6f8a4/6f8a43a4550ede02328e0ce0e12f83b1efba6dd4" alt=""
Accessed in 28/3/2016
http://sigel.aneel.gov.br/sigel.html
Access in 28/3/2016
data:image/s3,"s3://crabby-images/901f3/901f3a0b9ffa345e21b8fbe450994ea6908436a9" alt=""
Map information
- Power plant location
- Transmission lines
- Supply capacity
- Total capacity
- Nearby cities
- Distribution
- Boundaries / States
- Hydrographic basin
- Dealers
Electrical
Political
Environmental
Economy
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Challenge
Build a sytem that stores all these information and how the data is related.
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Case 1 - Modelling with relational databases
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Electrical
Political
Environmental
Economy
CREATE TABLE power_plant;
CREATE TABLE city;
CREATE TABLE hydrographic_basin;
CREATE TABLE dealer;
Question 1:
How do you represent a power plant neighbourhood?
data:image/s3,"s3://crabby-images/dc278/dc278b0c90949d6100d840b56f0b5a5ec5fe94a6" alt=""
- Self-relationship;
- Denormalisation (neighbours_ids)
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Question 2:
Which is the best power plant to provide energy for a group of cities?
id | usage (month, in Mwh) | population (milion) | coordinate |
---|---|---|---|
1 | 40 | 13 | |
2 | 11 | 2 |
city
id | capacity ( Mwh) | transmission_line (PK) | coordinate |
---|---|---|---|
1 | 95 | 22 | |
2 | 11 | 1 |
powe_plant
- Given a coordinate data set, sum the population inside the resultant polygon.
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Question 2:
Which is the best power plant to provide energy for a group of cities?
id | usage (month, in Mwh) | population (milion) | coordinate |
---|---|---|---|
1 | 40 | 13 | |
2 | 11 | 2 |
city
id | capacity ( Mwh) | transmission_line (PK) | coordinate |
---|---|---|---|
1 | 95 | 22 | |
2 | 11 | 1 |
powe_plant
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
2. Match power plants coordinates based on supply capacity
Question 2:
Which is the best power plant to provide energy for a group of cities?
id | usage (month, in Mwh) | population (milion) | coordinate |
---|---|---|---|
1 | 40 | 13 | |
2 | 11 | 2 |
city
id | capacity ( Mwh) | transmission_line (PK) | coordinate |
---|---|---|---|
1 | 95 | 22 | |
2 | 11 | 1 |
powe_plant
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
3. Verify properties into transmission_lines table
It is not that difficult
data:image/s3,"s3://crabby-images/23c42/23c42f307a662435286107e9a0825a32336e6ee6" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
It is not over!
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Question 2:
Which is the best power plant to provide energy for a group of cities?
id | usage (month, in Mwh) | population (milion) | coordinate |
---|---|---|---|
1 | 40 | 13 | |
2 | 11 | 2 |
city
id | capacity ( Mwh) | transmission_line (PK) | coordinate |
---|---|---|---|
1 | 95 | 22 | |
2 | 11 | 1 |
powe_plant
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
4. Verify if there are industries nearby
Question 2:
Which is the best power plant to provide energy for a group of cities?
id | usage (month, in Mwh) | population (milion) | coordinate |
---|---|---|---|
1 | 40 | 13 | |
2 | 11 | 2 |
city
id | capacity ( Mwh) | transmission_line (PK) | coordinate |
---|---|---|---|
1 | 95 | 22 | |
2 | 11 | 1 |
powe_plant
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
5. Verify HDI
Question 2:
Which is the best power plant to provide energy for a group of cities?
id | usage (month, in Mwh) | population (milion) | coordinate |
---|---|---|---|
1 | 40 | 13 | |
2 | 11 | 2 |
city
id | capacity ( Mwh) | transmission_line (PK) | coordinate |
---|---|---|---|
1 | 95 | 22 | |
2 | 11 | 1 |
powe_plant
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
6. Verify dealers interest.
Question 2:
Which is the best power plant to provide energy for a group of cities?
id | usage (month, in Mwh) | population (milion) | coordinate |
---|---|---|---|
1 | 40 | 13 | |
2 | 11 | 2 |
city
id | capacity ( Mwh) | transmission_line (PK) | coordinate |
---|---|---|---|
1 | 95 | 22 | |
2 | 11 | 1 |
powe_plant
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
7. Verify if the region has alternative energy sources
data:image/s3,"s3://crabby-images/452c6/452c63dbcb08ce9eb4e0717326665476d61f3a0d" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Question 3:
Assuming that hydropower plants work as tug-of-war with multiple endpoints, how do you redistribute the electrical charges if one plant shuts down?
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Question 3:
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Assuming that hydropower plants work as tug-of-war with multiple endpoints, how do you redistribute the electrical charges if one plant shuts down?
data:image/s3,"s3://crabby-images/901f3/901f3a0b9ffa345e21b8fbe450994ea6908436a9" alt=""
Maybe tables are not the best structures to represent information about energy distribution.
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Neo4j comes to rescue!
data:image/s3,"s3://crabby-images/3b29e/3b29efe0df5b4aa76a3a5cd84d7e34641fbd8ae8" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Quick intro - Neo4j
- Graph oriented database
- ACID
- Structures: Node, Relationship, Index and Label
- Maintained by Neotechnology
- Open Source
- Active community
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Case 1 - Graph Modelling
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Step 1 - Power plants become nodes
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
data:image/s3,"s3://crabby-images/a7aeb/a7aeb38238cd4ee5f3831baca0434ee1fa95ecb2" alt=""
Powered by Arrows - http://www.apcjones.com/arrows/#
CREATE (n:PowerPlant:HydropowerPlant { name : 'Itaipu', capacity : '14000' })
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Usina => Power Plant
Hidreletrica => Hydropower
capacidade => capacity
Step 2 - Cities become nodes
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Step 3 - Transmission lines become relationships!
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Itaipu - Ivaiporã
data:image/s3,"s3://crabby-images/1a69b/1a69b4798b9027b2937ae1c4568b01f0f6dad98e" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
data:image/s3,"s3://crabby-images/29d7b/29d7bc1b5571fae6b419eb0c65fe71be2ba88671" alt=""
MATCH (a:HidropowerPlant),(b:City)
WHERE a.name = 'Itaipu' AND b.name = 'Ivaipora'
CREATE (a)-[r:PROVIDES { cable_capacity : 765, rl : 330 }]->(b)
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Multiple relationships for several lines
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
data:image/s3,"s3://crabby-images/29e32/29e32ce7fbccb1029fa962b9e2b2516a98af9ec3" alt=""
MATCH (a:HidrepowerPlant),(b:City)
WHERE a.name = 'Itaipu' AND b.name = 'Cascavel Oeste'
CREATE (a)-[r:PROVIDES { cable_capacity : 500 }]->(b)
MATCH (a:City),(b:City)
WHERE a.name = 'Ivaipora' AND b.name = 'Cascavel Oeste'
CREATE (a)-[r:MESH { capacidade_cabo : 500 }]->(b)
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Step 4 - Dealers become nodes
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
data:image/s3,"s3://crabby-images/327ae/327aeac5392d2fb1a74c959c7bc520d010397675" alt=""
CREATE (n:Dealer { name : 'Fake',
percentage : 85, margin : 72 })
MATCH (a:Dealer),(b:City)
WHERE a.name = 'Ficticio' AND b.name = 'Cascavel Oeste'
CREATE (a)-[r:ATTENDS]->(b)
MATCH (a:Dealer),(b:PowerPlant)
WHERE a.name = 'Ficticio' AND b.name = 'Ita'
CREATE (a)-[r:OWNS]->(b)
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Step 5 - Queries poderosas
MATCH (n:PowerPlant {capacity : 14000}),
(c:City {name : 'Sao Paulo'})
p = shortestPath((n)-[]-(c)) RETURN p
Queries determine optinal paths for energy supply
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Case 1 - Evolving the model
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Important: add Indexes for the most frequently used properties
Capacity, population, coordinates
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Important[2]: Labels
:City, :PowerPlant, :Region
Usually, elements can be grouped deserve a label.
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
More evolving - turn other electrical elements into nodes
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
data:image/s3,"s3://crabby-images/35182/35182305aa620db13f0a61e96f8dd93fedeeb6f1" alt=""
CREATE (n:Component:Transformer
{ tag : 'F. Iguacu', type : 'Terciario', mva : 1650, total : 4 })
MATCH (a:Transformer),(b:PowerPlant)
WHERE a.tag = 'F. Iguacu' AND b.name = 'Itaipu'
CREATE (a)-[r:INSTALLED]->(b)
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Neo4j is flexible for modelling.
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Case 1 - Epic Fails
data:image/s3,"s3://crabby-images/6f556/6f5568bd9db22c7751542c2c0ad72d7f3b3746c6" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Too many nodes for cities! (There are too many cities)
Problem
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Too much information being loaded on MATCH; performance problems
Impact
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Remove some :Cities and add :Region label, grouping cities
Solution
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Do not save all the CREATE operations into a file
Problem
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Problems with backup / replication.
Impact
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Do not perform CREATE operations into Web interface!
Add queries into a Git repository - https://github.com/hannelita/qconsp
Solution
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Case 1 - Extra - Insights
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Find hidden information
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Example: mapping the components made a big difference for a deeper model evaluation.
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Mapping components...
data:image/s3,"s3://crabby-images/9682a/9682aedfac5b5a9a68006ee8bbcf900546561e0e" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Case 2 - Context
data:image/s3,"s3://crabby-images/d1e16/d1e16cf531412fb1f02c597d44765c5f79ae8c0d" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
A-HA! We could use graphs for (...) [complete]
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
PCB Routing / Trail design
data:image/s3,"s3://crabby-images/e67b6/e67b668402d8b015c61f361a260969b554f20f16" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Yes! But we can go further.
Let's analyse the board layout and components display.
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Case 2 - Modelling with relational databases
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Component
Trail
Sensor
Layer
CREATE TABLE component;
CREATE TABLE trail;
CREATE TABLE sensor;
CREATE TABLE layer;
Question 1:
A sensor detects temperature raise. How would you infer if it is a problem from a component or from the trail?
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Question 1
Usually you need extra information from the neighbours sensor. How do you model that?
data:image/s3,"s3://crabby-images/dc278/dc278b0c90949d6100d840b56f0b5a5ec5fe94a6" alt=""
- Self-relationship;
- Denormalise (sensors_ids)
Déjà vu!
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Question 2:
Which trails does affect more components at the same time? (ex: If Trail A breaks, the entire system stops working)
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Question 3:
Is it possible to extract some hidden or unseen information from the circuit by modelling it within a graph?
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Case 2 - Graph modelling
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Step 1: Components become nodes
CREATE (n:Component:Primary { name : 'R1',
type : 'resistor', value : '10K' })
CREATE (n:Component:Primary { name : 'C1',
type : 'capacitor', group : 'polyester',
value : '100p' })
CREATE (n:Component:CI { name : 'CI1',
type : 'LM741', seller : 'Texas' })
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Step 2: Map trails into relationships
MATCH (a:Primary),(c:CI)
WHERE a.name = 'R1' AND c.name = 'CI1'
CREATE (a)-[r:TRAILS { thickness : 2, dilation : 0.5 }]->(c)
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Step 3: Map Layers into Labels
CREATE (n:Component:Primary:LAYER1
{ name : 'R1', type : 'resistor', value : '10K' })
CREATE (n:Component:Primary:LAYER2
{ name : 'C1', type : 'capacitor',
group : 'polyester', value : '100p' })
CREATE (n:Component:CI:LAYER1 { name : 'CI1',
type : 'LM741', seller : 'Texas' })
Easy to fetch all the components from a specific Layer
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Case 2 - Evolving the model
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Step 4: Map sensors into nodes
CREATE (n:Sensor:LAYER1
{ name : 'SS1', type : 'light'})
CREATE (n:Sensor:LAYER2
{ name : 'SS2', type : 'temperature' })
MATCH (aPrimary),(s:Sensor)
WHERE a.name = 'R1' AND c.name = 'SS1'
CREATE (s)-[MONITORS { light : 2 }]->(a)
MATCH (a:Primary),(s:Sensor)
WHERE a.name = 'R1' AND c.name = 'SS2'
CREATE (s)-[r:MONITORS { temperature : 37 }]->(a)
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
MATCH (n:Sensor)-[MONITORS]-(c:Component)
WHERE n.temperature > 60
RETURN c.name, r.dilation
Decide if it is the component of if it is the trail that is damaged.
Step 5: Run the following periodic query:
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Case 2 - Epic Fails
data:image/s3,"s3://crabby-images/36d73/36d733928da02c521f6fde59c46fac6e1620686b" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Too many updates for the sensors; Neo4j has some writing restrictions
Problem
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Bad performance and high RAM consumption
Impact
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Remove some sensors node or jump to Enterprise version.
Solution
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Final considerations
- Flexible models
- Find hidden relations
- Easy to get started
- Active tool and active community
- It can be useful in several scenarios, beyond social networks and recommendation systems.
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Tools
- Data Import (Relational Databases, MongoDB, Cassandra, JSON, CSV)
- Visualization tools
- REST API
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
References
- Neo4j Meetup in São Paulo
- Neo4j Slack Users
- Neo4j Training (Free)
- Arrows (Sketching tool)
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Special thanks
- Neo Technology, @lyonwj, @ryguyrg e @mesirii
- B.C., for the excellent feedback and review
- @Codeminer42
data:image/s3,"s3://crabby-images/7ace6/7ace6af1396303cbb09c99acf06cfb29fb3f1bec" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
- Prof. Maurílio and Prof. Justino.
Thank you :)
Questions?
hannelita@gmail.com
@hannelita
data:image/s3,"s3://crabby-images/fcaf9/fcaf9682acaa1a883760a17a5af5bebf293b2e03" alt=""
#qconsp @hannelita
data:image/s3,"s3://crabby-images/63e1b/63e1b7f76e6b46622b848fe416aa799faf03fff5" alt=""
Graphs and Neo4j - From Hydropower plants to PCBs
By Hanneli Tavante (hannelita)
Graphs and Neo4j - From Hydropower plants to PCBs
Graphs and Neo4j - From Hydropower plants to PCBs - English version - QCON 2016
- 6,117