Представление экземпляров GPU: использование глубокого обучения для получения фронтальной визуализации изображений лица

Мы только что выпустили GPU Instances, наши первые серверы, оснащенные графическими процессорами (GPU). Оснащенные высокопроизводительными 16-ГБ картами NVIDIA Tesla P100 и высокоэффективными процессорами Intel Xeon Gold 6148, они идеально подходят для обработки данных, искусственного интеллекта, рендеринга и кодирования видео. В дополнение к выделенному графическому процессору и 10 ядрам Intel Xeon Gold каждый экземпляр поставляется с 45 ГБ памяти, 400 ГБ локального хранилища NVMe SSD и оплачивается 1 евро в час или 500 евро в месяц.

Сегодня мы представляем вам конкретный вариант использования для экземпляров графических процессоров, использующих глубокое обучение для получения фронтальной визуализации изображений лица. Не стесняйтесь попробовать это тоже. Для этого посетите консоль Scaleway, чтобы запросить квоты, прежде чем создавать свой первый экземпляр GPU.

Обзор графического процессора
Графический процессор (GPU) стал условным обозначением специализированной электронной схемы, предназначенной для питания графики на машине, в конце 1990-х годов, когда она была популяризирована производителем чипов NVIDIA.

Первоначально графические процессоры создавались главным образом для обеспечения высокого качества игр, создавая реалистичную цифровую графику. Сегодня эти возможности используются более широко для ускорения вычислительных нагрузок в таких областях, как искусственный интеллект, машинное обучение и сложное моделирование.

Экземпляры с графическим процессором в Scaleway были спроектированы так, чтобы их можно было оптимизировать для сбора огромных пакетов данных и очень быстрого выполнения одной и той же операции снова и снова. Сочетание эффективного процессора с мощным графическим процессором обеспечит наилучшее соотношение производительности системы и цены для ваших приложений глубокого обучения.

Написание собственного программного обеспечения Frontalization для лица с нуля
Сценаристы никогда не перестают нас смешить с причудливыми изображениями технологической индустрии, начиная от лукавого до веселого. Однако с учетом современных достижений в области искусственного интеллекта некоторые из самых нереалистичных технологий с экранов телевизоров оживают.

Например, программное обеспечение Enhance от CSI: NY (или Les Experts: Manhattan для наших франкоязычных читателей) уже вышло за пределы современных нейронных сетей Super Resolution. На более экстремальной стороне воображения находится враг государства:
«Поворот [кадры видеонаблюдения] на 75 градусов вокруг вертикали», должно быть, казался совершенно бессмысленным задолго до 1998 года, когда вышел фильм, о чем свидетельствуют комментарии YouTube под этим конкретным отрывком:


Несмотря на явный пессимизм аудитории, сегодня благодаря машинному обучению любой, кто обладает небольшим знанием Python, достаточно большим набором данных и учетной записью Scaleway, может попробовать написать программу, достойную научной фантастики.

Вступление
Забудьте MNIST, забудьте о классификаторах скучных кошек и собак, сегодня мы узнаем, как сделать что-то гораздо более захватывающее! Эта статья вдохновлена впечатляющей работой R. Huang et al. («За гранью вращения лица: глобальное и локальное восприятие GAN для фотореалистичного синтеза идентичности с сохранением идентичности»), в котором авторы синтезируют фронтальные виды лиц людей с учетом их изображений под разными углами. Ниже приведен рисунок 3 из этой статьи, в котором они сравнивают свои результаты [1] с предыдущей работой [2-6]:


Мы не будем пытаться воспроизвести современную модель R. Huang et al. Вместо этого вы сможете построить и обучить модель лобной фронтализации, дающую разумные результаты за один день:


Дополнительно вы узнаете:
  • Как использовать библиотеку NVIDIA DALI для высоко оптимизированной предварительной обработки изображений на GPU и подачи их в модель глубокого обучения.
  • Как зашифровать генерирующую состязательную сеть, которую в PyTorch назвал «самой интересной идеей за последние десять лет в машинном обучении» Янн ЛеКун, директор Facebook AI.
  • У вас также будет своя собственная Генеративная сеть состязаний, настроенная на обучение по выбранному вами набору данных. Без дальнейших церемоний, давайте копаться!

