Martin Geisler
2008-06-23 10:28:25 UTC
# HG changeset patch
# User Martin Geisler <***@daimi.au.dk>
# Date 1214215643 -7200
# Node ID cc937fbd7ac31e921fce1d374e982d5061b43081
# Parent 926f19ca9b83e6e803894369e654dee0e1129a0d
Test program for ElGamal based multiplication.
diff --git a/apps/elgamal.py b/apps/elgamal.py
new file mode 100755
--- /dev/null
+++ b/apps/elgamal.py
@@ -0,0 +1,57 @@
+#!/usr/bin/python
+
+# Copyright 2008 VIFF Development Team.
+#
+# This file is part of VIFF, the Virtual Ideal Functionality Framework.
+#
+# VIFF is free software: you can redistribute it and/or modify it
+# under the terms of the GNU Lesser General Public License (LGPL) as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# VIFF is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General
+# Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with VIFF. If not, see <http://www.gnu.org/licenses/>.
+
+import sys
+
+from twisted.internet import reactor
+
+from viff.field import GF256
+from viff.runtime import create_runtime, Share
+from viff.elgamal import ElGamalRuntime, _dummy_field
+from viff.config import load_config
+from viff.util import dprint
+
+id, players = load_config(sys.argv[1])
+input = int(sys.argv[2])
+
+print "I am player %d and will input %s" % (id, input)
+
+
+def protocol(runtime):
+ print "-" * 64
+ print "Program started"
+ print
+
+ a, b = runtime.share([1, 2], input)
+ c = a * b
+ a = runtime.open(a)
+ b = runtime.open(b)
+ c = runtime.open(c)
+
+ dprint("### opened a: %s ###", a)
+ dprint("### opened b: %s ###", b)
+ dprint("### opened c: %s ###", c)
+
+ runtime.wait_for(a, b, c)
+
+pre_runtime = create_runtime(id, players, 1, runtime_class=ElGamalRuntime)
+pre_runtime.addCallback(protocol)
+
+print "#### Starting reactor ###"
+reactor.run()
# User Martin Geisler <***@daimi.au.dk>
# Date 1214215643 -7200
# Node ID cc937fbd7ac31e921fce1d374e982d5061b43081
# Parent 926f19ca9b83e6e803894369e654dee0e1129a0d
Test program for ElGamal based multiplication.
diff --git a/apps/elgamal.py b/apps/elgamal.py
new file mode 100755
--- /dev/null
+++ b/apps/elgamal.py
@@ -0,0 +1,57 @@
+#!/usr/bin/python
+
+# Copyright 2008 VIFF Development Team.
+#
+# This file is part of VIFF, the Virtual Ideal Functionality Framework.
+#
+# VIFF is free software: you can redistribute it and/or modify it
+# under the terms of the GNU Lesser General Public License (LGPL) as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# VIFF is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General
+# Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with VIFF. If not, see <http://www.gnu.org/licenses/>.
+
+import sys
+
+from twisted.internet import reactor
+
+from viff.field import GF256
+from viff.runtime import create_runtime, Share
+from viff.elgamal import ElGamalRuntime, _dummy_field
+from viff.config import load_config
+from viff.util import dprint
+
+id, players = load_config(sys.argv[1])
+input = int(sys.argv[2])
+
+print "I am player %d and will input %s" % (id, input)
+
+
+def protocol(runtime):
+ print "-" * 64
+ print "Program started"
+
+ a, b = runtime.share([1, 2], input)
+ c = a * b
+ a = runtime.open(a)
+ b = runtime.open(b)
+ c = runtime.open(c)
+
+ dprint("### opened a: %s ###", a)
+ dprint("### opened b: %s ###", b)
+ dprint("### opened c: %s ###", c)
+
+ runtime.wait_for(a, b, c)
+
+pre_runtime = create_runtime(id, players, 1, runtime_class=ElGamalRuntime)
+pre_runtime.addCallback(protocol)
+
+print "#### Starting reactor ###"
+reactor.run()