Skip to content

Instantly share code, notes, and snippets.

@gubser
Created June 9, 2016 10:59
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save gubser/b4e53e33b6d6e121688d80d8aa063e36 to your computer and use it in GitHub Desktop.
Save gubser/b4e53e33b6d6e121688d80d8aa063e36 to your computer and use it in GitHub Desktop.
Display the source blob
Display the rendered blob
Raw
{
"metadata": {
"name": "",
"signature": "sha256:2ada4f6283dac6b626529452f0f8de44528bedb095069c9823c4c6e5cfe8430b"
},
"nbformat": 3,
"nbformat_minor": 0,
"worksheets": [
{
"cells": [
{
"cell_type": "code",
"collapsed": false,
"input": [
"import ast"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 1
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"from collections import defaultdict"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 2
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"fn = 'ecnspider-results-ip4-160606.fjson'"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 3
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"groups = defaultdict(list)\n",
"with open(fn,'rt') as fp:\n",
" for line in fp:\n",
" obj = ast.literal_eval(line)\n",
" groups[obj['dip']+' '+str(obj['dp'])].append(obj)"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 4
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"len(groups)"
],
"language": "python",
"metadata": {},
"outputs": [
{
"metadata": {},
"output_type": "pyout",
"prompt_number": 10,
"text": [
"102678"
]
}
],
"prompt_number": 10
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"sum(len(value) <= 1 for value in groups.values())"
],
"language": "python",
"metadata": {},
"outputs": [
{
"metadata": {},
"output_type": "pyout",
"prompt_number": 6,
"text": [
"8914"
]
}
],
"prompt_number": 6
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"sum(len(value) > 1 for value in groups.values())"
],
"language": "python",
"metadata": {},
"outputs": [
{
"metadata": {},
"output_type": "pyout",
"prompt_number": 7,
"text": [
"102678"
]
}
],
"prompt_number": 7
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"# discard single measurements\n",
"groups = {key: value for key, value in groups.items() if len(value) > 1}"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 8
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"len(groups)"
],
"language": "python",
"metadata": {},
"outputs": [
{
"metadata": {},
"output_type": "pyout",
"prompt_number": 9,
"text": [
"102678"
]
}
],
"prompt_number": 9
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"def ecnonoff(pair):\n",
" for ecn_on in pair:\n",
" if ecn_on['ecnstate'] == 1:\n",
" break\n",
" else:\n",
" return None\n",
" \n",
" for ecn_off in pair:\n",
" if ecn_off['ecnstate'] == 0:\n",
" break\n",
" else:\n",
" return None\n",
" \n",
" return ecn_off, ecn_on"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 11
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"ecnonoffs = {key: ecnonoff(value) for key, value in groups.items() if ecnonoff(value) is not None}"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 13
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"def ecn_works(pair):\n",
" return pair[0]['connstate'] == 1 and pair[1]['connstate'] == 1"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 17
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"def ecn_broken(pair):\n",
" return pair[0]['connstate'] == 1 and pair[1]['connstate'] == 0"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 18
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"num_broken = sum(ecn_broken(pair) for pair in ecnonoffs.values())"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 22
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"ECN broken:"
]
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"num_broken / len(ecnonoffs)"
],
"language": "python",
"metadata": {},
"outputs": [
{
"metadata": {},
"output_type": "pyout",
"prompt_number": 26,
"text": [
"0.0002438286957115409"
]
}
],
"prompt_number": 26
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"ECN works"
]
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"num_works = sum(ecn_works(pair) for pair in ecnonoffs.values())"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 27
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"num_works / len(ecnonoffs)"
],
"language": "python",
"metadata": {},
"outputs": [
{
"metadata": {},
"output_type": "pyout",
"prompt_number": 25,
"text": [
"0.9992295013215515"
]
}
],
"prompt_number": 25
},
{
"cell_type": "code",
"collapsed": false,
"input": [],
"language": "python",
"metadata": {},
"outputs": []
}
],
"metadata": {}
}
]
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment