Rate css на что влияет
Rate css на что влияет
Многие люди часто спрашивают что такое рейты, какие значения использовать и т.п Я думаю написание руководства, объясняющего что все это значит, поможет многим людям. Чтобы потом люди не говорили какие значения использовать, не понимая что они означают на самом деле.
Начнем с определений:
Я предполагаю, что большенство людей использует ADSL или кабель и здесь я буду рассматривать ADSL в качестве примера и исходя из этого я предполагаю, что скорость входящего потока у всех 512кб\с и скорость исходящего 256кб\с, но вы можете сделать все приведенные здесь расчеты и для кабеля, и для соединений на более низких скоростях (просто необходимо вычислить разницу). Теперь выставляйте значения rate, cl_updaterate и cl_cmdrate чем выше тем лучше, потому что это позволяет вам играть в более быструю игру и что более важно это позволяет вашим пулям попадать в противника с большей вероятностью. Сейчас я объясню вам почему.
Рейт
В теории соединение ADSL должно с легкостью поддерживать рейт в 30000. Это проверяется следующим образом:
берем значение рейта, которое измеряется в байтах в секунду и переводим его в килобайты в секунду.
30000 /1024 = 29,296875кБ/с
В теории ваше соединение работает на скорости 512 килобит в секунду (в реальности оно работает на более низкой скорости). Я перевожу это значение в килобайты в секунду: 512 / 8 = 64кБ/с
Теперь вы можете видеть что через ваше соединение могут играть 2 человека с рейтом в 30000 (64 / 29.3 = 2.18). Можно использовать такое же вычисление для cl_rate, но этого делать не стоит, значения по умолчанию 9999 более чем достаточно.
cl_updaterate
Далее вы хотите изменить значения команд cl_updaterate и cl_cmdrate. updaterate определяет как много обновлений в секунду вы можете получить от сервера. Ясно что нужно получать как можно больше обновлений, так как это дает вам более точную картину того где кто находится и куда летят их пули. Однако, если у вас будет высокий updaterate и низкий rate вы не сможете послать достаточное количество данных за обновление и любая выгода от высокого updaterate будет сведена к минимуму. Для того чтобы стало понятно, я сейчас все объясню.
Если я ставлю cl_updaterate в 100 и мой рейт равен 30000 в теории каждое обновление может содержать до 300байт данных (30000 / 100 = 300). Повторюсь, чем больше данных вы сможете получить за обновление, тем более четко вы будете видеть игровой мир (это не означает что игровой мир будет более четким, а означает то, что ваши пули будут более четко попадать в цель). Было вычислено, что когда у вас на экране происходит много действий, вы можете использовать 250байт на обновление. Таким образом если у вас высокий updaterate, вам нужен соответствующий ему высокий рейт.
Используя данные если у вас updaterate равен 100, ваш рейт должен быть равен по крайней мере 25000, но лучше иметь небольшой запас. Я рекомендую значение 30000 как минимум (чтобы определить какое значение выбрать для вашего рейта возьмите ваш cl_updaterate и умножьте его на 250, а затем прибавьте к полученному значению еще хотя бы 5000 для страховки).
cl_cmdrate
cl_cmdrate работает так же как и cl_updaterate. Эта команда определяет сколько обновлений в секунду вы посылаете на сервер. И снова ее значение нужно ставить как можно выше. Чем больше обновлений вы пошлете на сервер, тем больше информации он будет иметь о ваших действиях и о том куда летят ваши пули. На мой взгляд эта команда более важная чем cl_updaterate.
Как и с cl_updaterate и с rate вы можете вычислить максимальное количество данных которое может содержать каждое обновление. Отсюда, если у вас cl_cmdrate равен 100 и ваш cl_rate равен 9999, каждое обновление может содержать 99.99байт данных (9999 / 100 = 99.99). Этого должно хватить для ваших нужд, так как вы посылаете меньше данных на сервер, чем он посылает вам.
Помехи (choke) и потеря (loss)
Теперь мы будем смотреть на помехи и потерю. Помехи (choke) показывают вам число обновлений которые не были посланы в оба направления из за перегрузки соединения. Потеря (loss) показывает число обновлений которые были посланы, но не достигли другой стороны. Помехи более важны чем потери, потому что ими вы засоряете соединение и оно не справляется со всеми этими данными. Это означает что вам нужно понизить значения рейтов. Потеря не так важна и если у вас большая потеря это говорит о том что у вас с сервером плохое соединение. Появление как помех (choke) так и потери (loss) является следствием того, что значения рейтов которые вы используете, либо слишком низкие, либо слишком высокие.
Я рекомендую попробовать использовать эти значения:
rate 35000
cl_updaterate 100
cl_cmdrate 100
!Параметр cl_cmdrate должен быть равен параметру cl_updaterate
Если эти значения приводят к помехам или потерям, пробуйте понижать значения. Я бы попробовал так:
rate 30000
cl_updaterate 66
cl_cmdrate 66
!Параметр cl_cmdrate должен быть равен параметру cl_updaterate
Тем кто подключен к ADSL я бы рекомендовал использовать эти значения:
rate 30000 или rate 25000
cl_updaterate 100 или cl_updaterate 66
cl_cmdrate 100 или cl_cmdrate 66
!Параметр cl_cmdrate должен быть равен параметру cl_updaterate
Тем кто подключён к дргим провайдерам, то я бы рекомендовал использовать эти значения:
rate 25000 или rate 10000
cl_updaterate 66 или cl_updaterate 33
cl_cmdrate 66 или cl_cmdrate 33
!Параметр cl_cmdrate должен быть равен параметру cl_updaterate
Вы можете проверить помехи и потери при помощи команды net_graph 3. Все сервера отличаются друг от друга и если вы сильно беспокоитесь на счет помех и потерь включите net_graph и подстройте ваши рейты, если не один из выше перечисленных вам не подошел.
Найдите соединение которое наиболее близко к вашему и попытайтесь применить к нему одни из приведенных ниже рейтов.
Помехи (сhoke) случаются когда сервер собирается послать данные клиенту, но не может потому что клиент еще не готов принять эти данные (основывается это на настройках клиентского рейта (rate) или серверовского sv_maxrate). Некоторые вещи, такие как клиентский рейт слишком низкий для данного числа игроков на сервере, само собой приводят к потере. Другие вещи не всегда, но тоже могут привести к потере, такие как когда клиент поднимает значение cl_updaterate слишком высоко.
Рекомендуемые настройки рейтов на сервере CS:GO
Содержание
Основные понятия
TickRate
Что такое тикрейт?
При каждом тике, сервер обрабатывает информацию игроков, физические передвижения, обновления состояния объектов и так далее. После моделирования тика сервер решает, нуждается ли какой-либо игрок в обновлении игрового состояния, и при необходимости получает снимок текущего состояния. Более высокий тикрейт повышает точность моделирования, но также требует большей мощности процессора и доступной пропускной способности как на сервере, так и на клиенте. Соответственно, чем выше тикрейт, (а максимальный тикрейт в CS:GO это 128) тем чаще сервер обрабатывает информацию и тем лучше сказывается на игровом процессе, в том числе и стрельбе. Максимальной тикрейт в CS:GO это 128, но так как он требуемый к ресурсами, наиболее распространенный 64 тикрейт, который в частности используется на серверах матчмейкинга.
Зачем нужен высокий тикрейт?
Наверняка Вы встречались с такой ситуацией на матчмейкинге или на другом сервере с tickrate 64, когда Вы стреляете в противника, видите попадания, следы крови, но при этом сервер не засчитывает урон, причина в том, что ваша игра отправляет данные на сервер для обработки, но сервер сопоставив их с данными других игроков не засчитывает попадания. Кровь Вы видите лишь потому что, за отображение крови и попаданий отвечает игра, но не сервер. Вы видите, что попали в цель, игра отображает кровь, посылает информацию на сервер для проверки. Если сервер считает, что вы промахнулись, урон противнику не засчитывается. Высокий TickRate позволяет избежать таких ситуаций и как правило более корректно обрабатывает все данные.
Как изменить тикрейт на сервере MyArena.ru
Тариф с оплатой за слоты
Вы выбираете тикрейт ещё в момент покупки, но если Вы захотите сменить тикрейт, то это можно сделать лишь путем смены тарифа.
Тариф PRO
Сменить тикрейт Вы можете в панели управления, раздел «Настройки».
Что такое рейт (rate)?
0.5 Мбит/сек | rate 62500 | |
1.0 Мбит/сек | rate 125000 | |
1.5 Мбит/сек | rate 187500 | |
1.57 Мбит/сек | rate 196608 | (Стандартное значение) |
2.0 Мбит/сек | rate 250000 | |
2.5 Мбит/сек | rate 312500 | |
3.0 Мбит/сек | rate 375000 | |
3.5 Мбит/сек | rate 437500 | |
4.0 Мбит/сек | rate 500000 | |
4.5 Мбит/сек | rate 562500 | |
5.0 Мбит/сек | rate 625000 | |
5.5 Мбит/сек | rate 687500 | |
6.0 Мбит/сек | rate 750000 | |
6.2 Мбит/сек | rate 786432 | (Максимальное значение) |
Как выставлять рейт?
Необходимые Вам рейт на сервере выставляются с помощью двух переменных:
Прописывать эти переменные можете как в конфиге игрового режима, так и в server.cfg. Как правило, этих переменных нет по-умолчанию в стандартных конфигах, Вам необходимо их добавить вручную.
Какие значения sv_minrate и sv_maxrate рекомендуется выставить?
Не старайтесь ограничить игроков выставив sv_minrate выше стандартного значения, Вы никак не улучшите им игру, а некоторым игрокам можете лишь её усугубить, ведь не у всех качественный интернет и высокая скорость, по этому рекомендуемые значения не отличаются от стандартных.
CmdRate
Что такое CmdRate
Как выставить cmdrate на сервере
Вам необходимо ограничить игрокам минимальное допустимое значение cmdrate для комфортной игры в соответствии с тикрейтом вашего сервера. Предположим, что у Вас сервер на 128 тикрейте, следовательно необходимо в конфиг игрового режима или в server.cfg добавить переменную:
Помимо этой переменной существует ещё и sv_maxcmdrate, но необходимости её прописывать нет, так как она автоматически унаследует значение вашего тикрейта.
Какое значение sv_mincmdrate рекомендуется выставить?
Необходимо всегда выставлять значение переменной sv_mincmdrate равно значению тикрейта вашего сервера. То есть если сервер на 64 тикрейте, то прописывать нужно:
Если сервер на 128 тикрейте, то нужно:
UpdateRate
Что такое UpdateRate
Как выставить UpdateRate на сервере
Аналогично как и с CmdRate, необходимо ограничить игрокам минимальное значение для комфортной в соответсвии с тикрейтом. Следовательно необходимо в конфиг игрового режима или в server.cfg добавить переменную значением которой будет тикрейт сервера, к примеру у нас будет он 128:
Помимо этого есть переменная и sv_maxupdaterate, необходимость в которой отсутствует, так как она автоматически унаследует значение тикрейта сервера.
Какое рекомендуемое значение sv_minupdaterate нужно выставить?
Значение переменной должно быть равно тикрейту сервера. Если 64 тикрейт, то:
Если же 128 тикрейт, следовательно:
Рекомендуемые рейты
Данные переменные необходимо поместить в конфиг игрового режима или в server.cfg
Рейты для сервера с 64 тикрейтом
Рейты для сервера с 128 тикрейтом
Диагностика проблем и их решение
Слишком большой choke на сервере
Зайдите в игру, присоединитесь к своему серверу, откройте консоль игры и введите net_graph 3. Данная опция позволит Вам смотреть показатели, которые помогут обнаружить наличие проблемы с рейтами. Самая распространенная проблема вызвана неправильными рейтами это choke (потеря пакентов), если значение превышает 10% постоянно у всех игроков без исключения, значит следует проверить рейты вашего сервера.
Даже если Вы в server.cfg прописали правильные рейты, Вы не можете быть уверенны, что какой-то мод или плагин не заменил их на свои, как правило бывает, что мод добавляет свои конфиги в которых прописаны устаревшие и неправильные рейты (зачастую бывает в WarMod). Или же когда Вы используете какую-то устаревшую сборку сервера с своими конфигами. Для просмотра текущих рейтов на сервере, нужно в консоли сервера поочередно ввести переменные без значений:
В результате Вам отобразятся значения данных переменных которые на сервере в текущий момент, если они будут отличаться от тех, которые прописывали Вы, значит в каком-то конфигурационном файле указанные другие рейты.
Rate css на что влияет
В процессе игры все происходящее нам кажется непрерывным, но на самом деле это не так. Сервер Counter-Strike Source способен обрабатывать события игрового мира с частотой шестьдесят шесть раз за одну секунду (tickrate 66). Это значение установлено по умолчанию и встроенных возможностей для его изменений не предусмотрено. Исходя из этого, понятно, что клиент не может отправлять и получать данные чаще, чем установленный tickrate.
По умолчанию клиент получает от сервера двадцать пакетов в секунду, каждое изменение в игре вы сможете наблюдать не раньше, чем придет очередной пакет, а значит с частотой двадцать раз за одну секунду. Очевидно, что этого не достаточно, особенно если учесть высокую динамику игры. Вы только представьте себе ситуацию, когда ваш противник стрейфует или резко выбегает из за угла. В таких игровых моментах нужна повышенная информативность от сервера. Частоту обновления данных можно изменить с помощью консольной переменной cl_updaterate. Как упоминалось ранее, скорость приема пакетов ограничена значением tickrate сервера. Значит, максимально возможное значение cl_updaterate составит шестьдесят шесть пакетов в секунду.
cl_updaterate 66
(Установив это значение рейтов, вы будете получать более точные и более информативные данные о происходящем в игре.)
Все сказанное относительно обновления информации от сервера относится и к передаче данных от клиента. Ведь когда вы нажимаете на клавишу клавиатуры или мыши необходимо проинформировать об этом сервер как можно быстрее. Частота отправки пакетов от клиента к серверу настраивается при помощи консольной переменной cl_cmdrate (по умолчанию тридцать пакетов в секунду). Максимальное значение cl_cmdrate не может быть выше, чем tickrate сервера.
cl_cmdrate 66
(С таким параметром рейтов сервер будет максимально быстро получать сведения о ваших действиях.)
Все игроки Counter-strike Source обладают разным подключением к сети интернет. Во избежание потери пакетов подход к настройке клиента должен быть индивидуален для каждого. При помощи консольной переменной rate можно установить максимальное значение данных, которые вы можете принимать, т.е. установить максимальный входящий трафик вашего подключения. В этом случае сервер будет знать о вашей входящей пропускной способности и никогда не пошлет обновлений больше чем установленный rate. По умолчанию значение rate составляет 30000 байт в секунду. Рассчитать правильный rate очень просто, достаточно перевести ваш входящий трафик в байты. Например, мое подключение к интернету 15 Мбит/с (15*2 20 / 8 = 1966080 байт). Ставить такое высокое значение лишено всякого смысла. Поэтому лично я ограничиваюсь rate 262144 (2 Мбит/с)
Почему разработчиками Valve изначально установлены такие низкие значения rate, cl_updaterate и cl_cmdrate. Скорее всего, это исходило из расчета на среднестатистического пользователя с медленным модемным соединением. Но по моему нескромному мнению это могло иметь место еще несколько лет назад, когда ни кто не имел представление что такое доступ в мегабит(ы). В соревновательных режимах применяются максимально возможные рейты.
интерполяция и lerp
Как нетрудно догадаться, чем больше клиент будет получать пакетов от сервера, тем меньше интерполяция будет отдавать нам «фальшивых» снимков. Значит при максимально возможном обновлении (cl_updaterate 66), игрок будет получать более точную и честную информацию.
Для настройки интерполяции в клиенте предусмотрено несколько консольных переменных: cl_interp_ratio, cl_interp. Переменная cl_interp_ratio задает число интервалов, через которые будет происходить интерполяция (по умолчанию 2 интервала). Клиент будет ждать до тех пор, пока не придут два пакета, и только потом будут рассчитываться промежуточные значения. В случае потери одного из пакетов расчет будет вестись на основе второго. Установка cl_interp_ratio 1 (один интервал) заставит клиент ждать только один пакет, что сведет задержку интерполяции (lerp) к минимуму.
Переменная cl_interp устанавливает величину интерполяции. Рассчитать cl_interp очень просто:
cl_interp=cl_interp_ratio / cl_updaterate
(можно установить cl_interp 0, тогда его значение будет рассчитано автоматически.)
лагокомпенсация
Лагокомпенсация на сервере сводит к минимуму влияние задержек (пинга) клиент-сервер, а также задержек интерполяции. Представьте себе, что вы играете на сервере, который географически находится далеко от вас и вдобавок у всех игроков разные задержки. Вы делате точный выстрел в бегущего противника. За время прошедшее от нажатия вами на клавишу мыши и доставкой пакета на сервер ваша цель уже давно скрылась за угол, но попадание все равно засчитывается. Это происходит благодаря лагокомпенсации на стороне сервера. Все дело в том, что сервер запоминает позиции всех игроков, делая снимки игрового мира, и при обработке вашего выстрела находит нужный снимок по формуле:
Лагокомпенсация дает возможность игрокам с разными задержками играть практически на равных, но с ростом и нестабильностью пинга эффективность лагокомпенсации падает.
предсказание (prediction)
Надеюсь эта статья помогла вам разобраться с вопросами, касающимися настройки рейтов в Counter-Strike: Source.
Rate css на что влияет
Для начала настройки, давайте разберёмся, что означает слово «Рейты»?
Рейты CSS – это количество информации (байт), которые сервер может отправить клиенту, т. е. игроку. Здесь прослеживается прямая зависимость от скорости интернета игрока, поскольку от этого зависит, какое количество информации сможет принять канал.
Итак, настройка рейтов CSS требует знания трех основных команд:
rate — определяет максимальное количество передаваемых байт в секунду.
cl_cmdrate — определяет количество действий, которые будут отправлены клиентом на сервер.
cl_updaterate — определяет количество действий, которые будут отправлены сервером клиенту.
Набор настроек для медленного интернета (модемное соединение, общественные беспроводные сети и прочее):
А вот набор для высокоскоростного соединения (домашний кабельный интернет и похожее):
Rate css на что влияет
В Counter Strike: Source одна из, пожалуй, самых главных и страшных проблем – лаги. Иногда игроки, не разобравшись, жалуются мол «сервер фуфло, лагает жутко ну его в топку», когда на самом деле проблема на стороне клиента. Эта незамысловатая статья поможет разобраться начинающим геймерам в классификации «лагов», а также растолкует значеие слов rate, ping, choke и т.д. Статья будет полезна, как и тем, у кого лаги есть (дабы уменьшить, а то и вовсе избавиться от них), так и тем, у кого их нету (для общего развития, на будущее так сказать).
1. Основная терминология:
2. Net_graph 3 и его значение в Counter Strike: Source
2.1 Нажимаем на значек
(в быту называемой тильда)
2.2 Вводим команду «net_graph 3» (без кавычек) и нажимаем Enter (чтобы вернуть все обратно пишем в консоль net_graph 0). После ввода команды net_graph 3 у вас в правом нижнем углу CS:S должна появиться примерно следующая картина:
Обозначим все по порядку:
1) FPS – frame per second, что в переводе означает «количество кадров в секунду». Чем выше FPS, тем лучше и приятнее игра. Профессиональные геймеры держат значение FPS не меньше 40-50. Справка: человеческий глаз воспринимает 24 кадра в секунду, из этого следует, что для обеспечения комфортной игры достаточно держать значение FPS большим или равным 24.
2) Ping – см. выше.
3) in/out – значение того сколько вы получаете и посылается tcp/ip пакетов.
4) k/s per second – сколько вы посылаете или получается килобит в секунду (не очень важное для нас значение).
5) Out (нижняя часть) – значение, показывающие сколько раз ваш компьютер обновляет позицию игрока на сервере (в секунду).
In (верхняя часть) – значение, показывающие сколько раз сервер посылает позицию игрока т.е. вас (в секунду).
6) Loss – см. выше.
7) Choke – см. выше.
3. Собственно мы пришли к главному: методу борьбы с лагами в CS:S
Следующее шаги, я думаю, будут понятны всем, и даже тем, кто полный ламер и ничего не смыслит.
Эти незамысловатые методы помогут вам избавиться от лагов в «контре».
3.1 Надо понимать, что на каждом сервере тикрейт разный и что для каждого сервера нужны свои значения (обычно стоят программы по типу Force Rate которые устанавливают правильный тикрейт для определенного сервера и делают это без участия игрока).
3.2 Если рейты нужно проставить вручную то делается это при помощи команд, которые прописываются в консоли, команды следующие:
Если тикрейт 33 пишем следующее:
Rate 15000
Cl_cmdrate 33
Cl_updaterate 33
Если тик рейт 66 то следующее:
Rate 20000
Cl_cmdrate 66
Cl_updaterate 66
Если тикрейт 100, то пишем вот это:
Rate 30000
Cl_cmdrate 100
Cl_updaterate 10
3.3 А теперь расшифруем значение cmdrate, updaterate и rate:
cl_updaterate – значение, показывающие сколько раз посылается на сервер запрос о позициях противника (значение в секундах, по умолчанию 20).
cl_cmdrate – значение, показывающие сколько раз компьютером посылаются пакеты с позициями игроков на сервере (в секунду, по умолчанию 20).
rate – количество байтов, которое вы можете получить
4. Теперь поговорим о cmdrate и updaterate.
4.1 Зайдите на сервер где вы играете, и поменяйте значения cmdrate и updaterate на следующие: cl_cmdrate 80 и cl_updaterate 60.
4.2 Поиграйте немного и вы должны увидеть, что значения in и out (пункт 5 картинки с изображением net_graph’а) не изменяются, а остаются прежними.
4.3 Если их значения все время 33.3 или 66.6, то это значит, что нужно изменить значение cmdrate и updaterate на следующее: cl_cmdrate 66 и cl_updaterate 45.
4.4 Поиграйте чуть чуть и проследите за значениями loss и choke.
Если проблемы с choke, вы просто должны поставить значение рейтов на более низкое.
4.5 Старайтесь придерживаться соотношения в рейтах 3 к 4:
Updaterate должен составлять три четвертых от cmdrate. Это не обязательно, но желательно.
Для примера: если у вас значение choke равно 5, то следовательно рейты следует опустить на 5 значений, до cl_updaterate 35 и cl_cmdrate 50.
Примите во внимание, что при играх на паблике вполне нормальным считается значение choke 5 в примерно середине раунда, когда самое мясо начинается. А в конце раунда или в начале норма choke это 10-20 (это из-за того что в начале и конце раунда сервер обновляет объекты).
Attention!
Как правильно на DeathMatch серверах (игроки «воскрешаются» через некоторое время) значение choke варьируется примерно от 10 из-за обильной нагрузки на сервер, эти настройки помогут смягчить значение choke, но не убрать его.
5. Устанавливаем рейты:
Рейты, как уже говорилось выше, максимальное значение, которое может принять клиент (в байтах)
Обычно устанавливают примерно следующие значения: