Ковер аэропорт


17

В 2015 году международный аэропорт Портленда начал замену своего культового ковра . Я хочу, чтобы вы написали программу для рисования своего старого ковра в минимально возможном количестве байтов.

Ковер:

Одна плитка

Характеристики

  • Вот ссылка на масштабируемое изображение в формате PDF одной плитки. Ваш вывод должен соответствовать относительным размерам и размещению этого изображения.

  • Все цвета в вашем конечном изображении должны быть в пределах 15 от каждого значения RGB в указанном изображении. Они перечислены ниже для вашего удобства.

                Red   Green Blue
    Teal:       0,    168,  142
    Magenta:    168,  108,  185
    Orange:     247,  58,   58
    Light Blue: 90,   166,  216
    Dark Blue:  0,    77,   117
    
  • Ваш вывод должен быть не менее 150x150 пикселей и должен быть квадратным. Если вы выбираете вывод в масштабируемом формате, таком как векторное изображение, вы должны точно соответствовать изображению.

  • Вы можете вывести изображение в любом существующем ранее формате.

  • Это поэтому вы должны стремиться минимизировать количество байтов в вашем коде.



@ Hexaholic Я не думаю, поэтому я случайно ударил по Википедии и попал на страницу. Однако я, возможно, также видел это на Reddit перед рукой.
Пост Рок Гарф Хантер

1
Это должно быть двухмерное изображение или что-то вроде модели, рассматриваемой под определенным углом?
devRicher

Ответы:


9

Чистый HTML, 873 байта

<table width=152 height=152 bgcolor=#0a8><tr><td colspan=7><td bgcolor=#5AD><tr><td><td bgcolor=#057><td colspan=5><td bgcolor=#5AD><tr><td><td><td bgcolor=#057><td colspan=4><td bgcolor=#5AD><tr><td><td><td><td bgcolor=#057><td><td><td><td bgcolor=#5AD><tr><td colspan=7><td bgcolor=#057><td><td><td bgcolor=#057><tr><td colspan=7><td bgcolor=#057><td><td bgcolor=#057><tr><td colspan=7><td bgcolor=#057><td bgcolor=#057><td><td><td><td bgcolor=#F33><td bgcolor=#F33><td bgcolor=#F33><tr><td colspan=6><td bgcolor=#F33><td bgcolor=#057><td colspan=7 bgcolor=#057><tr><td bgcolor=#A6B><td bgcolor=#A6B><td bgcolor=#A6B><td bgcolor=#A6B><td bgcolor=#A6B><td bgcolor=#A6B><td bgcolor=#A6B><td rowspan=6 bgcolor=#057><tr><td><tr><td><tr><td colspan=11><td bgcolor=#057><tr><td colspan=12><td bgcolor=#057><tr><td colspan=13><td bgcolor=#057><tr><td colspan=7><td bgcolor=#057>

HTML + CSS, 625 байт

#l{background:#5AD}th{background:#057}#o{background:#F33}#m>td{background:#A6B
<table width=152 height=152 bgcolor=#0A8><tr><td colspan=7><td id=l><tr><td><th><td colspan=5><td id=l><tr><td><td><th><td colspan=4><td id=l><tr><td><td><td><th><td><td><td><td id=l><tr><td colspan=7><th><td><td><th><tr><td colspan=7><th><td><th><tr><td colspan=7><th><th><td><td><td><td bgcolor=#F33><td bgcolor=#F33><td bgcolor=#F33><tr><td colspan=6><td bgcolor=#F33><th><th colspan=7><tr id=m><td><td><td><td><td><td><td><th rowspan=6><tr><td><tr><td><tr><td colspan=11><th><tr><td colspan=12><th><tr><td colspan=13><th><tr><td colspan=7><th>


9

Тикз, 725 693 681 671 байт

