{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "## Basic Order\n", "This notebook contains a basic ordering example for vector optimization." ] }, { "cell_type": "code", "execution_count": 1, "metadata": {}, "outputs": [], "source": [ "import numpy as np\n", "from vopy.order import ConeTheta2DOrder" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Let's define two different cones to see their difference. The former will be an acute cone and the latter will be an obtuse cone." ] }, { "cell_type": "code", "execution_count": 2, "metadata": {}, "outputs": [ { "data": { "image/png": "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ggytUFXlx6+/jnjqqfLHV64Mr6YcDMrFILt3R7z4YllV+OCD5btiM8GQgyBDC3zySflxy5aySOLixXIF5Y4dES+8sHRD0qjuQYa2W1aQq6qK2dnZ1X4W4A4sLEQcP34+IiKq6nwcOFDeiJ6eLtdULr4y88KFhh4SiPHx8Vh3kyOpdVVVH3bd2Pnz52OrSX8AuGPnzp2LiYmJG/7/ywqy75Aht/Pnz8fBgwfj9OnTN/0FDzTnVt8hL+vIet26dX6RwwiYmJjwaxVGlClDAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABIQZABIQJABIAFBBoAEBBkAEhBkAEhAkAEgAUEGgAQEGQASEGQASECQASABQQaABAQZABJYV1VV1fRDAHenqqqYnZ2N8fHxWLduXdOPA9wBQQaABBxZA0ACggwACQgyACQgyACQgCADQAKCDAAJCDIAJPB/JO8J+T4IkVMAAAAASUVORK5CYII=", "text/plain": [ "
" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "order_acute = ConeTheta2DOrder(cone_degree=45)\n", "_ = order_acute.ordering_cone.plot()" ] }, { "cell_type": "code", "execution_count": 3, "metadata": {}, "outputs": [ { "data": { "image/png": "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cnPVyZO3bq6a6XfNlWq1Wp3fxwXm29TUVAwNDcXk5GQMDg42+nGA/7h0KX+9/eyzd/9si2+XBIDGGRiYWRhHCGQAKIJABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKIBABoACCGQAKEClWq1WG/0QwOxUq9W4dOlSDAwMRKVSafTjAPdBIANAAYysAaAAAhkACiCQAaAAAhkACiCQAaAAAhkACiCQAaAA/w+CtcwmsZHV3QAAAABJRU5ErkJggg==", "text/plain": [ "
" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "order_obtuse = ConeTheta2DOrder(cone_degree=135)\n", "_ = order_obtuse.ordering_cone.plot()" ] }, { "cell_type": "code", "execution_count": 4, "metadata": {}, "outputs": [], "source": [ "pt1, pt2 = np.array([[0, 0],\n", " [0.05, 1]])" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "We define $\\text{pt1} = (0, 0)$ and $\\text{pt2} = (0.05, 1)$. Surely $\\text{pt2}$ is better than $\\text{pt1}$... right? Actually, it depends on the partial ordering." ] }, { "cell_type": "code", "execution_count": 5, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Does pt2 dominate pt1 in acute cone ordering?: [False]\n", "Does pt2 dominate pt1 in obtuse cone ordering?: [ True]\n" ] } ], "source": [ "print(\"Does pt2 dominate pt1 in acute cone ordering?: \", order_acute.dominates(pt2, pt1))\n", "print(\"Does pt2 dominate pt1 in obtuse cone ordering?:\", order_obtuse.dominates(pt2, pt1))" ] } ], "metadata": { "language_info": { "name": "python" } }, "nbformat": 4, "nbformat_minor": 2 }