Günlük: CK2 - Modlama ve Optimizasyon
#1
diaryck2.png

Crusader Kings II geliştirici günlüklerinde bu hafta Meneth modlama alanında yapılan geliştirmelerden bahsediyor.

https://forum.paradoxplaza.com/forum/ind...n.1035735/ :Merhabalar, ben Magne "Meneth" Skjæran, CK2'de programcı olarak çalışıyorum. Geçmişte modlama, optimizasyon, arayüz geliştirmeleri gibi konularda çeşitli geliştirici günlükleri yazdım. Aynı zamanda geçen hafta, bir hatanın keşfedilme, rapor edilme ve çözülme sürecini anlatan ve ondan önceki hafta CK2 ekibini ve ekip üyelerinin sorumluluklarını özetleyen günlüğü de ben kaleme aldım.

Yaz halen devam ediyor dolayısıyla ofisin büyük bir kısmı Temmuz sonuna kadar tatilde. Bu esnada günlük yayınlamaya devam edelim dedik ve bu 4 hafta içerisinde geliştirici günlüklerini yazma işi bana düştü.

Ekibin büyük bir kısmının tatilde olması, oyunun geliştirilmesi namına çok az ilerleme katedildiği anlamına geliyor. Bu da bu tatil süresi boyunca yayınlanan 4 günlüğün oyun içeriği bakımından az şey barındıracağının bir habercisi. Umuyorum ki bu 4 günlük esnasında sizler için ilgi çekici bazı şeyler paylaşabilirim.

Bugün sizlere 2.8 yamasıyla birlikte modlama alanında yaptığımız bazı geliştirmelerden sözedeceğim. Ben de eskiden modlamayla uğraşıyordum ve bu sebepten bu benim konuşmayı en sevdiğim alanlardan bir tanesi. CK2 üzerinde çalışmam esnasında özellikle modlama alanında çok sayıda özellik eklemeyi başardım.

Yazının sonuna doğru aynı zamanda optimizasyon geliştirmelerimnden de bahsedeceğim. Bunun yanı sıra 2.8 yamasından seçmece 5 maddeyi okuyabilirsiniz.

Bağlılığımız
Daha önceki Modlar ve Telemetri günlüğünde de bahsettiğimiz üzere CK2 modlarına ve modcularına büyük önem veriyoruz. Bu modlar oyunun dizaynında alternatif senaryoları gerçeğe dönüştürerek oyunun oynanabilirlik seviyesini yükseltiyor. Benim bunları yazışım esnasında edindiğim veriye göre dün CK2 oynayan kişilerin %48'i oyununu en az bir modla oynadı, daha önce bu konuda yazdığımız günlükte bu oran %42'ydi.

Bunun yanı sıra Paradox'ta çalışan kişilerin büyük bir kısmının eski modcular olduğunu unutmayalım. Modcuların yaptığı birçok iş tasarımcılarımızın işini de kolaylaştırıyor ve yeni olasılıkları açığa çıkartıyor. Bu gibi sebeplerden dolayı oyunun modlanabilirliğini arttırmak uzun bir süredir istediğimiz bir şeydi ve 2.8'de de bu konuda ilerlemeler katettik.

