Skip to content

Commit

Permalink
minor update of web front-end
Browse files Browse the repository at this point in the history
  • Loading branch information
lejafar committed Dec 29, 2017
1 parent baa1e5c commit 757eb76
Show file tree
Hide file tree
Showing 11 changed files with 80 additions and 64 deletions.
1 change: 0 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1,2 +1 @@
__pycache__/
demo/dist
1 change: 1 addition & 0 deletions demo/.gitignore
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
.DS_Store
node_modules/
dist/
npm-debug.log*
yarn-debug.log*
yarn-error.log*
Expand Down
19 changes: 0 additions & 19 deletions demo/README.md

This file was deleted.

5 changes: 5 additions & 0 deletions demo/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion demo/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,8 @@
"vue-awesome": "^2.3.4",
"vue-markdown": "^2.2.4",
"vue-octicon": "^2.1.1",
"vue-router": "^2.7.0"
"vue-router": "^2.7.0",
"vue-spinner": "^1.0.3"
},
"devDependencies": {
"autoprefixer": "^7.1.2",
Expand Down
65 changes: 40 additions & 25 deletions demo/src/components/About.vue
Original file line number Diff line number Diff line change
@@ -1,35 +1,45 @@
<template>
<main>
<pre>

├── demo
| └─ Vue.js front-end to provide insight in prediction process
|
├── helper.py
| └─ Custom feature transformer classes allowing for easy predictions
├── extractor.py
| └─ Exctractor class enables retrieving all nlp features from `sentence`
|
├── learner.py
| └─ Preprocess data, construct pipeline, train SVM and export model.
└── parser.py
| └─ Parse latest transcript of plenary meeting, detect Check-Worthy statements
| and save predictions together with feedback to be served on demo page.
|
└── endpoint.py
└─ Load pre-trained model and provide endpoint for predictions.
</pre>
<vue-markdown>
**Fake news and the spread of misinformation** is nothing new. But, due to recent events, big players like Google and Facebook are now trying to clamp down on the problem. Automated end-to-end fact-checking can play a crucial role in this fight and recent success of [the Claimbuster-project](http://idir-server2.uta.edu/claimbuster/) has paved the way for developing such a system.

The starting point for any fact-checking process is the **identification of** interesting claims or statements that present facts. These kinds of sentences are defined as **Check-worthy Factual Statement**. Only when such sentences can be reliably identified, can they be sent to the next step in the pipeline that actually tries to falsify the interesting claims.

The goal of this project to take the first step towards developing such a fact-checking system for the **Dutch** language, with a focus on identifying Check-worthy Factual Statements. A classifier was trained using a linear classifier on **800** hand-classified **statements** and later calibrated in order to predict the probability of check-worthiness when provided with a statement. A demonstration of its current ability can be found on the [front page](/#/) in the from of a rank of Dutch statements made during the last Plenary Meeting of the Belgian parliament based on their check-worthiness. To provide you with the ability to play around with input of your own and see how this is interpreted by FactRank, we made a little [demo](/#/demo).

### Classifier

![confusion matrix](cnf_matrix.svg)

### Project Structure

```
├── demo
| └─ Vue.js front-end to provide insight in prediction process
|
├── helper.py
| └─ Custom feature transformer classes allowing for easy predictions
├── extractor.py
| └─ Exctractor class enables retrieving all nlp features from `sentence`
|
├── learner.py
| └─ Preprocess data, construct pipeline, train SVM and export model.
└── parser.py
| └─ Parse latest transcript of plenary meeting, detect Check-Worthy statements
| and save predictions together with feedback to be served on demo page.
|
└── endpoint.py
└─ Load pre-trained model and provide endpoint for predictions.
```

</vue-markdown>

</main>
</template>

<script>
import VueMarkdown from 'vue-markdown'
export default {
name: 'About',
components: {
'vue-markdown': VueMarkdown
},
data () {
return {
}
Expand All @@ -38,8 +48,13 @@ export default {
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
<style>
pre{
background-color: #f6f8fa;
padding: 20px;
border-radius: 5px;
}
h3 {
margin-bottom: 2rem;
}
</style>
20 changes: 8 additions & 12 deletions demo/src/components/Contact.vue
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
<div class="hello">
<vue-markdown>

FactRank is written and maintained by:
FactRank was created as a project for the course *Knowledge and the Web* by prof. Bettina Berendt at KU Leuven and is written and maintained by:

- Brecht Laperre (brecht.laperre@student.kuleuven.be)
- Ivo merchiers (ivo.merchiers@student.kuleuven.be)
Expand All @@ -11,10 +11,9 @@
You can always contact us for questions or suggestions.
If you find any bugs, please file a bug report on [github](https://github.com/lejafar/KaW-project/issues).

We have an open api at https://api.factrank.org/sentence
</vue-markdown>
<pre>
Our API is openly available on https://api.factrank.org/, a minimal example:

```javascript
makePrediction (input) {
fetch("https://api.factrank.org/sentence", {
body: JSON.stringify(input),
Expand All @@ -28,19 +27,14 @@
console.log(data.predictions);
})
}

</pre>
```
</vue-markdown>
</div>
</template>

<script>
import VueMarkdown from 'vue-markdown'
export default {
name: 'Contact',
components: {
'vue-markdown': VueMarkdown
},
props: [
'name'
],
Expand All @@ -52,8 +46,10 @@ export default {
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
<style>
pre{
background-color: #f6f8fa;
padding: 20px;
border-radius: 5px;
}
</style>
7 changes: 5 additions & 2 deletions demo/src/components/Demo.vue
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
<b-btn variant="outline-primary" class="submit_button" v-on:click="makePrediction(sentence_input)">submit</b-btn>
</b-col>
</b-row>
<results-table v-bind:result="sentence_result"/>
<results-table v-if="show_result" v-bind:result="sentence_result"/>
</div>
</template>

Expand All @@ -34,7 +34,8 @@ export default {
data () {
return {
sentence_input: '',
sentence_result: {}
sentence_result: {},
show_result: false
}
},
components: {
Expand All @@ -59,6 +60,8 @@ export default {
},
methods: {
makePrediction (sentences) {
this.sentence_result= {}
this.show_result = true
fetch("https://api.factrank.org/sentence", {
body: JSON.stringify(sentences),
method: "POST",
Expand Down
3 changes: 2 additions & 1 deletion demo/src/components/FactRanker.vue
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
<template>
<main v-if="result">
<main>
<results-table v-bind:result="result"/>
</main>
</template>

<script>
import ResultsTable from '@/components/ResultsTable'
import VueMarkdown from 'vue-markdown'
export default {
name: 'FactRanker',
Expand Down
17 changes: 14 additions & 3 deletions demo/src/components/ResultsTable.vue
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
<template>
<b-table show-empty
<b-table v-if="result.predictions"
:fields="fields"
:items="result.predictions"
:sort-compare="customSortCompare"
Expand All @@ -8,7 +8,7 @@
<!-- Information about Source of Statements IF meta is set -->
<template v-if="result.meta" slot="table-caption">
<p v-if="result.meta.date" >
Top Check-Whorty Factual statements from
Top 50 Check-Whorty Factual statements from
<span v-if="this.last"> last Plenary Meeting ({{result.meta.date}}, <strong>{{result.meta.amount}}</strong> statements)</span>
<span v-else> Plenary Meeting on {{result.meta.date}} ({{result.meta.amount}} statements)</span></p>
<a v-if="result.meta.url.length" :href="result.meta.url"><icon name="link" /> {{result.meta.url}} </a>
Expand All @@ -26,16 +26,21 @@
</b-card>
</template>
</b-table>
<div v-else class="loader-container">
<rotate-loader :color="'#ffc107'"></rotate-loader>
</div>
</template>

<script>
import SentenceExtended from '@/components/SentenceExtended'
import RotateLoader from 'vue-spinner/src/RotateLoader'
export default {
name: 'ResultsTable',
props: ['result'],
components: {
'sentence-extended': SentenceExtended
'sentence-extended': SentenceExtended,
'rotate-loader': RotateLoader
},
data () {
return {
Expand Down Expand Up @@ -85,4 +90,10 @@ blockquote{
abbr{
margin-right: 35px;
}

.loader-container{
text-align: center;
vertical-align: middle;
line-height: 300px;
}
</style>
3 changes: 3 additions & 0 deletions demo/src/main.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,9 @@ Vue.component('icon', Icon)

Vue.config.productionTip = false

import VueMarkdown from 'vue-markdown'
Vue.component('vue-markdown', VueMarkdown)

/* eslint-disable no-new */
new Vue({
el: '#app',
Expand Down

0 comments on commit 757eb76

Please sign in to comment.