Шаг 1: Запуск и настройка экземпляра Gpu на Scaleway
Если вы еще не получили себе экземпляр GPU, размещенный в Scaleway, вы можете сделать это:
  • Войдите в консоль Scaleway.
  • Выберите вкладку Compute на левой боковой панели и нажмите зеленую кнопку + Создать сервер.
  • Выберите вкладку «GPU OS» в «Выберите образ» и «GPU» в «Выберите сервер».

Для этого проекта вы можете выбрать любой из двух доступных в настоящее время образов ОС GPU (10.1 и 9.2 относятся к соответствующим версиям CUDA) и выбрать RENDER-S в качестве сервера.


Нажмите на зеленую кнопку «Создать новый сервер» внизу страницы, и через несколько секунд ваш собственный экземпляр GPU будет запущен!


Теперь вы можете подключиться к нему по ssh, используя IP-адрес, который вы прочитали в своем списке экземпляров на вкладке Compute:
ssh root@[YOUR GPU INSTANCE IP ADDRESS]


Докерский путь:
Если вы знакомы с Docker, удобной платформой контейнерирования, которая позволяет упаковывать приложения вместе со всеми их зависимостями, продолжайте и извлекайте наш образ Docker, содержащий все пакеты и код, необходимый для проекта Frontalization, а также небольшой примерный набор данных:
nvidia-docker run -it rg.fr-par.scw.cloud/opetrova/frontalization:tutorial
root@b272693df1ca:/Frontalization# ls
Dockerfile  data.py  main.py  network.py  test.py  training_set

(Обратите внимание, что вам нужно использовать nvidia-docker, а не обычную команду docker из-за наличия графического процессора.) Теперь вы находитесь в каталоге Frontalization, содержащем четыре файла Python, содержимое которых мы рассмотрим ниже, и каталог training_set содержащий образец учебного набора данных. Отличное начало, теперь вы можете перейти к шагу 2!

Родной путь:
Если вы не знакомы с Docker, нет проблем, вы можете легко настроить среду вручную. Экземпляры Scaleway GPU поставляются с уже установленными CUDA, Python и conda, но на момент написания этой статьи вам необходимо понизить версию Python до Python 3.6, чтобы библиотека DALI от Nvidia функционировала:
conda install -y python==3.6.7
conda install -y pytorch torchvision

pip install --extra-index-url https://developer.download.nvidia.com/compute/redist nvidia-dali==0.6.1


Вы можете загрузить свой собственный тренировочный набор на свой экземпляр GPU через:
scp -r path/to/local/training_set root@[YOUR GPU INSTANCE IP ADDRESS]:/root/Frontalization

и сохраните код Python, который вы увидите ниже, в каталоге Frontalization, используя выбранный вами текстовый редактор терминала (например, nano или vim, оба из которых уже установлены). В качестве альтернативы вы можете клонировать репозиторий Scaleway GitHub для этого проекта.

Шаг 2: Настройка ваших данных
В основе любого проекта машинного обучения лежат данные. К сожалению, Scaleway не может предоставить базу данных CMU Multi-PIE Face, которую мы использовали для обучения из-за авторских прав, поэтому мы продолжим, если у вас уже есть набор данных, на котором вы хотели бы обучить свою модель. Чтобы использовать библиотеку загрузки данных NVIDIA (DALI), изображения должны быть в формате JPEG. Размеры изображений не имеют значения, поскольку у нас есть DALI для изменения размера всех входов до размера, требуемого нашей сетью (128 × 128 пикселей), но для получения наиболее реалистичных синтезированных изображений желательно соотношение 1: 1.,
Преимущество использования DALI перед, например, стандартным набором данных PyTorch, заключается в том, что любая предварительная обработка (изменение размера, обрезка и т. Д.) Выполняется на графическом процессоре, а не на процессоре, после чего предварительно обрабатываются изображения на графическом процессоре. питаются прямо в нейронную сеть.

Управление нашим набором данных:
Для проекта фронтализации лица мы настраиваем наш набор данных следующим образом: папка набора данных содержит подпапку и целевое фронтальное изображение для каждого человека (также как субъект). В принципе, имена подпапок и целевых изображений не обязательно должны быть идентичными (как показано на рисунке ниже), но если мы хотим отдельно отсортировать все подпапки и все цели в алфавитно-цифровом порядке, те, которые соответствуют одному и тому же субъект должен появляться в одной и той же позиции в двух списках имен.