Öne Çıkanlar
Oyunun modlanabilirliğinde yapılan değişiklikler çok fazla, bu sebeple sizlere bazı öne çıkan hususlardan bahsetmek isterim. (Yazının buradan sonrası modcuların aşina olduğu çok sayıda terim içeriyor)
  • Sayıyla çalışan çok sayıda efekt ve trigger artık varyasyon ismiyle de çalışabiliyor ve bu varyasyonu mevcut scope'dan okuyabiliyor yani wealth=test_variable.
  • Daha önceden sadece geliştiriciler ve beta kullanıcıları tarafından kullanılabilen bazı komutlar artık herkes tarafından kullanılabiliyor: guibounds, noai, join_society, leave_society, society_rank_up/down, society_currency, set_society_grandmaster, get_all_artifacts, activate_artifacts
  • Hedefli decisionlar artık 3. bir karakteri veya artifactı destekliyor.
  • Artık varyasyonları event hedefleriyle aynı şekilde yazabiliyorsunuz, local_ ile başlayan varyasyonlar bu şekilde çalışıyor.
  • Steam'e yüklenen modların boyut sınırı kaldırıldı, eskiden 50MB'den yüksek boyuta sahip modlar yüklenemiyordu.
  • Efektler ve triggerlar artık tercihe bağlı show_scope_change parametresine sahip, eğer bunu 'no' olarak şiaretlerseniz bu değişiklik tooltipte görünmüyor. 
  • conditional_tooltip eklendi, bu kod trigger scriptinin ne zaman görüntüleneceğini etkiliyor.
  • Artık tüm tooltipler custom yerelleştirmeleri destekliyor.
  • Birkaç istisna dışında triggerlar karşılaştırma sembollerini (>=, <=, <, > ve ==) destekliyor.
  • else_if ve else için destek eklendi. 
  • fail_trigger_effect eventi eklendi. Bu durum örneğin bir event zinciri içinde olan karakterin zinciri tamamlamadan ölmesi gibi durumlarda devreye giriyor.
Optimizasyon
Modlamada yaptığımız değişikliklerin yanı sıra, optimizasyondan da bahsedelim.

Bu optimizasyon çalışmaları sonrasındaki hız değişiminin 2.6'daki optimizasyon çalışmalarının yakınından bile geçmesi mümkün olmasa da, birkaç günümüzü oyunu hızlandırmak için çalışmaya ayırdık. Bu hızlandırmanın amacı oyuna eklenecek yeni Tibet bölgesinin oyunun hızına olan etkisini azaltmaya yönelikti, ancak 2.7.1'deki hıza ulaştıktan sonra durmadık ve çalışmaya devam ettik.

Genel olarak testlerime baktığımda oyunun 2.7.1'deki halinden %8 daha hızlı olduğunu görüyorum, ancak bu değer bilgisayardan bilgisayara değişiklik gösterebilir.

Aşağıda yaptığımız bazı geliştirmeleri okuyabilirsiniz:
  • HoI4 günlüğünde 6 ay önce bahsedilen GUI optimizasyonu CK2'ye aktarıldı.
  • Daha farklı GUI optimizasyonları yapıldı.
  • Bölge ve karakter modifierlarında bazı gereksiz güncellemelerden kaçınıldı.
  • Courtier'lar artık daha uzun aralıklarla kontrol ediliyor.
  • Bazı kullanılmayan varyasyonlar kaldırıldı.
  • AI artık çok sayıda decisionu geçirip geçirmeyeceğini daha uzun aralıklarla kontrol ediyor.
  • Gereksiz karakter oluşturulmasında azaltmalar.
  • Kod değişiklikleri.
Tüm bunlar oyunun hızının az, ancak farkedilebilir bir şekilde hızlanmasıyla sonuçlanacaktır.

Özet
Modlama ve optimizasyon hususlarına CK2 ekibi olarak büyük önem gösteriyoruz ve 2.8'de bunların üzerindebazı çalışmalar yaptık.

Aşağıda 2.8 yama notlarındaki modlanabilirlikle ilgili kısımları okuyabilirsiniz. Ancak henüz duyurmadığımız bazı yeni özelliklere atıfta bulunan maddeleri bu listeden kaldırdık, aynı zamanda bu liste 2.8'deki modlanabilirlikle alakalı değişikliklerin final listesi değil, çıkış öncesi bu hususta daha fazla çalışma yapacağız.