\documentclass{standalone}\usepackage{xcolor,tikz}\begin{document}\tikz[line width=20,every node/.style={minimum size=20}]{\definecolor{t}{RGB}{0,168,142}\definecolor{m}{RGB}{168,99,185}\definecolor{o}{RGB}{247,58,58}\definecolor{b}{RGB}{90,166,216}\definecolor{d}{RGB}{40,77,117}\fill[t](-7.5,-7.5)rectangle(7.5,7.5);\draw(-1,0)node[fill=o]{};\foreach\x in{1,...,7}{\draw(-\x,-1)node[fill=m]{};\draw(0,\x)node[fill=b]{};}\foreach\x in{1,...,3}{\draw(\x,\x)node[fill=d]{};\draw(3+\x,-3-\x)node[fill=d]{};\draw(-3-\x,3+\x)node[fill=d]{};\draw(4+\x,1)node[fill=o]{};}\draw[d](.65,0)--(7.35,0);\draw[d,dash pattern=on20off8.5on162.5off8.5](0,-7.35)--(0,3.35);}\end{document}

Попробуйте онлайн!

объяснение

Большая часть кода является оберткой:

\documentclass{standalone}\usepackage{xcolor,tikz}\begin{document}\tikz{...}\end{document}

Это небольшая вариация стандартной обертки Tikz в том, что она также имеет строку \usepackage{xcolor} чтобы мы могли правильно создавать цвета.

Первое, что сделано, это line width=20,every node/.style={minimum size=20}] это устанавливает линии и узлы, чтобы иметь правильный размер.

Как только это будет сделано, мы определим цвета, которые мы будем использовать для различных частей изображения:

\definecolor{t}{RGB}{0,168,142}\definecolor{m}{RGB}{168,99,185}\definecolor{o}{RGB}{247,58,58}\definecolor{b}{RGB}{90,166,216}\definecolor{d}{RGB}{40,77,117}

Теперь, когда все настроено, мы рисуем фон для нашего холста:

\fill[t](-7.5,-7.5)rectangle(7.5,7.5);

(Я не буду включать изображение этого, потому что это просто чирок, но я буду включать изображения каждого шага)

Первый узел, который мы добавляем - это оранжевый узел слева от центра холста.

\draw(-1,0)node[fill=o]{};

Апельсин в море

Теперь нарисуем голубые и пурпурные узлы. Есть 7 синих узлов и 4 синих узла, но мы можем нарисовать дополнительные узлы, которые будут покрыты линиями позже, поэтому мы будем рисовать 7 из каждого.

\foreach\x in{1,...,7}{
    \draw(-\x,-1)node[fill=m]{};
    \draw(0,\x)node[fill=b]{};
}

Разветвленные дорожки

Теперь мы нарисуем все группы из 3 точек, используя один \foreachцикл

\foreach\x in{1,...,3}{\draw(\x,\x)node[fill=d]{};\draw(3+\x,-3-\x)node[fill=d]{};\draw(-3-\x,3+\x)node[fill=d]{};\draw(4+\x,1)node[fill=o]{};}

Рассеянные точки

Теперь мы рисуем правильную линию. Эта линия будет простой линией со смещениями .35в каждом направлении, чтобы соответствовать размеру узла.

\draw[d](.65,0)--(7.35,0);

коллизия

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

Этот шаблон [dash pattern=on20off8.5on162.5off8.5]создает квадрат с длинным сплошным хвостом. Наша линия начнется снизу и не будет полностью покрывать 2 цикла модели.

\draw[d,dash pattern=on20off8.5on162.5off8.5](0,-7.35)--(0,3.35);

окончательный

И теперь мы закончили.


Можете ли вы использовать числа для представления цветов RGB в Tikz вместо ввода смещений RGB?
Yytsi

@TuukkaX Я так думаю, но я не мог понять это. Если вы знаете, как я был бы благодарен за просветление.
Пост Рок Гарф Хантер