Как видите, подпапка 001 /, соответствующая теме 001, содержит изображения человека, изображенные в 001.jpg — это близко обрезанные изображения лица в разных позах, условиях освещения и различных выражениях лица. Для целей фронтализации лица крайне важно, чтобы фронтальные изображения были выровнены как можно ближе друг к другу, тогда как другие (профильные) изображения имеют немного больше свободы.

Например, все наши целевые фронтальные изображения имеют квадратную форму и обрезаются таким образом, что нижняя часть подбородка человека расположена в нижней части изображения, а центрированная точка между внутренними углами глаз расположена на 0,8 ч выше и 0,5 часа справа от нижнего левого угла (h — высота изображения). Таким образом, после изменения размера изображений до 128 × 128 все элементы лица появляются в более или менее одинаковых местах на изображениях в обучающем наборе, и сеть может научиться генерировать упомянутые элементы и объединять их вместе в реалистичный синтез. лица.


Строительство трубопровода DALI:
Теперь мы собираемся построить конвейер для нашего набора данных, который будет наследоваться от nvidia.dali.pipeline.Pipeline. На момент написания DALI не поддерживает непосредственное чтение пар (изображение, изображение) из каталога, поэтому мы будем использовать nvidia.dali.ops.ExternalSource () для передачи входных данных и целей в конвейер.
data.py
import collections
from random import shuffle
import os
from os import listdir
from os.path import join

import numpy as np
from nvidia.dali.pipeline import Pipeline
import nvidia.dali.ops as ops            
import nvidia.dali.types as types


def is_jpeg(filename):
    return any(filename.endswith(extension) for extension in [".jpg", ".jpeg"])


def get_subdirs(directory):
    subdirs = sorted([join(directory,name) for name in sorted(os.listdir(directory)) if os.path.isdir(os.path.join(directory, name))])
    return subdirs


flatten = lambda l: [item for sublist in l for item in sublist]


class ExternalInputIterator(object):

    def __init__(self, imageset_dir, batch_size, random_shuffle=False):
        self.images_dir = imageset_dir
        self.batch_size = batch_size

        # First, figure out what are the inputs and what are the targets in your directory structure:
        # Get a list of filenames for the target (frontal) images
        self.frontals = np.array([join(imageset_dir, frontal_file) for frontal_file in sorted(os.listdir(imageset_dir)) if is_jpeg(frontal_file)])

        # Get a list of lists of filenames for the input (profile) images for each person
        profile_files = [[join(person_dir, profile_file) for profile_file in sorted(os.listdir(person_dir)) if is_jpeg(profile_file)] for person_dir in get_subdirs(imageset_dir)]

        # Build a flat list of frontal indices, corresponding to the *flattened* profile_files
        # The reason we are doing it this way is that we need to keep track of the multiple inputs corresponding to each target
        frontal_ind = []
        for ind, profiles in enumerate(profile_files):
            frontal_ind += [ind]*len(profiles)
        self.frontal_indices = np.array(frontal_ind)

        # Now that we have built frontal_indices, we can flatten profile_files
        self.profiles = np.array(flatten(profile_files))

        # Shuffle the (input, target) pairs if necessary: in practice, it is profiles and frontal_indices that get shuffled
        if random_shuffle:
            ind = np.array(range(len(self.frontal_indices)))
            shuffle(ind)
            self.profiles = self.profiles[ind]
            self.frontal_indices = self.frontal_indices[ind]


    def __iter__(self):
        self.i = 0
        self.n = len(self.frontal_indices)
        return self


    # Return a batch of (input, target) pairs
    def __next__(self):
        profiles = []
        frontals = []

        for _ in range(self.batch_size):
            profile_filename = self.profiles[self.i]
            frontal_filename = self.frontals[self.frontal_indices[self.i]]

            profile = open(profile_filename, 'rb')
            frontal = open(frontal_filename, 'rb')

            profiles.append(np.frombuffer(profile.read(), dtype = np.uint8))
            frontals.append(np.frombuffer(frontal.read(), dtype = np.uint8))

            profile.close()
            frontal.close()

            self.i = (self.i + 1) % self.n
        return (profiles, frontals)

    next = __next__