Kod:
- Split the defines CONTESTED_TITLE_OCCUPIED_WARSCORE_BONUS and CONTESTED_TITLE_OCCUPIED_WARSCORE_BONUS_INDEP into attacker and defender version
- Split the 'ticking_war_score_multiplier' in Casus Belli scripts into 'att_ticking_war_score_multiplier' and 'def_ticking_war_score_multiplier'
- Added a new define for the effect of Fort Level on defender morale in sieges: FORT_LEVEL_MORALE_LOSS_REDUCTION_MULT
- Fixed a number of scopes not getting localised as effects, only as triggers
- error.log will now usually tell you if you've saved a map file in the wrong format
- The game will now crash slightly earlier if the province map is the wrong size (not a multiple of 64), making the issue easier to identify
- Cultures can now have "dynasty_name_first = yes" which puts the dynasty name before the personal name
- Added a "holding_types" folder in common. This can be used to define additional triggers for building each holding type
- The scaled_wealth trigger now supports "min" and "max" just like the scaled_wealth effect
- Fixed "effect" in history not being seeded, meaning that all effects with a random component would always produce the exact same result. Now the result will be properly randomized
- Build cost and build time modifiers now apply to forts, trade posts, and hospitals too. Note that there are still no type-specific modifiers for these three holdings
- on_heresy_takeover no longer creates a dummy character for the religion scope, but instead uses an actual religion scope
- "Religion" in loc while already in a religion will just return the same religion, to ensure that any loc written based on some on-actions using characters as makeshift religion scopes continue to work. The same has been done for "Culture" in culture scopes
- Most effects and triggers that take a number can now take a variable name instead, and will grab the variable from the current scope. E.G., "wealth = test_variable"
- gain_effect now fires in all cases (except history and death) for job titles and minor titles, including when added through script
- lose_effect or retire_effect now fires in all cases (except history and death) for job titles and minor titles. Being given a new job title will fire retire_effect on the old title, and gain_effect on the new title
- Fixed resigning as a commander firing lose_effect rather than retire_effect
- Added death_effect for job titles and minor titles, which fires when a character dies while holding the job/minor title
- Made the following console commands that before were only available to devs and beta testers available to everyone: guibounds, noai, join_society, leave_society, society_rank_up/down, society_currency, set_society_grandmaster, get_all_artifacts, activate_artifacts
- Added the console command "province_religion" or ("prov_rel") to change the religion of a province. Syntax is: "province_religion <province> <religion>"
- Targeted decisions now support having a 3rd party character or artifact
- Now possible to store variables in the same manner as event targets; any variable starting with "local_" will work this way, meaning it'll persist as long as the event chain does, but not be accessible outside it
- Uploading mods to Steam is no longer limited to 50MB
- Added the following targeted decision filters: court_including_me, home_court_including_me, dynasty_including_me, all_including_me, society_including_me, realm_including_me, sub_realm_including_me
- The regular versions of the above now consistently exclude the character themselves; in some cases before this restriction only applied if the AI was taking the decision
- Added max_defender_occupation_score and max_attacker_occupation_score modifiers for casus belli types
- Added documentation for the "aggression" parameter for governments
- Added a become_secret_heretic effect
- Added TRADE_ROUTE_SIEGE_MULTIPLIER and TRADE_ROUTE_OCCUPATION_MULTIPLIER defines
- Made the tributary system moddable and modular. You can now add new tributary types defining:
   - when and if the tributary relation breaks
   - what CBs the tributaries can use against their suzerain
   - The allowed_to_target_suzerains CB parameter no longer has any effect, as the above replaces it
   - if tributaries can unite together against their suzerain
   - if tributaries can fight against each other
   - if the suzerain can call their tributaries to arms, and if the tributaries are forced to join
   - if the tributaries can call their suzerain to their defense, and if the suzerain is forced to join
   - how much of what is paid by the tributary to the suzerain
   - What icon to use for the diplomatic relation
   - What modifiers to give the tributary