Я вообще не знаю Tikz, поэтому не могу с этим поделать :( Однако, если я правильно понял ваше правило о «в пределах 15 от каждого RGB», вы можете изменить 108 на 99, так как ошибка меньше 15.
Yytsi

@TuukkaX Спасибо!
Post Rock

Использование \definecolorсо HTMLспецификацией (а не RGB) позволяет указывать цвета с использованием шестнадцатеричного значения.
Джулиан Вольф

6

буквальный файл PNG, 283 , 234 227 байт

РЕДАКТИРОВАТЬ : Использование онлайн-сервиса сжатия изображений https://compress-or-die.com/ , это сократилось еще на 7 байт.

albn @ alexhi

j:~/tmp$ ls -l carpet3.png
-rw-r--r-- 1 albn albn 227 15. Feb 12:01 carpet3.png
albn@alexhij:~/tmp$ base64 carpet3.png 
iVBORw0KGgoAAAANSUhEUgAAAJgAAACYBAMAAADq7D0SAAAAD1BMVEUAqI4ATXWobLn3Ojpapthl
S7nNAAAAj0lEQVR4Ae3ThRHCQBQGYVqgBVq4Fui/Jt4ILks8/80uLvkyOTlkd67EILHojtWEyxQT
Sw6uFS5TTCw/uFa+TDGx/PjS3z+KiS2GcRtgzIqJdboDPomteniCxMTyatXtMiExMcB22amCJ7wG
MbHpBWBiYmJiYmJwAjGx/ncAn0VMrP8dwL+KieXHFyImltoF6oWZiblRTNQAAAAASUVORK5CYII=

carpet3.png

227 байт - это фактический размер двоичного файла carpet.png. При кодировании в base64, как показано в приведенном выше блоке, он на несколько байтов длиннее (308 байтов). Инкапсуляция этого в HTML-фрагменте, который отображает изображение правильно, добавит еще несколько байтов:

HTML, 414 , 343 , 336 байт

<img src=

Изменить : я удалил кавычки и закрытие>, как предложил Шегги. Также сжал изображение еще на 17 , 24 байта


1
Я не думаю, что буквальный файл считается допустимым языком программирования здесь на code-golf. Это зависит от ФП, является ли это действительным или нет.
Товарищ SparklePony

1
Вы можете быть правы, но даже в описании тега kolmogorov-сложно на codegolf.stackexchange.com/tags/kolmogorov-complexity/info упоминается сложная строка, кратчайшим представлением которой может быть ее буквальная печать. Если буквенная строка считается «худшим решением» для строкового кода-гольфа, буквенный файл изображения может считаться «худшим решением» для основанного на изображении кода-гольфа. Изменить: я только опубликовал файл, потому что я был удивлен, что он на самом деле короче, чем другие решения, опубликованные ранее. (после удаления необязательного фрагмента tIME из файла)
воскресенье,

Если это до меня, я в порядке с этим.
Пост Рок Гарф Хантер

2
С небольшим сжатием, вы можете получить это. Кроме того, отбросьте кавычки, любой трейлинг =и закрытие >. Вот 366-байтовая версия, над которой я работал до того, как увидел ваш ответ:<img src=
Shaggy

1
@ComradeSparklePony Обычно нам не нужны ответы на языке программирования на такие вопросы: codegolf.meta.stackexchange.com/questions/3610/…
isaacg,

5

Mathematica, 285 байтов

e={1,1};r=RGBColor["#"<>#]&;c=Cuboid;s=c[3#-e,3#+e]&;a=Array;b=a[s[{1,-1}#]&,3,#]&;Graphics@{r@"0a8",c[-23e,23e],r@"a6b",a[s@{-#,-1}&,7],r@"f33",a[s@{#,1}&,3,5],s@{-1,0},r@"5ad",a[s@{0,#}&,4,4],r@"057",a[s[e#]&,4,0],b@4,b[-6],s@{0,-7},{-1,2}~c~{1,10},{-1,-2}~c~{1,-19},{2,-1}~c~{22,1}}

Легче читать:

 1  c = Cuboid; e = {1, 1};
 2  s = c[3 # - e, 3 # + e] &;
 3  a = Array; b = a[s[{1, -1} #] &, 3, #] &;
 4  r = RGBColor["#" <> #] &; 
 5  Graphics@{
 6   r@"0a8", c[-23 e, 23 e],
 7   r@"a6b", a[s@{-#, -1} &, 7],
 8   r@"f33", a[s@{#, 1} &, 3, 5], s@{-1, 0},
 9   r@"5ad", a[s@{0, #} &, 4, 4],
10   r@"057",
11    a[s[e #] &, 4, 0], b@4, b[-6], s@{0, -7},
12    {-1, 2}~c~{1, 10}, {-1, -2}~c~{1, -19}, {2, -1}~c~{22, 1}
13  }

Строки 1–3 определяют короткие имена для функций, наиболее важным из которых является sотрисовка квадрата с центром в координатах, которые он получает (в действительности в 3 раза больше его координат, для соответствующего масштабирования). В строке 4 определяется цветовая функция с использованием «сокращенной» RGB-системы Mathematica: RGBColor["#xyz"]где xyzшестнадцатеричные цифры означаютRGBColor[{17x, 17y, 17z}] (так, чтобы каждая координата имела 16 одинаково разнесенных опций, работающих от 0 до 255). Первые команды в строках 6–10 переключают текущий цвет, используя горячие цвета, которые ближе всего к назначенным пяти цветам (при округлении до значения, кратного 17, никакое значение не будет больше 8).

Линия 6 рисует большой чирок. Линия 7 рисует линию пурпурных квадратов, линия 8 рисует линию оранжевых квадратов и один оранжевый квадрат. Линия 9 рисует линию голубых квадратов. Линия 11 рисует три диагональные линии темно-синих квадратов, а также один темно-синий квадрат внизу. Наконец, линия 12 рисует три длинных темно-синих прямоугольника. Выход ниже:

Портленд

(Совет по гольфу: команда Cuboid, предназначенная для трехмерных графических объектов, прекрасно работает в 2d и короче Rectangle.)


2

Питон, 420

from PIL import Image,ImageDraw
B=0,77,117
I=Image.new('RGB',(300,300),(0,168,142))
r=ImageDraw.Draw(I).rectangle
for x,y,c in['7172737a98cde670123456bcd70112233456666778888888bcde23232323331111300000003333'[x::26]for x in range(26)]:exec'r([W,W,14+W,14+W],[(168,108,185),(247,58,58),(90,166,216),B][%s]);'.replace('W','2+20*0x%s')%(x,y,x,y,c)
r([162,142,296,156],B)
r([142,82,156,136],B)
r([142,162,156,276],B)
I.show()

1

HTML / SVG, 550 542 521 байт

<svg><path fill=#0a8 d="M0 0h152v152H0z"/><path fill=#5ad d="M72 2h8v8h-8zm0 10h8v8h-8zm0 10h8v8h-8zm0 10h8v8h-8z"/><path fill=#057 d="M12 12h8v8h-8zm10 10h8v8h-8zm10 10h8v8h-8zm40 10h8v28h-8zm0 30h8v8h-8zm10-10h8v8h-8zm10-10h8v8h-8zm10-10h8v8h-8zM82 72h68v8H82zM72 82h8v58h-8zm0 60h8v8h-8zm40-30h8v8h-8zm10 10h8v8h-8zm10 10h8v8h-8z"/><path fill=#f33 d="M62 72h8v8h-8zm60-10h8v8h-8zm10 0h8v8h-8zm10 0h8v8h-8z"/><path fill=#a6b d="M2 82h8v8H2zm10 0h8v8h-8zm10 0h8v8h-8zm10 0h8v8h-8zm10 0h8v8h-8zm10 0h8v8h-8zm10 0h8v8h-8z"


1

HTML, 366 байт

Воскресенье получил ответ Base64 , пока я еще работал над этим; если он / она решит использовать его, я удалю этот ответ.

<img src=

Если строка Base64 сама по себе является правильным ответом, то это всего лишь 335 байтов:

iVBORw0KGgoAAAANSUhEUgAAAJgAAACYBAMAAADq7D0SAAAAD1BMVEUAqI4ATXWobLlaptj3OjrqGXAuAAAAp0lEQVRo3u3YQQqFMAxFUbeQLbiFbsH9r8k3y8CmTiKm7b2Dwv/CgUAD4jF3TYGBRdgKmRqPCQa28gaMZ20KDGz5DQhnbQoMTG2wAcPR/ScY2HeYVw4zBQYWYDUvbRLWFS/lBxhYhM3bpXzMcWBgEVa5U70cpsDAnkf1FxcwMDAwMLBczP8DAwuwmpc2HzMFBhY8qHlp8zFTYGCdyn8GKrhOYBtjv3QDvf+Zic+8bOsAAAAASUVORK5CYII

1

HTML / SVG + JavaScript (ES6), 500 499 байт

Для >того, чтобы это функционировало как сниппет, требуется дополнительное , см. Эту скрипту для реального кода.

[[t="5ad",2],[t,o=12],[t,p=22],[t,q=32],[,o,o],[,p,p],[,q,q],[,42,,28],[],[,v=62,s=82],[,52,92],[,42,102],[,,s,,68],[,s,,58],[,142],[,112,112],[,122,122],[,132,132],[t="f33",,v],[t,v,122],[t,v,132],[t,v,142],[t="a6b",s,2],[t,s,o],[t,s,p],[t,s,q],[t,s,42],[t,s,52],[t,s,v],["0a8",0,0,152,152]].map(x=>a(x[0],x[1],x[2],x[3],x[4]),a=(f="057",y=72,x=72,h=8,w=8)=>(c.after(r=c.cloneNode()),r.id++,r[s="setAttribute"]("fill","#"+f),r[s]("x",x),r[s]("y",y),r[s]("width",w),r[s]("height",h)))
<svg><rect id=c>


объяснение

Массив массивов сопоставляется с функцией a, создавая клоныrect в HTML, вставляя их после первоначального rectи установки их fill, x, y, width& heightатрибуты. Каждый массив содержит значения для этих атрибутов в указанном порядке, причем все пропущенные значения устанавливаются параметрами по умолчанию a. Казалось бы, ненужный r.id++позволяет использовать cloneNode(), гарантируя, что есть только 1 rectс idc; это избавляет от необходимости использовать смехотворно дорого document.createElementNS("http://www.w3.org/2000/svg","rect").


1

PHP + SVG, 425 байт

<svg><rect x=0 y=0 fill=#00a88e width=150 height=150 /><?foreach(["004d75"=>[[1,1],[2,2],[3,3],[7,14],[7,7],[8,6],[9,5],[10,4],[11,11],[12,12],[13,13],[7,4,0,2],[8,7,6,0],[7,8,0,5]],"5aa6d8"=>[[7,0],[7,1],[7,2],[7,3]],a86cb9=>[[0,8],[1,8],[2,8],[3,8],[4,8],[5,8],[6,8]],f73a3a=>[[6,7],[12,6],[13,6],[14,6]]]as$c=>$p)foreach($p as$v)echo"<rect x={$v[0]}1 y={$v[1]}1 width=".(8+10*$v[2])." height=".(8+10*$v[3])." fill=#$c />";

расширенный

<svg><rect x=0 y=0 fill=#00a88e width=150 height=150 />
<?foreach([
"004d75"=>[[1,1],[2,2],[3,3],[7,14],[7,7],[8,6],[9,5],[10,4],[11,11],[12,12],[13,13],[7,4,0,2],[8,7,6,0],[7,8,0,5]]
,"5aa6d8"=>[[7,0],[7,1],[7,2],[7,3]]
,a86cb9=>[[0,8],[1,8],[2,8],[3,8],[4,8],[5,8],[6,8]]
,f73a3a=>[[6,7],[12,6],[13,6],[14,6]] # Array containing color and position ,width, height of each rect without the background
]as$c=>$p)
  foreach($p as$v)
    echo"<rect x={$v[0]}1 y={$v[1]}1 width=".(8+10*$v[2])." height=".(8+10*$v[3])." fill=#$c />"; # Output the rects

Результат кода в фрагменте HTML

<svg><rect x=0 y=0 fill=#00a88e width=150 height=150 /><rect x=11 y=11 width=8 height=8 fill=#004d75 /><rect x=21 y=21 width=8 height=8 fill=#004d75 /><rect x=31 y=31 width=8 height=8 fill=#004d75 /><rect x=71 y=141 width=8 height=8 fill=#004d75 /><rect x=71 y=71 width=8 height=8 fill=#004d75 /><rect x=81 y=61 width=8 height=8 fill=#004d75 /><rect x=91 y=51 width=8 height=8 fill=#004d75 /><rect x=101 y=41 width=8 height=8 fill=#004d75 /><rect x=111 y=111 width=8 height=8 fill=#004d75 /><rect x=121 y=121 width=8 height=8 fill=#004d75 /><rect x=131 y=131 width=8 height=8 fill=#004d75 /><rect x=71 y=41 width=8 height=28 fill=#004d75 /><rect x=81 y=71 width=68 height=8 fill=#004d75 /><rect x=71 y=81 width=8 height=58 fill=#004d75 /><rect x=71 y=01 width=8 height=8 fill=#5aa6d8 /><rect x=71 y=11 width=8 height=8 fill=#5aa6d8 /><rect x=71 y=21 width=8 height=8 fill=#5aa6d8 /><rect x=71 y=31 width=8 height=8 fill=#5aa6d8 /><rect x=01 y=81 width=8 height=8 fill=#a86cb9 /><rect x=11 y=81 width=8 height=8 fill=#a86cb9 /><rect x=21 y=81 width=8 height=8 fill=#a86cb9 /><rect x=31 y=81 width=8 height=8 fill=#a86cb9 /><rect x=41 y=81 width=8 height=8 fill=#a86cb9 /><rect x=51 y=81 width=8 height=8 fill=#a86cb9 /><rect x=61 y=81 width=8 height=8 fill=#a86cb9 /><rect x=61 y=71 width=8 height=8 fill=#f73a3a /><rect x=121 y=61 width=8 height=8 fill=#f73a3a /><rect x=131 y=61 width=8 height=8 fill=#f73a3a /><rect x=141 y=61 width=8 height=8 fill=#f73a3a />

PHP + SVG, 375 байт

Это число байтов может быть достигнуто с помощью сжатия SVG

<?=bzdecompress(base64_decode("QlpoNDFBWSZTWY2177gAASSZgEgA/+c/5B3gMAE5TQVtQeig0AAACU0VNMAAAEYIlEnpMKNlGahso2plh0zoaSEpIkukINaC3RWRF74IvArdRF1FcBXrSTFWXTorp2xvpb3k7FbaV62syISgiBEweHhxtWUmgWCsqqaKSEARyAOAEZJJOwYBQqTAWotSrmEXJbBRTYNhCg4RPaKOUUbAX+Fr4VfIrzzIQQkkJCWfMEEOOISTuDkOzgQzDQDNQKu/4K7AZh8L41DddV8iv2LQOBXv+iugriHAr6sK/IrUV1FeRXMV3FdhW8V9KugrmK8CvOQin+LuSKcKEhG2vfcA"));
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.