class ImagePipeline(Pipeline):
    '''
    Constructor arguments:  
    - imageset_dir: directory containing the dataset
    - image_size = 128: length of the square that the images will be resized to
    - random_shuffle = False
    - batch_size = 64
    - num_threads = 2
    - device_id = 0
    '''

    def __init__(self, imageset_dir, image_size=128, random_shuffle=False, batch_size=64, num_threads=2, device_id=0):
        super(ImagePipeline, self).__init__(batch_size, num_threads, device_id, seed=12)  
        eii = ExternalInputIterator(imageset_dir, batch_size, random_shuffle)
        self.iterator = iter(eii)
        self.num_inputs = len(eii.frontal_indices)

        # The source for the inputs and targets
        self.input = ops.ExternalSource()
        self.target = ops.ExternalSource()

        # nvJPEGDecoder below accepts  CPU inputs, but returns GPU outputs (hence device = "mixed")
        self.decode = ops.nvJPEGDecoder(device = "mixed", output_type = types.RGB)

        # The rest of pre-processing is done on the GPU
        self.res = ops.Resize(device="gpu", resize_x=image_size, resize_y=image_size)
        self.norm = ops.NormalizePermute(device="gpu", output_dtype=types.FLOAT,
                                         mean=[128., 128., 128.], std=[128., 128., 128.],
                                         height=image_size, width=image_size)


    # epoch_size = number of (profile, frontal) image pairs in the dataset
    def epoch_size(self, name = None):
        return self.num_inputs


    # Define the flow of the data loading and pre-processing
    def define_graph(self):    
        self.profiles = self.input(name="inputs")
        self.frontals = self.target(name="targets")
        profile_images = self.decode(self.profiles)
        profile_images = self.res(profile_images)
        profile_output = self.norm(profile_images)
        frontal_images = self.decode(self.frontals)
        frontal_images = self.res(frontal_images)
        frontal_output = self.norm(frontal_images)
        return (profile_output, frontal_output)


    def iter_setup(self):
        (images, targets) = self.iterator.next()
        self.feed_input(self.profiles, images)
        self.feed_input(self.frontals, targets)


Теперь вы можете использовать класс ImagePipeline, который вы написали выше, для загрузки изображений из вашего каталога наборов данных, по одному пакету за раз.

Если вы используете код из этого учебника в блокноте Jupyter, вот как вы можете использовать ImagePipeline для отображения изображений:
from __future__ import division
import matplotlib.gridspec as gridspec
import matplotlib.pyplot as plt
%matplotlib inline