- You can now use the is_tributary trigger to check for a specific type, and a specific suzerain
- You can now use custom loc in the is_tributary trigger
- The set_tribute_suzerain now takes a "type" parameter, specifying the type. If none is specified, "default" is used
- Added set_trade_route_base_value and set_trade_route_value_multiplier effects
- Provinces with several trade routes will now show the presence and effect of all of them in their tooltip
- Effect and trigger scope changes now have an optional "show_scope_change" parameter. If set to "no", the scope change won't be shown in the tooltip. It'll be shown as just "effect description" rather than "scope change: effect description". This functionality isn't supported by any/random scopes.
- Added hostages_block_cb parameter for CBs
- Variables that haven't been set yet now work in localisation; they'll show "0" rather than simply being blank. "GetName" works as well. So [global_test.GetName] will return 0 for GetValue, and the "global_test" localisation for GetName
- Fixed the is_interested_in_society trigger not localising properly if negated, and not ending with a linebreak
- Added interested_in_society_of_character trigger
- Fixed empty "OR" triggers in some cases crashing the game on launch
- show_as_title = yes for minor titles now works even if the character has no titles
- Fixed a crash that could happen when a selectable object overlapped with an impassable province
- Fixed setting someone's employer on the same date that employer becomes landed not working properly
- Fixed capital changes in some cases failing if the county holder became holder on the same day as the capital change
- Added as_if_allied_to parameter for gain_settlements_under_title, vassalize_or_take_under_title, subjugate_or_take_under_title, and vassalize_or_take_under_title_destroy_duchies. This ensures that land occupied by people in that character's war against the title's holder can be taken
- Castes can now be enabled for individual religions rather than being hardcoded to the Indian group. This is done using the "castes" parameter
- Removed various hardcoding associated with the Hindu religion. This is now connected to the "caste_opinions" parameter instead
- The subjugation opinion is no longer applied when using vassalize_or_take_under_title, just subjugate_or_take_under_title
- Added event pretrigger for Game Book
- Decisions can now have a "_desc_extra" localisation key defined. This will be shown after the Requirements section in its tooltip
- Added "conditional_tooltip"; defines when a given piece of trigger script should be displayed. Its contents are only evaluated if it is displayed
- Added government parameters gets_religion_opinion_penalties, gives_religion_opinion_penalties, and vassal_government_opinion_penalties. See _governments.info for documentation
- Added title parameters can_be_claimed and can_be_usurped. See 00_landed_titles.info for documentation
- You can now use "extended" (bracket-based) localization in Artifact scopes:
   - [GetName] will display the name
   - [Owner] will rescope to the current owner of the artifact
   - [OriginalOwner] will rescope to the original owner of the artifact
- There is now an AI exclusion pretrigger in decision "ai = no" that can be used to avoid decisions being considered by the AI at all
- Removed the "coalition_threat" CB parameter as it had nothing to do with coalitions
- Fixed rulers in some cases being considered to have no primary holding on the day of their death when going backwards in history
- Added console commands "print_global_flags" (aka "pgf") and "print_global_variables" (aka "print_global_vars" and "pgv"). They print whatever they're named after
- "character_info" aliased to "debug_mode" since it is used by more than just character to display debug info
- Added "attrition" character modifier. This will reduce/increase the attrition suffered by the army they command. It is capped at -99%
- Added "army_reinforce_rate" character modifier. This will make the army the character commands reinforce faster. Affects retinues and horde units as well, not just levies. Does not affect the reinforcement of the settlement itself. Cannot go below 0
- Added "days_of_supply" character modifier. This modifies the number of days of supply of the army the character commands by an absolute number of days. Days of supply cannot go below 1
- Added command modifiers phase_skirmish_attack, phase_pursue_attack, phase_melee_attack, phase_skirmish_defense, phase_pursue_defense, and phase_melee_defense
- Added scopes any_neighbor_independent_ruler and random_neighbor_independent_ruler. A "neighbor independent ruler" is a ruler that neighbors the realm you're in (E.G., the HRE if you're a count in the HRE)
- Added "demesne_size_compared_to_limit" trigger. For example, "demesne_size_compared_to_limit < 0.5" will check if someone is below 50% of their demesne limit
- Added "multiplicative_trade_post_income_modifier" holding modifier
- Added "can_create_empires" government parameter (can_create_kingdoms already exists)
- Added "extra_ai_eval_troops" title parameter. See 00_landed_titles.info for documentation
- Added "relative_realm_size" trigger. For example, relative_realm_size = { who = liege size > 0.2 } checks that your realm size is at least 20% of your liege's
- Strings that are too long (above 1023 characters) will no longer crash the game, though they should still be avoided as they simply don't work beyond 1023 characters. This should also solve crashes involving mismatched quote signs
- Strings that are too long now get logged in error.log
- The game will no longer crash if more than 32767 flags (E.G., set_character_flag) are used. New limit is 2^32, which you will run out of memory long before reaching
- Using export_to_variable on a dead character will no longer crash the game
- has_coa_on_barony_only can now be set to yes/no on individual religions rather than just groups. This will override whatever has been set for the group
- The "give_title" console command now gives more feedback if something is wrong with the parameters
- Absolutely all tooltips now support custom loc. Generally, "Root" will be the player
- Most text directly related to religion (E.G., religion name, description, holy war name) now provide the religion itself for custom loc purposes
- Added a "RelHead" promotion for religion loc, meaning you can now for example name a religion "Cult of [RelHead.GetFirstName]"
- Added optional generate_tooltip parameter for hidden effects. If set to "no", the game won't generate the tooltip at all. Note that if event targets are set in the hidden effect, this will break them in tooltips. It may also break randomization, so only ever use it if you have a really compelling reason to do so
- Added 'add_modifier' and 'remove_modifier' console commands (for Character Modifiers.)
- Added 'decision' console command, which ignores the trigger conditions
- Stewardship no longer applies a debuff when below 5; 0 is its baseline now like all the other stats
- Added 'realm_levies_plus_allies' as an exportable value for the 'export_to_variable' effect.
- Added a Define for Looter army maintenance cost (LOOTER_ARMY_MAINT_MULT)
- random_list chances below 1% but above 0% will now use 2 decimals rather than 0
- The game will now log invalid tributary relationships in history (E.G., someone being a tributary of a title with no holder)
- Fixed looting for raiding adventurers not of a religion/culture/government that allows raiding not working
- If the flag "always_show_in_marriage_selection" is set on a character, they will bypass most conditions to be shown in the marriage selection view. Note that this does *not* allow otherwise illegal marriages, just ensures they show up in the listing
- Fixed observing unplayable characters instantly booting you back to regular observe mode
- Fixed the "completely_controls" trigger not considering empty non-wasteland provinces
- Fixed scoping to event targets in effects not being properly localised, thus showing just a colon with no name before it
- Added "ai_check_interval" parameter for decisions. This determines how rarely the AI checks a given decision, and can be useful for performance-heavy decisions that don't need to be checked often. See 00_decisions.info for documentation
- Added a "shares_realm_border_with" trigger. Checks if any province in your realm (everything under your titles) borders any province in their realm
- Added COALITION_THREAT_MAX_DISTANCE define. Independent AIs will consider independent rulers within this range to be threats if they're strong enough (COALITION_SCARY_TROOP_STRENGTH_THREAT_RATIO)
- "Added COURTIER_EVENT_PROCESS_OFFSET define, which determines how often courtiers check MTTH events. Set to 50, as compared to 20 for rulers". This changelog entry from 2.7 now actually has an effect
- Added num_of_society_members trigger. Scope must be a character or society. Returns true if the society has at least this many members. Also supports <, <=, ==, and >=
- A lot of error messages that previously only showed in the internal beta .exe now get logged at all times
- Added "hire_range" parameter for mercenary titles. If set, this overrides the MERCENARY_HIRE_DISTANCE_THRESHOLD define for that specific mercenary
- Added "can_demand_religious_conversion" government parameter. Decides whether people with the government can use the Demand Religious Conversion interaction. Defaults to yes
- create_character now supports "dynasty = actually_culture" which picks a random dynasty name from the culture if there's no unused static dynasty to use, rather than just resorting to a random holding in the world (what "dynasty = culture" does)
- Now possible to scope to timed modifiers in localisation. For example, if ROOT is a character, [Root.modifier_name.GetExpiryDate] would show the expiry date of the modifier. If no such modifier is present, nothing gets shown. Also supports "GetName"
- random_direct_de_jure_vassal_title now exists. Works like any_direct_de_jure_vassal_title, except picks one at random
- Fixed start_date and current_date checking that the days are equal rather than equal or greater
- All numerical triggers now support comparison operators (>=, <=, <, >, and ==) with a few exceptions: tier triggers, among_most_powerful_vassals. These exceptions are due to operation triggers breaking existing behavior (E.G., "tier = duke" isn't equivalent to "tier >= duke", which the comparison operators assume)
- Added "unsafe_destroy_artifact" effect, which can destroy indestructible artifacts
- Artifact localisation (E.G., name and desc) now provides the artifact as From
- The artifact activation and gift triggers now provide the artifact as From
- Added support for "else_if" and "else". If one of these is placed after an "if" or "else_if", it will be executed if the "if"/"else_if" limit returns false. Example:
   if = { limit = { something = yes } do_something = yes }
   else_if = { limit = { something_else = yes } do_something_else = yes }
   else = { do_another_thing = yes }
- Added trigger "artifact_can_be_gifted_to = ROOT", which checks if the artifact currently scoped to can be gifted to the target character
- Now possible to specify "sound = no" for death reasons, which will prevent killing someone with that reason causing a death sound
- Fixed FROMFROM (the holding title) not always being available in the building trigger
- Fixed whatever character is FROM getting included in event option portrait lists if you scope to something that isn't a character
- Improved the error messages for the reload_texture command, and made it more forgiving when it comes to "/" vs. "\\" and ".dds" vs. ".tga". Also fixed it in some cases crashing. Generally, simply copying the path specified in the .gfx file should work
- Added COST_COMBAT_RATING define for specifying the cost of combat rating in the ruler designer
- Added unsafe_impregnate and unsafe_impregnate_cuckoo effects. These can impregnate someone who is already pregnant, while the two old effects are no longer able to do so
- Added a fail_trigger_effect field for events. This effect is triggered if script attempts to trigger an event, but the trigger isn't fulfilled. Useful for handling things like one character in a chain dying for unrelated reasons partway through the chain
- Fixed not all parts of the society rank tooltip having the appropriate scopes set
- spawn_unit can now take "province = closest_to_capital", which will spawn as close to the character's capital as possible
- The "debug_mode" console command (AKA "charinfo") will now also show extra information about titles

Umuyoruz bu bilgileri ilgi çekici bulmuşsunuzdur.

Son olarak söz verdiğimiz gibi aşağıda 2.8 yama notlarından rastgele 5 madde:
  • Yapayzeka artık spesifik bir ünvanı değil de tüm ülkeyi fethetmek için savaş açtığında, bu ülke uzakta bile olsa o ülkeye ulaşmaya çalışıyor.
  • Sapkınlıkların kutsal toprak ikonu artık holding arayüzünde görüntüleniyor.
  • Asker arayüzünde başka bir özel birime sahip olmanıza rağmen Horse Archer ikonunun görüntülenmesi problemi giderildi.
  • Ordularda artık hangi flank liderinin siege modifierı en yüksekse kuşatmalarda o bonusu kullanıyor, hangi liderin hızı en yüksekse o hızı.
  • Raiding adventurerlar bir yeri ele geçirdikten sonra bu yeni yerin onların üssü olduğunu idrak edip orduları başka bir şeyle meşgul olmadığında buraya çekiyor.
Bu haftalık bu kadar, haftaya Gustav "Gruffa" Groth, CK2'nin ürün şefi sizler için Paradox'un 'yayımcı tarafının' CK2 için yaptıklarından bahsedecek.
Cevapla
 




Konuyu Okuyanlar: 1 Ziyaretçi



Strategyturk Forumları

Strategyturk Forumları tüm Türk stratejiseverler için büyük ve kaliteli bir platform olma amacı güder. Forum içerisinde çok sayıda strateji oyunu için bölüm ve bu bölümlerde haber konuları, rehberler, mod tanıtımları, multiplayer etkinlikleri ve üye paylaşımları için alanlar yer alır.