def show_images(image_batch, batch_size):
    columns = 4
    rows = (batch_size + 1) // (columns)
    fig = plt.figure(figsize = (32,(32 // columns) * rows))
    gs = gridspec.GridSpec(rows, columns)

    for j in range(rows*columns):
        plt.subplot(gs[j])
        plt.axis("off")
        plt.imshow(np.transpose(image_batch.at(j), (1,2,0)))


batch_size = 8
pipe = ImagePipeline('my_dataset_directory', image_size=128, batch_size=batch_size)
pipe.build()
profiles, frontals = pipe.run()


# The images returned by ImagePipeline are currently on the GPU
# We need to copy them to the CPU via the asCPU() method in order to display them
show_images(profiles.asCPU(), batch_size=batch_size)
show_images(frontals.asCPU(), batch_size=batch_size)


blog.scaleway.com/2019/gpu-instances-using-deep-learning-to-obtain-frontal-rendering-of-facial-images/

Домен .MONSTER — для ужасно хороших проектов и идей

14 марта 2019 года на сайте REG.RU, крупнейшего доменного регистратора и хостинг-провайдера России, стартует предзаказ адресов в доменной зоне .MONSTER. Домен подойдёт для развлекательных ресурсов, специализированных литературных журналов, сайтов киностудии, личных блогов и ярких коммерческих проектов. Участие в этапе предзаказа повышает шансы на получение лучших имён во время открытой регистрации.

Изначально доменная зона .MONSTER принадлежала владельцам сайта по поиску работы MONSTER.COM и была доменом-брендом. Но компания не смогла найти для него применение. Однако .MONSTER оказался уж слишком интересен и привлекателен, чтобы просто быть удалённым и забытым. Поэтому его приобрел администратор зоны .XYZ XYZ Registry и сделал домен доступным для всех желающих.

Доменная зона .MONSTER прежде всего заинтересует владельцев развлекательных ресурсов: видеохостингов, сайтов с мемами и другим контентом. Зона .MONSTER также станет хорошим выбором для специализированных сайтов и интернет-журналов с хоррор-историями и рассказами. Домен подойдёт и крупным киностудиям, которые захотят сделать необычный промосайт для своего фильма о каком-либо монстре, или производителям тематических детских игрушек. Кроме того, .MONSTER может стать более ярким и дерзким аналогом доменов .GURU и .PRO. Владельцы сайтов в такой зоне смогут показать всем, что они настоящие «монстры» в своём деле и справятся с любой задачей.

Для участия в предзаказе достаточно подать заявку с указанием желаемого домена на сайте REG.RU и оплатить годовую стоимость регистрации — 709 рублей. Если доменное имя не будет зарегистрировано, то регистратор вернёт средства в полном объёме. Открытая регистрация в .MONSTER стартует 1 апреля 2019 года. Подробности о предзаказе на сайте REG.RU: www.reg.ru/domain/new-gtlds#preorder

«Возможность самореализоваться и выделиться — одно из преимуществ Интернета. И так было практически с самого начала. На рынке доменов действуют множество зон, главная цель которых не показать специализацию бизнеса или сайта, а подчеркнуть его индивидуальность, необычность и привлечь дополнительное внимание. Зоны .WTF, .LOL, .SEXY — этот список можно продолжать долго. Сейчас к нему присоединяется .MONSTER. Домен для самых смелых, ярких, заметных. Для настоящих монстров рынка», — комментирует генеральный директор REG.RU Алексей Королюк.

OVH's SmartFuse Technology

Каждый сервер защищен отдельно (Смартфусе), может быть выключен вручную, и мы mesure энергопотребление в режиме реального времени. Нет дополнительных кабелей: Ethernet над питанием (BPL/CPL) с шифрованием.

Dell и AMD



Мы собрали Dell и AMD вместе в одном доме. Наш новейший сервер Dell оснащен процессором AMD EPYC 7551P с 32 ядрами и 128 ГБ оперативной памяти DDR4 ECC. Благодаря большому количеству потоков ЦП и оперативной памяти DDR4 ECC, которые можно масштабировать за небольшую дополнительную плату, этот сервер специально разработан для приложений виртуализации и многопоточности.

Выделенный корневой сервер DX180 доступен в базовой конфигурации всего за 189 евро в месяц плюс единовременная плата за установку в размере 189 евро!

Кроме того, вы можете добавить до 10 дисков в соответствии с вашими конкретными требованиями к хранилищу. Вы можете установить NVM, которые начинаются с 28 евро в месяц, или твердотельные накопители, которые начинаются всего с 8 евро в месяц. Или вы можете смонтировать смесь обоих!

www.hetzner.com/dedicated-rootserver/matrix-dell
www.hetzner.com/dedicated-rootserver/dell/dx180/configurator

Новая точка в Сиэтл


Осенью мы добавили точку в Далласе и вчера запустили точку в Сиэтле. gthost.com/seattle-dedicated-servers/
Америка полностью накрыта:
  • Chicago
  • New York
  • Miami
  • Dallas
  • Los Angeles
  • Seattle

Сервера Xeon E3 v3 от $49/месяц. Платы за установку нет. Сервера готовые через 5 минут после оплаты, если без ОС и через 10-15 минут с Linux OS. В каждом сервере есть IPMI, так что можно устаналивать любую ОС. Оплата помесячно. Можно любой сервер арендовать на тест от 1 до 10 дней от $5/day, после теста сервер можно продлить на месяц или опять на тестовый период или удалится автоматом.

Обзороное видео по сайту и демонстрация, как арендовать сервер за несколько минут:
www.youtube.com/watch?v=VkMth_to6uE

Больше 200 готовых, список серверов в реальном режиме времени: gthost.com/instant-servers/

Всегда есть скидка на первый месяц: gthost.com/promotions/

Проверить ping и traceroute: gthost.com/looking-glass/

Изменения в приложениях к договору

В связи с появлением возможности добавления опции Wildcard в процессе заказа SSL-сертификата Thawte SSL 123 с 14 марта 2019 года вступают в действие обновленные версии приложений к договору.

www.nic.ru/news/2019/0314-izmeneniya-v-prilozheniyakh-k-dogovoru/

Hetzner Online Community




community.hetzner.com
community.hetzner.com/tutorials
forum.hetzner.com

Интернет-сообщество Hetzner включает в себя активный дискуссионный форум Hetzner Online, где вы уже можете обмениваться советами и рекомендациями с пользователями. Кроме того, он будет включать новый раздел учебников.

Нам нужна ваша помощь, чтобы наше сообщество росло. Независимо от того, являетесь ли вы разработчиком, администратором, посредником или просто человеком, который любит писать хорошие руководства, в Сообществе есть место для вас. У вас также есть идея для полезного учебника, который еще не был опубликован? Отправь это! Если мы опубликуем его, мы предоставим вам кредит в размере до 50 евро (без НДС), который вы можете использовать для продуктов Hetzner, таких как выделенные корневые серверы, ящики для хранения, пакеты Nextcloud и многое другое.

Воспользуйтесь опытом других, делитесь идеями с профессионалами и тестируйте инновационные решения.

Серверы от 3 500 руб


Весна уже здесь, а вместе со снегом тают и цены. Не пропустите серверную распродажу марта. Выделенные серверы по тарифу «все включено» от 3 500 рублей в месяц. Выбирайте подходящий сервер, а мы подготовим его в кратчайшие сроки.

Получите при аренде сервера в RackStore:
  • Бесплатную установку и подключение сервера
  • Полностью безлимитный Интернет 100 Мбит/сек.
  • IP-адрес (IPv4 или IPv6 на выбор)
  • Удаленное управление сервером IPMI на 5 дней
  • Первичную установку ОС на выбор
  • Бесперебойное питание
Готовность любого сервера — 2 часа. Количество акционных серверов ограничено. По Вашему желанию мы можем оперативно внести изменения в выбранную конфигурацию.
rackstore.ru/arenda-servera.html

Домен 864.com украден второй раз за короткое время

Группа пользователей из Китая подала иск в Окружной суд округа Западной Вирджинии по поводу кражи ряда ценных числовых доменов: 864.com, 00998.com, 00488.com, 0103.com, и 1148.com. Истцы сообщают, что домены были похищены хакерами, и требуют вернуть их им как законным владельцам. Иск подан по месту нахождения VeriSign — администратора доменной зоны .COM

При этом самый ценный из доменов — 864.com — был украден второй раз за короткое время. До этого он был похищен в 2017 году и был возвращён владельцу по решению суда. Недавно домен был украден снова. Стоит также отметить, что в ноябре 2018 года 864.com сменил владельца. Он был приобретен за весьма значительную сумму — 147 тысяч долларов. Возможно, мошенникам удалось сбыть уже украденный домен, так как в заявлении истцов сказано, что доступ к домену был потерян в июле 2018 года.

Эксперты отмечают, что именно цифровые домены часто становятся объектами кражи. Поэтому если такой домен в последнее время часто менял владельца или переводился от одного регистратора к другому — это должно насторожить покупателя. Приобретая подобные домены, нужно удостовериться, что вы покупаете их у законных владельцев.

www.webnames.ru

Бесплатно отдадим ИБП самовывозом

Уважаемый абонент!
Отдадим БЕСПЛАТНО несколько ИБП в разном состоянии:
  • 1 SNR-UPS-ONRT-2-MPL 2000ВА / 1800Вт Ошибка, реле
  • 2 SNR-UPS-ONRT-3-MPL 3000ВА / 2700Вт Ошибка, реле
  • 3 SNR-UPS-ODC-3KVA 3000ВА / 2400Вт Ошибка, реле
  • 4 SNR-UPS-ONRT-2-MPL 2000ВА / 1800Вт Ошибка, реле
  • 5 SNR-UPS-ONRT-3-MPL 3000ВА / 2700Вт Ошибка, реле
  • 6 EATON PW9130i6000T-XL 6000ВА / 5400Вт Ошибка
Все ИБП необходимо предварительно продиагностировать. Если у вас есть знакомые мастера или вы сами знатный инженер, то это предложение для вас =)
Самовывоз из нашего офиса по адресу Шишкова 13.

Если Вы заинтересовались звоните по телефону 705-464.